Appium 【求解】java.lang.NoClassDefFoundError: android/os/Handler$Callback

叶子 · 2015年05月07日 · 最后由 叶子 回复于 2015年05月07日 · 2443 次阅读

前言:我用 appium 在执行完注册功能之后,我想对通过调用自身的 open sdk 对登录状态做断言

@Test
    public void registerOtherAccount()
    {

        WebElement navigateLt = driver.findElementById("com.xxxx.sample:id/tabpage_indicator_parentview");
        List<WebElement> navigateRLList = navigateLt.findElements(By.className("android.widget.RelativeLayout"));
        navigateRLList.get(4).findElement(By.id("com.xxxxx.sample:id/tabindicator_image")).click();
        driver.findElementByName("使用其他帐户").click();
        driver.findElementByName("注册").click();
        List<WebElement> userTextList = driver.findElements(By.className("android.widget.EditText"));
        Random r = new Random();
        userTextList.get(0).sendKeys("test1369"+r.nextInt(10000));
        userTextList.get(1).sendKeys("qqqqqq");
        driver.findElementById("com.xxxxx.sample:id/usernameregister_register").click();
//调用自己的open sdk 来断言注册后的登录状态
        Assert.assertTrue(AccountManager.isLoggedIn());

    }

出现问题:引入 sdk project 后,一切正常,执行用例时,报如下错误

java.lang.NoClassDefFoundError: android/os/Handler$Callback
    at com.xxxx.open.AccountManager.isLoggedIn(AccountManager.java:114)
    at com.demo.sampleTest.registerOtherAccount(sampleTest.java:157)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
    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.os.Handler$Callback
    at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 27 more


疑问:Caused by: java.lang.ClassNotFoundException: android.os.Handler$Callback,是 appium 不可以使用源码吗?还是回调有什么问题。

求解答

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
共收到 12 条回复 时间 点赞

运行环境里面有这个 AccountManager 么?能调用不代表能运行。而且你这个 AccountManager.isLoggedIn() 是啥,就算不保错,能不能使用还是一回事

你是否缺少等待,我看你点击登录后就立即判断。

#1 楼 @doctorq 我在 Robotium 中是可以这么用的,我是通过 java build path->Project 将 AccountManager 在的 project add 进来的

#1 楼 @doctorq 我想通过调用 sdk 来对登录状态做断言,我的程序如果注册成功,sdk 中 AccountManager.isLoggedIn() 会返回 true

#2 楼 @snake 应该不是等待的问题

#3 楼 @emily robotium 是基于 instrumentation,他的运行环境是在 android 手机里,能用很正常。appium 的客户端只是跟 server 通信,他并不是在 android 系统环境里。

@emily Assert.assertTrue(AccountManager.isLoggedIn()); isLoggedIn 这个 method 的代码能贴出来看看么?

怎么引入 sdk project 的。这个操作看下,然后 sdk 相关的方法看下

#8 楼 @monkey 这个 sample 是嵌入 sdk 的,

/**
     * 检测当前是否有用户登录
     * @return 当前是否有用户登录
     */
public static boolean isLoggedIn()
    {
        if (LoginManager.curLoginUser() != null)
        {
            return true;
        }
        else
        {
            return false;
        }
    }
/**
     * 获取当前登录用户信息
     * @return 当前登录用户信息
     */
public final static UModel curLoginUser(){
        return sCurLoginUser;
    }

#9 楼 @emily 你直接打 jar 放入被测工程试试看

叶子 #11 · 2015年05月07日 Author

#10 楼 @monkey
试了,报一样的错

叶子 #12 · 2015年05月07日 Author

#6 楼 @doctorq 所以说 appium 中不可以这么用?

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册