3

我在为 Android 2.3.x 进行 CTS R12 测试时发现了一个问题。在媒体压力测试中,所有案例均因文件异常而失败。它是由测试用例期间静态变量“FILE_PATH”为空引起的。我发现它在装有 Android 2.3.6 的 NexusOne/NexusS 上是 100% 可重现的。

我还写了一个非常简单的测试项目来测试它,代码附在下面。

活动代码:

package com.hw.hello;

import android.app.Activity;
import android.os.Bundle;

public class HelloActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }
}

测试用例代码:

package com.hw.hello.test;

import com.hw.hello.HelloActivity;

import android.test.ActivityInstrumentationTestCase2;
import android.util.Log;

public class HelloTest extends ActivityInstrumentationTestCase2<HelloActivity> {

    private static final String STR;

    static {
        STR = "XXXXXX";
    }

    public HelloTest() {
        super("com.hw.hello", HelloActivity.class);
    }

    @Override
    public void setUp() {

    }

    public void test1() {
        Log.d("111111", "STR="+STR);
    }

    public void test2() {
        Log.d("222222", "STR="+STR);
    }
}

当你运行它时,你会发现结果是:

02-24 01:24:04.280: D/111111(28075): STR=XXXXXX

02-24 01:24:04.327: D/222222(28075): STR=null

我知道谷歌已经在 ICS 上解决了这个问题。但是我发现 Dalvik VM 的变化太大了,要合并到 2.3.7。我该怎么做才能在 2.3.7 上解决此问题以通过 CTS R12 完成?

==================================================== ===============================

我无法在 8 小时内自己回答我的问题。所以我在这里有答案:

我的法国同事给了我寻找最终解决方案的提示:我发现 ActivityTestCase.java 的 ICS 源代码发生了一些变化

更改是一个附加条件: && (field.getModifiers() & Modifier.FINAL) == 0

@Override
 protected void scrubClass(final Class<?> testCaseClass)
 throws IllegalAccessException {
     final Field[] fields = getClass().getDeclaredFields();
     for (Field field : fields) {
         final Class<?> fieldClass = field.getDeclaringClass();
         if (testCaseClass.isAssignableFrom(fieldClass) && !field.getType().isPrimitive()
                 && (field.getModifiers() & Modifier.FINAL) == 0) {
             try {
                 field.setAccessible(true);
                 field.set(this, null);
             } catch (Exception e) {
                 android.util.Log.d("TestCase", "Error: Could not nullify field!");
             }

             if (field.get(this) != null) {
                 android.util.Log.d("TestCase", "Error: Could not nullify field!");
             }
         }
     }
 }

我将这部分代码放入我的测试用例类中以覆盖超类的方法,现在问题已解决。

4

2 回答 2

1

As @Malcolm 's request

I cannot answer my question myself within 8 hours. So I have the answer here:

My French Colleague gave me the hint to find the final resolution: I have found some change in ICS source code of ActivityTestCase.java

The change is an added condition: && (field.getModifiers() & Modifier.FINAL) == 0

@Override
 protected void scrubClass(final Class<?> testCaseClass)
 throws IllegalAccessException {
     final Field[] fields = getClass().getDeclaredFields();
     for (Field field : fields) {
         final Class<?> fieldClass = field.getDeclaringClass();
         if (testCaseClass.isAssignableFrom(fieldClass) && !field.getType().isPrimitive()
                 && (field.getModifiers() & Modifier.FINAL) == 0) {
             try {
                 field.setAccessible(true);
                 field.set(this, null);
             } catch (Exception e) {
                 android.util.Log.d("TestCase", "Error: Could not nullify field!");
             }

             if (field.get(this) != null) {
                 android.util.Log.d("TestCase", "Error: Could not nullify field!");
             }
         }
     }
 }
于 2013-03-21T02:40:17.380 回答
0

好吧,您可以确保您的静态字段在构造函数中获得适当的值。是的,这是一个丑陋的黑客,但它有效。

于 2012-02-23T14:51:27.283 回答