Android Unit Test在Log上抛出NoClassDefFoundError

Gav*_*ler 6 java junit android unit-testing

我得到一个java.lang.NoClassDefFoundError: android/util/Log错误,当我尝试运行在Eclipse中我的单元测试项目.

蒸馏下来,我的测试代码如下所示:

package com.randomtype.yycparking;

import junit.framework.TestCase;
import android.util.Log;

public class StallTests extends TestCase {  
    public void setUp() {
        Log.v("HI", "Fail");
    }

    public void testShouldParseIdFromTitle() {
        assertTrue(true);
    }
}
Run Code Online (Sandbox Code Playgroud)

并且代码在Log.v调用时抛出异常.当我正常运行android项目时,我没有任何例外Log.

完整堆栈跟踪:

java.lang.NoClassDefFoundError: android/util/Log
    at com.randomtype.yycparking.StallTests.setUp(StallTests.java:11)
    at junit.framework.TestCase.runBare(TestCase.java:132)
    at junit.framework.TestResult$1.protect(TestResult.java:110)
    at junit.framework.TestResult.runProtected(TestResult.java:128)
    at junit.framework.TestResult.run(TestResult.java:113)
    at junit.framework.TestCase.run(TestCase.java:124)
    at junit.framework.TestSuite.runTest(TestSuite.java:243)
    at junit.framework.TestSuite.run(TestSuite.java:238)
    at org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestReference.run(JUnit3TestReference.java:130)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.lang.ClassNotFoundException: android.util.Log
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    ... 14 more
Run Code Online (Sandbox Code Playgroud)

正如dtmilano指出的那样,我没有将单元测试作为一个单元测试Android JUnit Test.你怎么能分辨出来呢?寻找小一个在下面的图片,如:

JUnit图标旁边的屏幕截图

Die*_*ano 4

您的测试应该位于单独的 Android 测试项目中(项目 -> Android 工具 -> 新 Android 项目),并且您应该将它们作为 Android JUnit 测试运行(运行方式 -> Android JUnit 测试)。