gpt4 book ai didi

android - android.test.ServiceTestCase 中的 java.lang.NoClassDefFoundError

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:55:30 25 4
gpt4 key购买 nike

每次我开始我的 Android 仪器测试时它都会失败

android.test.suitebuilder.TestSuiteBuilder$FailedToCreateTests:
Error in testSuiteConstructionFailed:
java.lang.RuntimeException: Exception during suite construction
at android.test.suitebuilder.TestSuiteBuilder$FailedToCreateTests.testSuiteConstructionFailed(TestSuiteBuilder.java:239)
at java.lang.reflect.Method.invokeNative(Native Method)
at android.test.AndroidTestRunner.runTest(AndroidTestRunner.java:169)
at android.test.AndroidTestRunner.runTest(AndroidTestRunner.java:154)
at android.test.InstrumentationTestRunner.onStart(InstrumentationTestRunner.java:520)
at android.app.Instrumentation$InstrumentationThread.run(Instrumentation.java:1447)
Caused by: java.lang.reflect.InvocationTargetException
at com.samy4me.test.Test_Service2.<init>(Test_Service2.java:26)
at java.lang.reflect.Constructor.constructNative(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:446)
at android.test.suitebuilder.TestMethod.instantiateTest(TestMethod.java:87)
at android.test.suitebuilder.TestMethod.createTest(TestMethod.java:73)
at android.test.suitebuilder.TestSuiteBuilder.addTest(TestSuiteBuilder.java:263)
at android.test.suitebuilder.TestSuiteBuilder.build(TestSuiteBuilder.java:185)
at android.test.InstrumentationTestRunner.onCreate(InstrumentationTestRunner.java:373)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4218)
at android.app.ActivityThread.access$3000(ActivityThread.java:125)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2071)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4627)
at java.lang.reflect.Method.invokeNative(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NoClassDefFoundError: com.XXX.ws.Service
... 19 more

类(class)就在那里。我检查了 ProGuard,我暂时停用了 ProGuard。我将测试减少到绝对最低限度:

public class Test_Service2
extends android.test.ServiceTestCase<Service>
{

public Test_Service2 ()
{
super (Service.class);
} // Test_Service2
} // Test_Service2

有人知道这是怎么发生的吗?

仔细观察,我现在发现了以下内容:

04-23 15:56:21.186 W/ClassPathPackageInfoSource(  580): Caused by: java.lang.IllegalAccessError: Class ref in pre-verified class resolved to unexpected implementation
04-23 15:56:21.186 W/ClassPathPackageInfoSource( 580): at dalvik.system.DexFile.defineClass(Native Method)
04-23 15:56:21.186 W/ClassPathPackageInfoSource( 580): at dalvik.system.DexFile.loadClassBinaryName(DexFile.java:209)
04-23 15:56:21.186 W/ClassPathPackageInfoSource( 580): at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:203)
04-23 15:56:21.186 W/ClassPathPackageInfoSource( 580): at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
04-23 15:56:21.186 W/ClassPathPackageInfoSource( 580): at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
04-23 15:56:21.186 W/ClassPathPackageInfoSource( 580): ... 26 more

这是原始错误异常链的一部分,但被截断了。预验证异常并不新鲜,它是 Android 开发中的另一个痛点。

最佳答案

好的,我发现了问题 - 主要是 PEBKAC。所以这里是:

  1. 我只看过控制台。但是那里的错误消息被截断了。经验教训:还要始终检查 logcat
  2. 真正的错误是众所周知的预验证错误,当用于主应用程序的库被拖入测试应用程序时会发生这种错误。经验教训:始终确保库不会被拖入仪器测试

如果您像我一样使用 Maven,那么您可以在此处阅读详细信息 Automate Android Test Project ,这是我两周前写给自己的——为了增加尴尬。

关于android - android.test.ServiceTestCase 中的 java.lang.NoClassDefFoundError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5758966/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com