我已经开发了一段时间的应用程序(在这里),我正在尝试在我的 Android 设备和模拟器上进行这两项测试。
目前我已经在 Travis 上进行了构建,所有测试都运行良好。此外,我设置了一个本地模拟器,可以正常运行。我的物理设备(Moto X)也可以很好地运行一切,但只有在 Dalvik 上时才可以。一旦我切换到 ART,我就会收到以下错误:
11-11 15:28:54.013 6259-6259/org.bspeice.minimalbible E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: org.bspeice.minimalbible, PID: 6259
java.lang.NoClassDefFoundError: org.jdom2.xpath.jaxen.JDOMCoreNavigator
at java.lang.Class.classForName(Native Method)
at java.lang.Class.forName(Class.java:305)
at android.test.ClassPathPackageInfoSource.createPackageInfo(ClassPathPackageInfoSource.java:88)
at android.test.ClassPathPackageInfoSource.access$000(ClassPathPackageInfoSource.java:39)
at android.test.ClassPathPackageInfoSource$1.load(ClassPathPackageInfoSource.java:50)
at android.test.ClassPathPackageInfoSource$1.load(ClassPathPackageInfoSource.java:47)
at android.test.SimpleCache.get(SimpleCache.java:31)
at android.test.ClassPathPackageInfoSource.getPackageInfo(ClassPathPackageInfoSource.java:72)
at android.test.ClassPathPackageInfo.getSubpackages(ClassPathPackageInfo.java:48)
at android.test.ClassPathPackageInfo.addTopLevelClassesTo(ClassPathPackageInfo.java:61)
at android.test.ClassPathPackageInfo.getTopLevelClassesRecursive(ClassPathPackageInfo.java:55)
at android.test.suitebuilder.TestGrouping.testCaseClassesInPackage(TestGrouping.java:156)
at android.test.suitebuilder.TestGrouping.addPackagesRecursive(TestGrouping.java:117)
at android.test.suitebuilder.TestSuiteBuilder.includePackages(TestSuiteBuilder.java:102)
at android.test.InstrumentationTestRunner.onCreate(InstrumentationTestRunner.java:366)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4400)
at android.app.ActivityThread.access$1500(ActivityThread.java:139)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1270)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5086)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
如果有帮助,这里有一个完整的会话跟踪。
所以我的问题是:有什么理由这将是 ART 而不是 Dalvik 的问题?我根本没有更改应用程序构建过程,唯一似乎有所作为的变量是 Dalvik/ART。该应用程序本身运行良好,只是测试有错误。