UiDevice.getInstance(getInstrumentation())使用startInstrumentation()

时间:2015-07-17 11:27:39

标签: android ui-automation uiautomator android-uiautomator android-instrumentation

Android SDK:22(L) UiAutomator版本:' com.android.support.test.uiautomator:uiautomator-v18:2.1.1'

在按钮上单击我尝试使用

从Android应用程序访问检测
Boolean start = false;
start = startInstrumentation(new ComponentName("com.automation.vzw.sanity.test", "android.test.InstrumentationTestRunner"), null, null);
  System.out.println("value of start is " +start);

开始的价值显示" true"这表明它已经发布了

问题是:一旦Instrumentation启动并调用setUp(),当执行以下操作时,就会出现Crash

public class ApplicationTest extends InstrumentationTestCase {

 public void setUp() {
              UiDevice testDevice = UiDevice.getInstance(getInstrumentation());
             }

 public void testCase1(){

        System.out.println("In testcase1");

}

}

崩溃详情:

/TestRunner(11209): started: testCase1(com.automation.vzw.sanity.ApplicationTest)

I/TestRunner(11209): failed: testCase1(com.automation.vzw.sanity.ApplicationTest)

I/TestRunner(11209): ----- begin exception -----

I/TestRunner(11209): 

I/TestRunner(11209):   java.lang.NullPointerException: Attempt to invoke virtual method 'void android.app.UiAutomation.setOnAccessibilityEventListener(android.app.UiAutomation$OnAccessibilityEventListener)' on a null object reference

I/TestRunner(11209):    at android.support.test.uiautomator.UiAutomatorBridge.setOnAccessibilityEventListener(UiAutomatorBridge.java:78)

I/TestRunner(11209):    at android.support.test.uiautomator.QueryController.<init>(QueryController.java:58)

I/TestRunner(11209):    at android.support.test.uiautomator.UiAutomatorBridge.<init>(UiAutomatorBridge.java:66)

I/TestRunner(11209):    at android.support.test.uiautomator.InstrumentationUiAutomatorBridge.<init>(InstrumentationUiAutomatorBridge.java:35)

I/TestRunner(11209):    at android.support.test.uiautomator.UiDevice.<init>(UiDevice.java:103)

I/TestRunner(11209):    at android.support.test.uiautomator.UiDevice.getInstance(UiDevice.java:263)

I/TestRunner(11209):    at com.automation.vzw.sanity.ApplicationTest.setUp(ApplicationTest.java:103)

I/TestRunner(11209):    at junit.framework.TestCase.runBare(TestCase.java:132)

I/TestRunner(11209):    at junit.framework.TestResult$1.protect(TestResult.java:115)

I/TestRunner(11209):    at junit.framework.TestResult.runProtected(TestResult.java:133)

I/TestRunner(11209):    at junit.framework.TestResult.run(TestResult.java:118)

I/TestRunner(11209):    at junit.framework.TestCase.run(TestCase.java:124)

I/TestRunner(11209):    at android.test.AndroidTestRunner.runTest(AndroidTestRunner.java:191)

I/TestRunner(11209):    at android.test.AndroidTestRunner.runTest(AndroidTestRunner.java:176)

I/TestRunner(11209):    at android.test.InstrumentationTestRunner.onStart(InstrumentationTestRunner.java:555)

I/TestRunner(11209):    at android.app.Instrumentation$InstrumentationThread.run(Instrumentation.java:1944)

I/TestRunner(11209): ----- end exception -----

I/TestRunner(11209): finished: testCase1(com.automation.vzw.sanity.ApplicationTest)

I/ActivityManager(30686): Force stopping com.automation.vzw.sanity appid=10175 user=0: finished inst

I/ActivityManager(30686): Killing 11209:com.automation.vzw.sanity/u0a175 (adj 0): stop com.automation.vzw.sanity

I/ServiceManager(31912): Waiting for service SurfaceFlinger...

W/ActivityManager(30686): Spurious death for ProcessRecord{2a8ec647 11209:com.automation.vzw.sanity/u0a175}, curProc for 11209: null

注意:从命令行执行时没有问题可以正常工作(仪器-w com.automation.vzw.sanity.test / android.test.InstrumentationTestRunner)

请帮助克服这个

由于

1 个答案:

答案 0 :(得分:1)

那不是你如何获得仪器。使用

Instrumentation instr = InstrumentationRegistry.getInstrumentation();

访问检测。

然后你可以获得一个UiDevice对象:

UiDevice device = UiDevice.getInstance(instr);