appium 从启动到测试再到结束流程梳理

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值