赞
踩
1、客户端发送http请求到服务器,服务器层调用AppiumDriver.createSession()建立Session会话;
- self.caps = {}
- self.caps["platformName"] = "Android"
- self.caps["platformVersion"] = devices.dev[Constant.phone]["platformVersion"]
- self.caps["deviceName"] = devices.dev[Constant.phone]["phone"]
- self.caps["appPackage"] = Constant.appPackage
- self.caps["appActivity"] = Constant.appActivity
- self.caps['app'] = Constant.app
- self.caps["unicodeKeyboard"] = True
- self.caps["autoAcceptAlerts"] = True # 对权限弹窗进行授权
- self.caps["resetKeyboard"] = True
- self.caps["noReset"] = True
- self.caps["newCommandTimeout"] = 6000
- self.driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', self.caps) # localhost
对应的日志为
- [HTTP] Request idempotency key: 4bcb8839-2dc6-4d95-8e18-9d8b07c1890c
- [HTTP] --> POST /wd/hub/session
- [HTTP] {"capabilities":{"firstMatch":[{"platformName":"Android","appium:platformVersion":"9","appium:deviceName":"8ADX0QRKA","appium:appPackage":"com.example.helloworld","appium:appActivity":"com.example.helloworld.activity.net.NetMainActivity","appium:app":"","appium:unicodeKeyboard":true,"appium:autoAcceptAlerts":true,"appium:resetKeyboard":true,"appium:noReset":true,"appium:newCommandTimeout":6000}]},"desiredCapabilities":{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000}}
- [W3C] Calling AppiumDriver.createSession() with args: [{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000},null,{"firstMatch":[{"platformName":"Android","appium:platformVersion":"9","appium:deviceName":"8ADX0QRKA","appium:appPackage":"com.example.helloworld","appium:appActivity":"com.example.helloworld.activity.net.NetMainActivity","appium:app":"","appium:unicodeKeyboard":true,"appium:autoAcceptAlerts":true,"appium:resetKeyboard":true,"appium:noReset":true,"appium:newCommandTimeout":6000}]}]
- [BaseDriver] Event 'newSessionRequested' logged at 1658716967870 (10:42:47 GMT+0800 (中国标准时间))
2、appium利用desired capabilities创建新的AndroidUiautomator2Driver (v1.65.0) session
得到session id; 这个驱动应该是和手机端代理程序通信的吧??
- [Appium] Appium v1.21.0 creating new AndroidUiautomator2Driver (v1.65.0) session
- [Appium] Applying relaxed security to 'AndroidUiautomator2Driver' as per server command line argument. All insecure features will be enabled unless explicitly disabled by --deny-insecure
- [BaseDriver] W3C capabilities and MJSONWP desired capabilities were provided
- [BaseDriver] Creating session with W3C capabilities: {
- [BaseDriver] "alwaysMatch": {
- [BaseDriver] "platformName": "Android",
- [BaseDriver] "appium:platformVersion": "9",
- [BaseDriver] "appium:deviceName": "8ADX0QRKA",
- [BaseDriver] "appium:appPackage": "com.example.helloworld",
- [BaseDriver] "appium:appActivity": "com.example.helloworld.activity.net.NetMainActivity",
- [BaseDriver] "appium:app": "",
- [BaseDriver] "appium:unicodeKeyboard": true,
- [BaseDriver] "appium:autoAcceptAlerts": true,
- [BaseDriver] "appium:resetKeyboard": true,
- [BaseDriver] "appium:noReset": true,
- [BaseDriver] "appium:newCommandTimeout": 6000
- [BaseDriver] },
- [BaseDriver] "firstMatch": [
- [BaseDriver] {}
- [BaseDriver] ]
- [BaseDriver] }
- [BaseDriver] The following capabilities were provided, but are not recognized by Appium:
- [BaseDriver] autoAcceptAlerts
- [BaseDriver] Session created with session id: 84d8194f-eb08-440d-a4f8-d9cf06ec8bf6

3、接下来通过adb命令获取pc端都有哪些android build-tools可使用。---所以在appium应用程序上需要配置pc端Android Sdk的路径;
- [UiAutomator2] Starting 'com.example.helloworld' directly on the device
- [ADB] Found 8 'build-tools' folders under '/Users/liuqinhou/Library/Android/sdk' (newest first):
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.2
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.1
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/29.0.3
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/29.0.2
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/28.0.3
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/27.0.3
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/26.0.2
4、使用adb启动adb服务
- [ADB] Using 'adb' from '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 start-server'
5、获取pc端已连接的手机设备列表
- [AndroidDriver] Retrieving device list
- [ADB] Trying to find a connected android device
- [ADB] Getting connected devices
- [ADB] Connected devices: [{"udid":"efaa068a7d2a","state":"device"}]
6、利用desired capabilities找出符合条件的手机设备
- [AndroidDriver] Looking for a device with Android '9.0.0'
- [ADB] Setting device id to efaa068a7d2a
- [ADB] Getting device platform version
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.release'
- [ADB] Current device property 'ro.build.version.release': 9
- [AndroidDriver] Using device: efaa068a7d2a
- [ADB] Using 'adb' from '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 start-server'
- [ADB] Setting device id to efaa068a7d2a
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.sdk'
- [ADB] Current device property 'ro.build.version.sdk': 28
- [ADB] Getting device platform version
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.release'
- [ADB] Current device property 'ro.build.version.release': 9
- [ADB] Device API level: 28
- [UiAutomator2] Relaxing hidden api policy
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell 'settings put global hidden_api_policy_pre_p_apps 1;settings put global hidden_api_policy_p_apps 1;settings put global hidden_api_policy 1''

7、安装io.appium.setting代理程序
使用appium,appium服务端需要和手机进行通信,所以手机端要安装一个代理程序,这个程序专门负责和pc端的appium server进行通信。可以通过日志看出,appium会先检查手机上是否安装了包名为”io.appium.setting“的应用程序。如果没有安装的话,就会把pc端保持的这个应用程序包push到手机上,然后安装。
7.1、检查是否安装io.appium.settings
adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.settings
7.2、push pc端io.appium.settings到手机端,并执行安装
adb -P 5037 -s efaa068a7d2a install -g /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/io.appium.settings/apks/settings_apk-debug.apk
7.3、启动手机端的io.appium.settings应用程序
adb -P 5037 -s efaa068a7d2a shell am start -n io.appium.settings/.Settings -a android.intent.action.MAIN -c android.intent.category.LAUNCHER'
8、开启日志捕获
adb -P 5037 -s efaa068a7d2a logcat -v threadtime
9、确保支持unicode 键盘 Enabling Unicode keyboard support
adb -P 5037 -s efaa068a7d2a shell settings get secure default_input_method'
即这一步使得程序运行时使用的是io.appium.settings自己的输入法,而不是系统自带的
- [AndroidDriver] Enabling Unicode keyboard support
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell settings get secure default_input_method'
- [AndroidDriver] Unsetting previous IME com.sohu.inputmethod.sogou.xiaomi/.SogouIME
- [AndroidDriver] Setting IME to 'io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime enable io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime set io.appium.settings/.UnicodeIME'
10、利用adb forward进行端口转发,即转发手机端uiautomator服务的端口6790 到pc本地的8200端口;
- [UiAutomator2] Forwarding UiAutomator2 Server port 6790 to local port 8200
- [ADB] Forwarding system: 8200 to device: 6790
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a forward tcp:8200 tcp:6790'
10.1.1、先检查手机端的io.appium.uiautomator2.server服务是否在运行;
10.1.2、如果检测到没有该服务,再检查appium-uiautomator2-server-v4.21.1.apk安装包是否已安装。如果该安装包未安装,则继续检查pc端存放的appium-uiautomator2-server-v4.21.1.apk的证书。使用Android/sdk/build-tools/30.0.3/lib/apksigner.jar的apk签名包对appium-uiautomator2-server-v4.21.1.apk进行签名,得到使用签名文件签好名的安装包;
10.2.1、再检查手机端io.appium.uiautomator2.server.test服务是否在运行;
10.2.2、如果该服务不在运行,再检查appium-uiautomator2-server-debug-androidTest.apk安装包是否已安装。如果未安装,则apksigner.jar使用对其进行签名;
- Getting install status for io.appium.uiautomator2.server.test
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.uiautomator2.server.test'
- [ADB] 'io.appium.uiautomator2.server.test' is not installed
- [ADB] Checking app cert for /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk
- [ADB] Using 'apksigner.jar' from '/Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3/lib/apksigner.jar'
- [ADB] Starting apksigner: /Library/Java/JavaVirtualMachines/jdk1.8.0_271.jdk/Contents/Home/bin/java -Xmx1024M -Xss1m -jar /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3/lib/apksigner.jar verify --print-certs /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk
- [ADB] apksigner stdout: Signer #1 certificate DN: EMAILADDRESS=android@android.com, CN=Android, OU=Android, O=Android, L=Mountain View, ST=California, C=US
- [ADB] Signer #1 certificate SHA-256 digest: a40da80a59d170caa950cf15c18c454d47a39b26989d8b640ecd745ba71bf5dc
- [ADB] Signer #1 certificate SHA-1 digest: 61ed377e85d386a8dfee6b864bd85b0bfaa5af81
- [ADB] Signer #1 certificate MD5 digest: e89b158e4bcf988ebd09eb83f5378e87
- [ADB]
- [ADB] sha256 hash did match for 'appium-uiautomator2-server-v4.21.1.apk'
- [ADB] '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' is signed with the default certificate
如果存在则检查服务版本号是否一致,不一致的话使用最新的版本
- Getting install status for io.appium.uiautomator2.server
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.uiautomator2.server'
- [ADB] 'io.appium.uiautomator2.server' is installed
- [ADB] Getting package info for 'io.appium.uiautomator2.server'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.uiautomator2.server'
- [ADB] The version name of the installed 'io.appium.uiautomator2.server' is greater or equal to the application version name ('4.21.1' >= '4.21.1')
- [UiAutomator2] io.appium.uiautomator2.server installation state: sameVersionInstalled
10.3、安装appium-uiautomator2-server-v4.21.1.apk
adb -P 5037 -s efaa068a7d2a install -r /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk'
10.4、安装appium-uiautomator2-server-debug-androidTest.apk
adb -P 5037 -s efaa068a7d2a install -r /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk'
10.5、执行pm list instrumentation获取到已经安装在设备中的instrumetation测试包;
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell pm list instrumentation'
- [UiAutomator2] Instrumentation target 'io.appium.uiautomator2.server.test/androidx.test.runner.AndroidJUnitRunner' is available
- xxxx-MB0 ~ % adb shell pm list instrumentation
- instrumentation:com.example.helloworld/androidx.test.runner.AndroidJUnitRunner (target=com.example.helloworld)
- instrumentation:com.snda.wifilocating/com.lantern.daemon.farmore.ExportInstrumentation (target=com.snda.wifilocating)
- instrumentation:com.xunmeng.pinduoduo/.jessie.JessieInstrument (target=com.xunmeng.pinduoduo)
- instrumentation:io.appium.uiautomator2.server.test/androidx.test.runner.AndroidJUnitRunner (target=io.appium.uiautomator2.server)
上面是通过adb在手机端运行的结果,可以看到设备上已安装的instrumetation测试包。
10.6、把手机端的["io.appium.settings","io.appium.uiautomator2.server","io.appium.uiautomator2.server.test"]加入到doze白名单中,使自己的App不受打盹模式的影响。
- [ADB] Adding packages ["io.appium.settings","io.appium.uiautomator2.server","io.appium.uiautomator2.server.test"] to Doze whitelist
- [ADB] Got the following command chunks to execute: [["dumpsys","deviceidle","whitelist","+io.appium.settings",";","dumpsys","deviceidle","whitelist","+io.appium.uiautomator2.server",";","dumpsys","deviceidle","whitelist","+io.appium.uiautomator2.server.test",";"]]
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys deviceidle whitelist +io.appium.settings ; dumpsys deviceidle whitelist +io.appium.uiautomator2.server ; dumpsys deviceidle whitelist +io.appium.uiautomator2.server.test ;'
10.7 强制关闭io.appium.uiautomator2.server.test
- [UiAutomator2] No app capability. Assuming it is already on the device
- [UiAutomator2] Performing shallow cleanup of automation leftovers
- [UiAutomator2] No obsolete sessions have been detected (socket hang up)
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell am force-stop io.appium.uiautomator2.server.test'
10.8、启动UIAutomator2 server
- [UiAutomator2] Starting UIAutomator2 server 4.21.1
- [UiAutomator2] Using UIAutomator2 server from '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' and test from '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk'
- [UiAutomator2] Waiting up to 30000ms for UiAutomator2 to be online...
10.9、创建adb子进程,并执行instrumentation进程初始化,运行测试包的运行器并等待其完成;
- [ADB] Creating ADB subprocess with args: ["-P",5037,"-s","efaa068a7d2a","shell","am","instrument","-w","-e","disableAnalytics",true,"io.appium.uiautomator2.server.test/androidx.test.runner.AndroidJUnitRunner"]
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [Instrumentation] io.appium.uiautomator2.server.test.AppiumUiAutomator2Server:
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] Got response with status 200: {"sessionId":"None","value":{"message":"UiAutomator2 Server is ready to accept commands","ready":true}}
- [UiAutomator2] The initialization of the instrumentation process took 5318ms

10.10、 通过am start命令开始执行测试用例
adb -P 5037 -s efaa068a7d2a shell am start -W -n com.example.helloworld/com.example.helloworld.activity.net.NetMainActivity -S -a android.intent.action.MAIN -c android.intent.category.LAUNCHER -f 0x10200000
10.11、测试用例执行完或出现异常终止程序运行后,恢复现场:
1、停止抓取日志logcat
2、关闭所有会话
3、恢复手机输入法
4、关闭待测试应用程序
5、停止录像
6、断开tcp端口转发
- [Logcat] Logcat terminated with code 1, signal null
- [BaseDriver] Shutting down because we waited 6000 seconds for a command
- [Appium] Closing session, cause was 'New Command Timeout of 6000 seconds expired. Try customizing the timeout using the 'newCommandTimeout' desired capability'
- [Appium] Removing session '272490bd-2f8b-402b-a423-7ca967433bdc' from our master session list
- [UiAutomator2] Deleting UiAutomator2 session
- [UiAutomator2] Deleting UiAutomator2 server session
- [WD Proxy] Matched '/' to command name 'deleteSession'
- [WD Proxy] Proxying [DELETE /] to [DELETE http://127.0.0.1:8200/wd/hub/session/520a226c-513e-4009-9105-5bd916b9772d] with no body
- [WD Proxy] Got response with status 200: {"sessionId":"520a226c-513e-4009-9105-5bd916b9772d","value":null}
- [UiAutomator2] Resetting IME to 'io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime set io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell am force-stop com.example.helloworld'
- [Logcat] Stopping logcat capture
- [Logcat] Logcat already stopped
- [ADB] Removing forwarded port socket connection: 8200
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a forward --remove tcp:8200'
- [UiAutomator2] Restoring hidden api policy to the device default configuration
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell 'settings delete global hidden_api_policy_pre_p_apps;settings delete global hidden_api_policy_p_apps;settings delete global hidden_api_policy''
- [Instrumentation] .
- [Instrumentation] Time: 6,004.981
- [Instrumentation]
- [Instrumentation] OK (1 test)
- [Instrumentation] The process has exited with code 0

完整日志为
-
- The server is running
- [Appium] Welcome to Appium v1.21.0
- [Appium] Non-default server args:
- [Appium] relaxedSecurityEnabled: true
- [Appium] allowInsecure: {
- [Appium] }
- [Appium] denyInsecure: {
- [Appium] }
- [Appium] Appium REST http interface listener started on 0.0.0.0:4723
- [HTTP] Request idempotency key: 4bcb8839-2dc6-4d95-8e18-9d8b07c1890c
- [HTTP] --> POST /wd/hub/session
- [HTTP] {"capabilities":{"firstMatch":[{"platformName":"Android","appium:platformVersion":"9","appium:deviceName":"8ADX0QRKA","appium:appPackage":"com.example.helloworld","appium:appActivity":"com.example.helloworld.activity.net.NetMainActivity","appium:app":"","appium:unicodeKeyboard":true,"appium:autoAcceptAlerts":true,"appium:resetKeyboard":true,"appium:noReset":true,"appium:newCommandTimeout":6000}]},"desiredCapabilities":{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000}}
- [W3C] Calling AppiumDriver.createSession() with args: [{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000},null,{"firstMatch":[{"platformName":"Android","appium:platformVersion":"9","appium:deviceName":"8ADX0QRKA","appium:appPackage":"com.example.helloworld","appium:appActivity":"com.example.helloworld.activity.net.NetMainActivity","appium:app":"","appium:unicodeKeyboard":true,"appium:autoAcceptAlerts":true,"appium:resetKeyboard":true,"appium:noReset":true,"appium:newCommandTimeout":6000}]}]
- [BaseDriver] Event 'newSessionRequested' logged at 1658716967870 (10:42:47 GMT+0800 (中国标准时间))
- [Appium]
- [Appium] ======================================================================
- [Appium] DEPRECATION WARNING:
- [Appium]
- [Appium] The 'automationName' capability was not provided in the desired
- [Appium] capabilities for this Android session
- [Appium]
- [Appium] Setting 'automationName=UiAutomator2' by default and using the
- [Appium] UiAutomator2 Driver
- [Appium]
- [Appium] The next major version of Appium (2.x) will **require** the
- [Appium] 'automationName' capability to be set for all sessions on all
- [Appium] platforms
- [Appium]
- [Appium] In previous versions (Appium <= 1.13.x), the default was
- [Appium] 'automationName=UiAutomator1'
- [Appium]
- [Appium] If you wish to use that automation instead of UiAutomator2, please
- [Appium] add 'automationName=UiAutomator1' to your desired capabilities
- [Appium]
- [Appium] For more information about drivers, please visit
- [Appium] http://appium.io/docs/en/about-appium/intro/ and explore the
- [Appium] 'Drivers' menu
- [Appium]
- [Appium] ======================================================================
- [Appium]
- [Appium] Appium v1.21.0 creating new AndroidUiautomator2Driver (v1.65.0) session
- [Appium] Applying relaxed security to 'AndroidUiautomator2Driver' as per server command line argument. All insecure features will be enabled unless explicitly disabled by --deny-insecure
- [BaseDriver] W3C capabilities and MJSONWP desired capabilities were provided
- [BaseDriver] Creating session with W3C capabilities: {
- [BaseDriver] "alwaysMatch": {
- [BaseDriver] "platformName": "Android",
- [BaseDriver] "appium:platformVersion": "9",
- [BaseDriver] "appium:deviceName": "8ADX0QRKA",
- [BaseDriver] "appium:appPackage": "com.example.helloworld",
- [BaseDriver] "appium:appActivity": "com.example.helloworld.activity.net.NetMainActivity",
- [BaseDriver] "appium:app": "",
- [BaseDriver] "appium:unicodeKeyboard": true,
- [BaseDriver] "appium:autoAcceptAlerts": true,
- [BaseDriver] "appium:resetKeyboard": true,
- [BaseDriver] "appium:noReset": true,
- [BaseDriver] "appium:newCommandTimeout": 6000
- [BaseDriver] },
- [BaseDriver] "firstMatch": [
- [BaseDriver] {}
- [BaseDriver] ]
- [BaseDriver] }
- [BaseDriver] The following capabilities were provided, but are not recognized by Appium:
- [BaseDriver] autoAcceptAlerts
- [BaseDriver] Session created with session id: 84d8194f-eb08-440d-a4f8-d9cf06ec8bf6
- [UiAutomator2] Starting 'com.example.helloworld' directly on the device
- [ADB] Found 8 'build-tools' folders under '/Users/liuqinhou/Library/Android/sdk' (newest first):
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.2
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.1
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/29.0.3
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/29.0.2
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/28.0.3
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/27.0.3
- [ADB] /Users/liuqinhou/Library/Android/sdk/build-tools/26.0.2
- [ADB] Using 'adb' from '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 start-server'
- [AndroidDriver] Retrieving device list
- [ADB] Trying to find a connected android device
- [ADB] Getting connected devices
- [ADB] Connected devices: [{"udid":"efaa068a7d2a","state":"device"}]
- [AndroidDriver] Looking for a device with Android '9.0.0'
- [ADB] Setting device id to efaa068a7d2a
- [ADB] Getting device platform version
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.release'
- [ADB] Current device property 'ro.build.version.release': 9
- [AndroidDriver] Using device: efaa068a7d2a
- [ADB] Using 'adb' from '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 start-server'
- [ADB] Setting device id to efaa068a7d2a
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.sdk'
- [ADB] Current device property 'ro.build.version.sdk': 28
- [ADB] Getting device platform version
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.release'
- [ADB] Current device property 'ro.build.version.release': 9
- [ADB] Device API level: 28
- [UiAutomator2] Relaxing hidden api policy
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell 'settings put global hidden_api_policy_pre_p_apps 1;settings put global hidden_api_policy_p_apps 1;settings put global hidden_api_policy 1''
- [AndroidDriver] No app sent in, not parsing package/activity
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a wait-for-device'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell echo ping'
- [AndroidDriver] Pushing settings apk to device...
- [ADB] Getting install status for io.appium.settings
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.settings'
- [ADB] 'io.appium.settings' is not installed
- [ADB] App '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/io.appium.settings/apks/settings_apk-debug.apk' is not installed
- [ADB] Installing '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/io.appium.settings/apks/settings_apk-debug.apk'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a help'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a features'
- [ADB] The application at '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/io.appium.settings/apks/settings_apk-debug.apk' will not be cached, because the device under test has confirmed the support of streamed installs
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a install -g /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/io.appium.settings/apks/settings_apk-debug.apk'
- [ADB] The installation of 'settings_apk-debug.apk' took 6915ms
- [ADB] Install command stdout: Performing Streamed Install
- [ADB] Success
- [ADB] Getting IDs of all 'io.appium.settings' processes
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell 'pgrep --help; echo $?''
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell pgrep -f \(\[\[:blank:\]\]\|\^\)io\.appium\.settings\(\[\[:blank:\]\]\|\$\)'
- [ADB] Getting IDs of all 'io.appium.settings' processes
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell pgrep -f \(\[\[:blank:\]\]\|\^\)io\.appium\.settings\(\[\[:blank:\]\]\|\$\)'
- [ADB] Starting Appium Settings app
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell am start -n io.appium.settings/.Settings -a android.intent.action.MAIN -c android.intent.category.LAUNCHER'
- [ADB] Getting IDs of all 'io.appium.settings' processes
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell pgrep -f \(\[\[:blank:\]\]\|\^\)io\.appium\.settings\(\[\[:blank:\]\]\|\$\)'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell appops set io.appium.settings android:mock_location allow'
- [Logcat] Starting logs capture with command: /Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a logcat -v threadtime
- [AndroidDriver] Enabling Unicode keyboard support
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell settings get secure default_input_method'
- [AndroidDriver] Unsetting previous IME com.sohu.inputmethod.sogou.xiaomi/.SogouIME
- [AndroidDriver] Setting IME to 'io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime enable io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime set io.appium.settings/.UnicodeIME'
- [UiAutomator2] Forwarding UiAutomator2 Server port 6790 to local port 8200
- [ADB] Forwarding system: 8200 to device: 6790
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a forward tcp:8200 tcp:6790'
- [ADB] Getting install status for io.appium.uiautomator2.server
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.uiautomator2.server'
- [ADB] 'io.appium.uiautomator2.server' is not installed
- [ADB] App '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' is not installed
- [UiAutomator2] io.appium.uiautomator2.server installation state: notInstalled
- [ADB] Checking app cert for /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk
- [ADB] Using 'apksigner.jar' from '/Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3/lib/apksigner.jar'
- [ADB] Starting apksigner: /Library/Java/JavaVirtualMachines/jdk1.8.0_271.jdk/Contents/Home/bin/java -Xmx1024M -Xss1m -jar /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3/lib/apksigner.jar verify --print-certs /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk
- [ADB] apksigner stdout: Signer #1 certificate DN: EMAILADDRESS=android@android.com, CN=Android, OU=Android, O=Android, L=Mountain View, ST=California, C=US
- [ADB] Signer #1 certificate SHA-256 digest: a40da80a59d170caa950cf15c18c454d47a39b26989d8b640ecd745ba71bf5dc
- [ADB] Signer #1 certificate SHA-1 digest: 61ed377e85d386a8dfee6b864bd85b0bfaa5af81
- [ADB] Signer #1 certificate MD5 digest: e89b158e4bcf988ebd09eb83f5378e87
- [ADB]
- [ADB] sha256 hash did match for 'appium-uiautomator2-server-v4.21.1.apk'
- [ADB] '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' is signed with the default certificate
- [ADB] Getting install status for io.appium.uiautomator2.server.test
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.uiautomator2.server.test'
- [ADB] 'io.appium.uiautomator2.server.test' is not installed
- [ADB] Checking app cert for /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk
- [ADB] Starting apksigner: /Library/Java/JavaVirtualMachines/jdk1.8.0_271.jdk/Contents/Home/bin/java -Xmx1024M -Xss1m -jar /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3/lib/apksigner.jar verify --print-certs /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk
- [ADB] apksigner stdout: Signer #1 certificate DN: EMAILADDRESS=android@android.com, CN=Android, OU=Android, O=Android, L=Mountain View, ST=California, C=US
- [ADB] Signer #1 certificate SHA-256 digest: a40da80a59d170caa950cf15c18c454d47a39b26989d8b640ecd745ba71bf5dc
- [ADB] Signer #1 certificate SHA-1 digest: 61ed377e85d386a8dfee6b864bd85b0bfaa5af81
- [ADB] Signer #1 certificate MD5 digest: e89b158e4bcf988ebd09eb83f5378e87
- [ADB]
- [ADB] sha256 hash did match for 'appium-uiautomator2-server-debug-androidTest.apk'
- [ADB] '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk' is signed with the default certificate
- [UiAutomator2] Server packages are going to be (re)installed
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a version'
- [ADB] The application at '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' will not be cached, because the device under test has confirmed the support of streamed installs
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a install -r /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk'
- [Logcat] Logcat terminated with code 0, signal null
- [UiAutomator2] Deleting UiAutomator2 session
- [UiAutomator2] Deleting UiAutomator2 server session
- [WD Proxy] Matched '/' to command name 'deleteSession'
- [UiAutomator2] Did not get confirmation UiAutomator2 deleteSession worked; Error was: UnknownError: An unknown server-side error occurred while processing the command. Original error: Trying to proxy a session command without session id
- [UiAutomator2] Resetting IME to 'com.sohu.inputmethod.sogou.xiaomi/.SogouIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime set com.sohu.inputmethod.sogou.xiaomi/.SogouIME'
- [UiAutomator2] Unable to reset IME: Error executing adbExec. Original error: 'Command '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime set com.sohu.inputmethod.sogou.xiaomi/.SogouIME' exited with code 1'; Stderr: 'adb: device 'efaa068a7d2a' not found'; Code: '1'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell am force-stop com.example.helloworld'
- [UiAutomator2] Unable to force stop app: Error executing adbExec. Original error: 'Command '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell am force-stop com.example.helloworld' exited with code 1'; Stderr: 'adb: device 'efaa068a7d2a' not found'; Code: '1'
- [Logcat] Stopping logcat capture
- [Logcat] Logcat already stopped
- [ADB] Removing forwarded port socket connection: 8200
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a forward --remove tcp:8200'
- [ADB] Error sending command, reconnecting device and retrying: forward,--remove,tcp:8200
- [ADB] Trying to find a connected android device
- [ADB] Getting connected devices
- [ADB] Connected devices: [{"udid":"efaa068a7d2a","state":"device"}]
- [UiAutomator2] Unable to remove system port forward: Error executing adbExec. Original error: 'Command '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a forward --remove tcp\:8200' exited with code 1'; Stderr: 'adb: error: device 'efaa068a7d2a' not found'; Code: '1'
- [UiAutomator2] Restoring hidden api policy to the device default configuration
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell 'settings delete global hidden_api_policy_pre_p_apps;settings delete global hidden_api_policy_p_apps;settings delete global hidden_api_policy''
- [BaseDriver] Event 'newSessionStarted' logged at 1658716987874 (10:43:07 GMT+0800 (中国标准时间))
- [W3C] Encountered internal error running command: Error executing adbExec. Original error: 'Command '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a install -r /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' exited with code 1'; Stderr: 'adb: failed to install /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk:'; Code: '1'
- [W3C] Error: Command '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a install -r /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' exited with code 1
- [W3C] at ChildProcess. (/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/teen_process/lib/exec.js:113:19)
- [W3C] at ChildProcess.emit (events.js:203:13)
- [W3C] at maybeClose (internal/child_process.js:1021:16)
- [W3C] at Socket. (internal/child_process.js:430:11)
- [W3C] at Socket.emit (events.js:203:13)
- [W3C] at Pipe. (net.js:588:12)
- [HTTP] <-- POST /wd/hub/session 500 20055 ms - 1587
- [HTTP]
- [HTTP] Request idempotency key: e00bf29b-e874-42ea-8bb6-592a1cf35e32
- [HTTP] --> POST /wd/hub/session
- [HTTP] {"capabilities":{"firstMatch":[{"platformName":"Android","appium:platformVersion":"9","appium:deviceName":"8ADX0QRKA","appium:appPackage":"com.example.helloworld","appium:appActivity":"com.example.helloworld.activity.net.NetMainActivity","appium:app":"","appium:unicodeKeyboard":true,"appium:autoAcceptAlerts":true,"appium:resetKeyboard":true,"appium:noReset":true,"appium:newCommandTimeout":6000}]},"desiredCapabilities":{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000}}
- [W3C] Calling AppiumDriver.createSession() with args: [{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000},null,{"firstMatch":[{"platformName":"Android","appium:platformVersion":"9","appium:deviceName":"8ADX0QRKA","appium:appPackage":"com.example.helloworld","appium:appActivity":"com.example.helloworld.activity.net.NetMainActivity","appium:app":"","appium:unicodeKeyboard":true,"appium:autoAcceptAlerts":true,"appium:resetKeyboard":true,"appium:noReset":true,"appium:newCommandTimeout":6000}]}]
- [BaseDriver] Event 'newSessionRequested' logged at 1658717004641 (10:43:24 GMT+0800 (中国标准时间))
- [Appium]
- [Appium] ======================================================================
- [Appium] DEPRECATION WARNING:
- [Appium]
- [Appium] The 'automationName' capability was not provided in the desired
- [Appium] capabilities for this Android session
- [Appium]
- [Appium] Setting 'automationName=UiAutomator2' by default and using the
- [Appium] UiAutomator2 Driver
- [Appium]
- [Appium] The next major version of Appium (2.x) will **require** the
- [Appium] 'automationName' capability to be set for all sessions on all
- [Appium] platforms
- [Appium]
- [Appium] In previous versions (Appium <= 1.13.x), the default was
- [Appium] 'automationName=UiAutomator1'
- [Appium]
- [Appium] If you wish to use that automation instead of UiAutomator2, please
- [Appium] add 'automationName=UiAutomator1' to your desired capabilities
- [Appium]
- [Appium] For more information about drivers, please visit
- [Appium] http://appium.io/docs/en/about-appium/intro/ and explore the
- [Appium] 'Drivers' menu
- [Appium]
- [Appium] ======================================================================
- [Appium]
- [Appium] Appium v1.21.0 creating new AndroidUiautomator2Driver (v1.65.0) session
- [Appium] Applying relaxed security to 'AndroidUiautomator2Driver' as per server command line argument. All insecure features will be enabled unless explicitly disabled by --deny-insecure
- [BaseDriver] W3C capabilities and MJSONWP desired capabilities were provided
- [BaseDriver] Creating session with W3C capabilities: {
- [BaseDriver] "alwaysMatch": {
- [BaseDriver] "platformName": "Android",
- [BaseDriver] "appium:platformVersion": "9",
- [BaseDriver] "appium:deviceName": "8ADX0QRKA",
- [BaseDriver] "appium:appPackage": "com.example.helloworld",
- [BaseDriver] "appium:appActivity": "com.example.helloworld.activity.net.NetMainActivity",
- [BaseDriver] "appium:app": "",
- [BaseDriver] "appium:unicodeKeyboard": true,
- [BaseDriver] "appium:autoAcceptAlerts": true,
- [BaseDriver] "appium:resetKeyboard": true,
- [BaseDriver] "appium:noReset": true,
- [BaseDriver] "appium:newCommandTimeout": 6000
- [BaseDriver] },
- [BaseDriver] "firstMatch": [
- [BaseDriver] {}
- [BaseDriver] ]
- [BaseDriver] }
- [BaseDriver] The following capabilities were provided, but are not recognized by Appium:
- [BaseDriver] autoAcceptAlerts
- [BaseDriver] Session created with session id: 272490bd-2f8b-402b-a423-7ca967433bdc
- [UiAutomator2] Starting 'com.example.helloworld' directly on the device
- [ADB] Using 'adb' from '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 start-server'
- [AndroidDriver] Retrieving device list
- [ADB] Trying to find a connected android device
- [ADB] Getting connected devices
- [ADB] Connected devices: [{"udid":"efaa068a7d2a","state":"device"}]
- [AndroidDriver] Looking for a device with Android '9.0.0'
- [ADB] Setting device id to efaa068a7d2a
- [ADB] Getting device platform version
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.release'
- [ADB] Current device property 'ro.build.version.release': 9
- [AndroidDriver] Using device: efaa068a7d2a
- [ADB] Using 'adb' from '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 start-server'
- [ADB] Setting device id to efaa068a7d2a
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.sdk'
- [ADB] Current device property 'ro.build.version.sdk': 28
- [ADB] Getting device platform version
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell getprop ro.build.version.release'
- [ADB] Current device property 'ro.build.version.release': 9
- [ADB] Device API level: 28
- [UiAutomator2] Relaxing hidden api policy
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell 'settings put global hidden_api_policy_pre_p_apps 1;settings put global hidden_api_policy_p_apps 1;settings put global hidden_api_policy 1''
- [AndroidDriver] No app sent in, not parsing package/activity
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a wait-for-device'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell echo ping'
- [AndroidDriver] Pushing settings apk to device...
- [ADB] Getting install status for io.appium.settings
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.settings'
- [ADB] 'io.appium.settings' is installed
- [ADB] Getting package info for 'io.appium.settings'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.settings'
- [ADB] The version name of the installed 'io.appium.settings' is greater or equal to the application version name ('3.3.0' >= '3.3.0')
- [ADB] There is no need to install/upgrade '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/io.appium.settings/apks/settings_apk-debug.apk'
- [ADB] Getting IDs of all 'io.appium.settings' processes
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell 'pgrep --help; echo $?''
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell pgrep -f \(\[\[:blank:\]\]\|\^\)io\.appium\.settings\(\[\[:blank:\]\]\|\$\)'
- [AndroidDriver] io.appium.settings is already running. There is no need to reset its permissions.
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell appops set io.appium.settings android:mock_location allow'
- [Logcat] Starting logs capture with command: /Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a logcat -v threadtime
- [AndroidDriver] Enabling Unicode keyboard support
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell settings get secure default_input_method'
- [AndroidDriver] Unsetting previous IME io.appium.settings/.UnicodeIME
- [AndroidDriver] Setting IME to 'io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime enable io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime set io.appium.settings/.UnicodeIME'
- [UiAutomator2] Forwarding UiAutomator2 Server port 6790 to local port 8200
- [ADB] Forwarding system: 8200 to device: 6790
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a forward tcp:8200 tcp:6790'
- [ADB] Getting install status for io.appium.uiautomator2.server
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.uiautomator2.server'
- [ADB] 'io.appium.uiautomator2.server' is installed
- [ADB] Getting package info for 'io.appium.uiautomator2.server'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.uiautomator2.server'
- [ADB] The version name of the installed 'io.appium.uiautomator2.server' is greater or equal to the application version name ('4.21.1' >= '4.21.1')
- [UiAutomator2] io.appium.uiautomator2.server installation state: sameVersionInstalled
- [ADB] Checking app cert for /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk
- [ADB] Using 'apksigner.jar' from '/Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3/lib/apksigner.jar'
- [ADB] Starting apksigner: /Library/Java/JavaVirtualMachines/jdk1.8.0_271.jdk/Contents/Home/bin/java -Xmx1024M -Xss1m -jar /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3/lib/apksigner.jar verify --print-certs /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk
- [ADB] apksigner stdout: Signer #1 certificate DN: EMAILADDRESS=android@android.com, CN=Android, OU=Android, O=Android, L=Mountain View, ST=California, C=US
- [ADB] Signer #1 certificate SHA-256 digest: a40da80a59d170caa950cf15c18c454d47a39b26989d8b640ecd745ba71bf5dc
- [ADB] Signer #1 certificate SHA-1 digest: 61ed377e85d386a8dfee6b864bd85b0bfaa5af81
- [ADB] Signer #1 certificate MD5 digest: e89b158e4bcf988ebd09eb83f5378e87
- [ADB]
- [ADB] sha256 hash did match for 'appium-uiautomator2-server-v4.21.1.apk'
- [ADB] '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' is signed with the default certificate
- [ADB] Getting install status for io.appium.uiautomator2.server.test
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys package io.appium.uiautomator2.server.test'
- [ADB] 'io.appium.uiautomator2.server.test' is not installed
- [ADB] Checking app cert for /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk
- [ADB] Starting apksigner: /Library/Java/JavaVirtualMachines/jdk1.8.0_271.jdk/Contents/Home/bin/java -Xmx1024M -Xss1m -jar /Users/liuqinhou/Library/Android/sdk/build-tools/30.0.3/lib/apksigner.jar verify --print-certs /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk
- [ADB] apksigner stdout: Signer #1 certificate DN: EMAILADDRESS=android@android.com, CN=Android, OU=Android, O=Android, L=Mountain View, ST=California, C=US
- [ADB] Signer #1 certificate SHA-256 digest: a40da80a59d170caa950cf15c18c454d47a39b26989d8b640ecd745ba71bf5dc
- [ADB] Signer #1 certificate SHA-1 digest: 61ed377e85d386a8dfee6b864bd85b0bfaa5af81
- [ADB] Signer #1 certificate MD5 digest: e89b158e4bcf988ebd09eb83f5378e87
- [ADB]
- [ADB] sha256 hash did match for 'appium-uiautomator2-server-debug-androidTest.apk'
- [ADB] '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk' is signed with the default certificate
- [UiAutomator2] Server packages are going to be (re)installed
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a features'
- [ADB] The application at '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' will not be cached, because the device under test has confirmed the support of streamed installs
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a install -r /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk'
- [ADB] The installation of 'appium-uiautomator2-server-v4.21.1.apk' took 2847ms
- [ADB] Install command stdout: Performing Streamed Install
- [ADB] Success
- [ADB] The application at '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk' will not be cached, because the device under test has confirmed the support of streamed installs
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a install -r /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk'
- [ADB] The installation of 'appium-uiautomator2-server-debug-androidTest.apk' took 8002ms
- [ADB] Install command stdout: Performing Streamed Install
- [ADB] Success
- [UiAutomator2] Waiting up to 30000ms for services to be available
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell pm list instrumentation'
- [UiAutomator2] Instrumentation target 'io.appium.uiautomator2.server.test/androidx.test.runner.AndroidJUnitRunner' is available
- [ADB] Adding packages ["io.appium.settings","io.appium.uiautomator2.server","io.appium.uiautomator2.server.test"] to Doze whitelist
- [ADB] Got the following command chunks to execute: [["dumpsys","deviceidle","whitelist","+io.appium.settings",";","dumpsys","deviceidle","whitelist","+io.appium.uiautomator2.server",";","dumpsys","deviceidle","whitelist","+io.appium.uiautomator2.server.test",";"]]
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys deviceidle whitelist +io.appium.settings ; dumpsys deviceidle whitelist +io.appium.uiautomator2.server ; dumpsys deviceidle whitelist +io.appium.uiautomator2.server.test ;'
- [UiAutomator2] No app capability. Assuming it is already on the device
- [UiAutomator2] Performing shallow cleanup of automation leftovers
- [UiAutomator2] No obsolete sessions have been detected (socket hang up)
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell am force-stop io.appium.uiautomator2.server.test'
- [UiAutomator2] Starting UIAutomator2 server 4.21.1
- [UiAutomator2] Using UIAutomator2 server from '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-v4.21.1.apk' and test from '/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-uiautomator2-server/apks/appium-uiautomator2-server-debug-androidTest.apk'
- [UiAutomator2] Waiting up to 30000ms for UiAutomator2 to be online...
- [ADB] Creating ADB subprocess with args: ["-P",5037,"-s","efaa068a7d2a","shell","am","instrument","-w","-e","disableAnalytics",true,"io.appium.uiautomator2.server.test/androidx.test.runner.AndroidJUnitRunner"]
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [Instrumentation] io.appium.uiautomator2.server.test.AppiumUiAutomator2Server:
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] socket hang up
- [WD Proxy] Matched '/status' to command name 'getStatus'
- [WD Proxy] Proxying [GET /status] to [GET http://127.0.0.1:8200/wd/hub/status] with no body
- [WD Proxy] Got response with status 200: {"sessionId":"None","value":{"message":"UiAutomator2 Server is ready to accept commands","ready":true}}
- [UiAutomator2] The initialization of the instrumentation process took 5318ms
- [WD Proxy] Matched '/session' to command name 'createSession'
- [WD Proxy] Proxying [POST /session] to [POST http://127.0.0.1:8200/wd/hub/session] with body: {"capabilities":{"firstMatch":[{"platform":"LINUX","webStorageEnabled":false,"takesScreenshot":true,"javascriptEnabled":true,"databaseEnabled":false,"networkConnectionEnabled":true,"locationContextEnabled":false,"warnings":{},"desired":{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000},"platformName":"Android","platformVersion":"9","deviceName":"efaa068a7d2a","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000,"deviceUDID":"efaa068a7d2a"}],"alwaysMatch":{}}}
- [WD Proxy] Got response with status 200: {"sessionId":"520a226c-513e-4009-9105-5bd916b9772d","value":{"capabilities":{"firstMatch":[{"platform":"LINUX","webStorageEnabled":false,"takesScreenshot":true,"javascriptEnabled":true,"databaseEnabled":false,"networkConnectionEnabled":true,"locationContextEnabled":false,"warnings":{},"desired":{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000},"platformName":"Android","platformVersion":"9","deviceName":"efaa068a7d2a","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000,"deviceUDID":"efaa068a7d2a"}],"alwaysMatch":{}},"sessionId":"520a226c-513e-4009-9105-5bd916b9772d"}}
- [WD Proxy] Determined the downstream protocol as 'W3C'
- [WD Proxy] Proxying [GET /appium/device/info] to [GET http://127.0.0.1:8200/wd/hub/session/520a226c-513e-4009-9105-5bd916b9772d/appium/device/info] with no body
- [WD Proxy] Got response with status 200: {"sessionId":"520a226c-513e-4009-9105-5bd916b9772d","value":{"androidId":"b32ecb3d70e0152f","apiVersion":"28","bluetooth":{"state":"ON"},"brand":"xiaomi","carrierName":"","displayDensity":320,"locale":"zh_CN","manufacturer":"Xiaomi","model":"Redmi 6A","networks":[{"capabilities":{"SSID":null,"linkDownBandwidthKbps":1048576,"linkUpstreamBandwidthKbps":1048576,"networkCapabilities":"NET_CAPABILITY_NOT_METERED,NET_CAPABILITY_INTERNET,NET_CAPABILITY_NOT_RESTRICTED,NET_CAPABILITY_TRUSTED,NET_CAPABILITY_NOT_VPN,NET_CAPABILITY_VALIDATED,NET_CAPABILITY_NOT_ROAMING,NET_CAPABILITY_FOREGROUND,NET_CAPABILITY_NOT_CONGESTED,NET_CAPABILITY_NOT_SUSPENDED","signalStrength":-31,"transportTypes":"TRANSPORT_WIFI"},"detailedState":"CONNECTED","extraInfo":null,"isAvailable":true,"isConnected":true,"isFailover":false,"isRoaming":false,"state":"CONNECTED","subtype":0,"subtypeName":"","type":1,"typeName":"WIFI"}],"platformVersion":"9","realDisplaySize":"720x1440","timeZone":"Asia/Shanghai"}}
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell dumpsys window'
- [AndroidDriver] Screen already unlocked, doing nothing
- [UiAutomator2] Starting 'com.example.helloworld/com.example.helloworld.activity.net.NetMainActivity and waiting for 'com.example.helloworld/com.example.helloworld.activity.net.NetMainActivity'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell am start -W -n com.example.helloworld/com.example.helloworld.activity.net.NetMainActivity -S -a android.intent.action.MAIN -c android.intent.category.LAUNCHER -f 0x10200000'
- [WD Proxy] Proxying [GET /appium/device/pixel_ratio] to [GET http://127.0.0.1:8200/wd/hub/session/520a226c-513e-4009-9105-5bd916b9772d/appium/device/pixel_ratio] with no body
- [WD Proxy] Got response with status 200: {"sessionId":"520a226c-513e-4009-9105-5bd916b9772d","value":2}
- [WD Proxy] Matched '/appium/device/system_bars' to command name 'getSystemBars'
- [WD Proxy] Proxying [GET /appium/device/system_bars] to [GET http://127.0.0.1:8200/wd/hub/session/520a226c-513e-4009-9105-5bd916b9772d/appium/device/system_bars] with no body
- [WD Proxy] Got response with status 200: {"sessionId":"520a226c-513e-4009-9105-5bd916b9772d","value":{"statusBar":48}}
- [WD Proxy] Matched '/window/current/size' to command name 'getWindowSize'
- [WD Proxy] Proxying [GET /window/current/size] to [GET http://127.0.0.1:8200/wd/hub/session/520a226c-513e-4009-9105-5bd916b9772d/window/current/size] with no body
- [WD Proxy] Got response with status 200: {"sessionId":"520a226c-513e-4009-9105-5bd916b9772d","value":{"height":1344,"width":720}}
- [Appium] New AndroidUiautomator2Driver session created successfully, session 272490bd-2f8b-402b-a423-7ca967433bdc added to master session list
- [BaseDriver] Event 'newSessionStarted' logged at 1658717026469 (10:43:46 GMT+0800 (中国标准时间))
- [W3C (272490bd)] Cached the protocol value 'W3C' for the new session 272490bd-2f8b-402b-a423-7ca967433bdc
- [W3C (272490bd)] Responding to client with driver.createSession() result: {"capabilities":{"platform":"LINUX","webStorageEnabled":false,"takesScreenshot":true,"javascriptEnabled":true,"databaseEnabled":false,"networkConnectionEnabled":true,"locationContextEnabled":false,"warnings":{},"desired":{"platformName":"Android","platformVersion":"9","deviceName":"8ADX0QRKA","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000},"platformName":"Android","platformVersion":"9","deviceName":"efaa068a7d2a","appPackage":"com.example.helloworld","appActivity":"com.example.helloworld.activity.net.NetMainActivity","app":"","unicodeKeyboard":true,"autoAcceptAlerts":true,"resetKeyboard":true,"noReset":true,"newCommandTimeout":6000,"deviceUDID":"efaa068a7d2a","deviceApiLevel":28,"deviceScreenSize":"720x1440","deviceScreenDensity":320,"deviceModel":"Redmi 6A","deviceManufacturer":"Xiaomi","pixelRatio":2,"statBarHeight":48,"viewportRec...
- [HTTP] <-- POST /wd/hub/session 200 21831 ms - 1132
- [HTTP]
- [Logcat] Logcat terminated with code 1, signal null
- [BaseDriver] Shutting down because we waited 6000 seconds for a command
- [Appium] Closing session, cause was 'New Command Timeout of 6000 seconds expired. Try customizing the timeout using the 'newCommandTimeout' desired capability'
- [Appium] Removing session '272490bd-2f8b-402b-a423-7ca967433bdc' from our master session list
- [UiAutomator2] Deleting UiAutomator2 session
- [UiAutomator2] Deleting UiAutomator2 server session
- [WD Proxy] Matched '/' to command name 'deleteSession'
- [WD Proxy] Proxying [DELETE /] to [DELETE http://127.0.0.1:8200/wd/hub/session/520a226c-513e-4009-9105-5bd916b9772d] with no body
- [WD Proxy] Got response with status 200: {"sessionId":"520a226c-513e-4009-9105-5bd916b9772d","value":null}
- [UiAutomator2] Resetting IME to 'io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell ime set io.appium.settings/.UnicodeIME'
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell am force-stop com.example.helloworld'
- [Logcat] Stopping logcat capture
- [Logcat] Logcat already stopped
- [ADB] Removing forwarded port socket connection: 8200
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a forward --remove tcp:8200'
- [UiAutomator2] Restoring hidden api policy to the device default configuration
- [ADB] Running '/Users/liuqinhou/Library/Android/sdk/platform-tools/adb -P 5037 -s efaa068a7d2a shell 'settings delete global hidden_api_policy_pre_p_apps;settings delete global hidden_api_policy_p_apps;settings delete global hidden_api_policy''
- [Instrumentation] .
- [Instrumentation] Time: 6,004.981
- [Instrumentation]
- [Instrumentation] OK (1 test)
- [Instrumentation] The process has exited with code 0

Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。