Jul*_*les 9 java junit android
我在Android项目中有一个JUnit测试用例,其中包含如下所示的代码:
private static final URI TEST_RESOURCE_URL = TasksService.TASKLIST_RESOURCELIST_URL.resolve("task/test.task");
public void setUp () {
Log.i("Test", "TEST_RESOURCE_URL=" + TEST_RESOURCE_URL);
}
Run Code Online (Sandbox Code Playgroud)
此测试类具有多个测试方法,其中一些参考(但不尝试修改)此常量的值.但是,当我运行这些测试(Android 2.2.2)时,所有这些测试但第一个测试失败了,logcat向我展示了这个:
03-03 18:56:41.791: I/Test(12008): TEST_RESOURCE_URL=http://apate.meridiandigital.net/tasks/task/test.task
03-03 18:56:42.101: I/Test(12008): TEST_RESOURCE_URL=null
03-03 18:56:42.131: I/Test(12008): TEST_RESOURCE_URL=null
03-03 18:56:42.151: I/Test(12008): TEST_RESOURCE_URL=null
03-03 18:56:42.281: I/Test(12008): TEST_RESOURCE_URL=null
03-03 18:56:42.311: I/Test(12008): TEST_RESOURCE_URL=null
03-03 18:56:42.341: I/Test(12008): TEST_RESOURCE_URL=null
03-03 18:56:42.361: I/Test(12008): TEST_RESOURCE_URL=null
03-03 18:56:42.391: I/Test(12008): TEST_RESOURCE_URL=null
03-03 18:56:42.391: I/Test(12008): TEST_RESOURCE_URL=null
Run Code Online (Sandbox Code Playgroud)
静态最终字段如何改变这样的值?我该如何防止这种情况发生?还有其他可能发生的情况吗?
---编辑1
我现在已经将代码修改为一个可以包含在其中的较小示例.见下文:
public class MyService extends Service {
@Override
public IBinder onBind(Intent intent) {
return null;
}
}
public class StaticFinalTest extends ServiceTestCase<MyService> {
public StaticFinalTest() {
super(MyService.class);
}
public static final Object CONST2 = new Object();
public void testA ()
{
assertNotNull (CONST2);
}
public void testB ()
{
assertNotNull (CONST2);
}
}
Run Code Online (Sandbox Code Playgroud)
当此测试运行时,testA通过但testB失败.如果testA被注释掉,testB就会通过.
它是ServiceTestCase似乎很重要.标准的JUnit TestCase不会导致问题.如果'CONST2'是一个String,则两个测试都按预期传递.任何其他参考类型似乎重现了这个问题.
似乎在每次测试后AndroidTestCase使用反射将所有非原始字段设置为.它不会检查字段是静态的还是最终的,因此这似乎是问题的根源.nullscrubClass
要解决此问题,请将字段更改为非最终字段并将其设置为内部setUp.此外,请确保将其super.setUp()作为第一行调用,setUp以确保测试用例已正确初始化.
| 归档时间: |
|
| 查看次数: |
1852 次 |
| 最近记录: |