Вот что я пытаюсь работать на Android 1.6:VerifyError при запуске JUnit Test на Android 1.6
package com.healthlogger.test;
public class AllTests extends TestSuite
{
public static Test suite()
{
return new TestSuiteBuilder(AllTests.class).includeAllPackagesUnderHere().build();
}
}
и:
package com.healthlogger.test;
public class RecordTest extends AndroidTestCase
{
/**
* Ensures that the constructor will not take a null data tag.
*/
@Test(expected=AssertionFailedError.class)
public void testNullDataTagInConstructor()
{
Record r = new Record(null, Calendar.getInstance(), "Data");
fail("Failed to catch null data tag.");
}
}
Основной проект HealthLogger. Они запускаются из отдельного тестового проекта (HealthLoggerTest). HealthLogger и jUnit4 находятся в пути сборки HealthLoggerTest. jUnit4 также находится в пути сборки HealthLogger. Класс «Запись» находится в com.healthlogger.
Комментируя строки «@Test ...» и «Record r ...», этот тест можно запустить. Когда они раскоментированы, я получаю исключение VerifyError. Я сильно заблокирован этим; почему это происходит?
EDIT: некоторая информация от LogCat после аварии:
E/AndroidRuntime(3723): Uncaught handler: thread main exiting due to uncaught exception
E/AndroidRuntime(3723): java.lang.VerifyError: com.healthlogger.test.RecordTest E/AndroidRuntime(3723): at java.lang.Class.getDeclaredConstructors(Native Method)
E/AndroidRuntime(3723): at java.lang.Class.getConstructors(Class.java:507) E/AndroidRuntime(3723): at android.test.suitebuilder.TestGrouping$TestCasePredicate.hasValidConstructor(TestGrouping.java:226)
E/AndroidRuntime(3723): at android.test.suitebuilder.TestGrouping$TestCasePredicate.apply(TestGrouping.java:215)
E/AndroidRuntime(3723): at android.test.suitebuilder.TestGrouping$TestCasePredicate.apply(TestGrouping.java:211)
E/AndroidRuntime(3723): at android.test.suitebuilder.TestGrouping.select(TestGrouping.java:170) E/AndroidRuntime(3723): at android.test.suitebuilder.TestGrouping.selectTestClasses(TestGrouping.java:160)
E/AndroidRuntime(3723): at android.test.suitebuilder.TestGrouping.testCaseClassesInPackage(TestGrouping.java:154)
E/AndroidRuntime(3723): at android.test.suitebuilder.TestGrouping.addPackagesRecursive(TestGrouping.java:115)
E/AndroidRuntime(3723): at android.test.suitebuilder.TestSuiteBuilder.includePackages(TestSuiteBuilder.java:103)
E/AndroidRuntime(3723): at android.test.InstrumentationTestRunner.onCreate(InstrumentationTestRunner.java:321)
E/AndroidRuntime(3723): at android.app.ActivityThread.handleBindApplication(ActivityThread.java:3848)
E/AndroidRuntime(3723): at android.app.ActivityThread.access$2800(ActivityThread.java:116) E/AndroidRuntime(3723): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1831)
E/AndroidRuntime(3723): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(3723): at android.os.Looper.loop(Looper.java:123) E/AndroidRuntime(3723): at android.app.ActivityThread.main(ActivityThread.java:4203)
E/AndroidRuntime(3723): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(3723): at java.lang.reflect.Method.invoke(Method.java:521)
E/AndroidRuntime(3723): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791)
E/AndroidRuntime(3723): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:549) E/AndroidRuntime(3723): at dalvik.system.NativeStart.main(Native Method)
Возможный дубликат [Android JUnit Тесты не работают с java.lang.VerifyError] (http://stackoverflow.com/questions/5437595/android-junit-tests-failing-with-java-lang-verifyerror) –
Вы можете быть верным. К сожалению, я больше не могу пытаться проверить решение этой проблемы - у меня нет устройства 1.6. Если вы чувствуете, что эти два достаточно похожи, не стесняйтесь удалять/закрывать этот вопрос. –
Это происходит в эмуляторе? Если это так, вы можете попробовать его на эмуляторе 1.6. –