標籤:des android style blog http ar io os 使用
此文的目的主要是通過分析Appium Server列印出來的log,加深對Appium Server所扮演角色的理解。
這整一個過程是由一個Test Case開始執行到結束,測試的對象是SDK內建的NotePad.apk。 Test Case很簡單:開啟Notepad程式,然後點擊安卓的Menu Options按鈕調出“Add Note”功能表按鈕,然後點擊該按鈕,然後完成測試。
[java] view plaincopy
- package majcit.com.AppiumDemo;
-
- import io.appium.java_client.AppiumDriver;
-
- import java.io.File;
- import java.net.URL;
- import java.util.List;
-
- import org.junit.Test;
- import org.junit.After;
- import org.junit.Before;
- import org.openqa.selenium.By;
- import org.openqa.selenium.WebElement;
- import org.openqa.selenium.remote.CapabilityType;
- import org.openqa.selenium.remote.DesiredCapabilities;
- import org.openqa.selenium.remote.RemoteWebDriver;
- import org.openqa.selenium.*;
-
- import static org.hamcrest.Matchers.*;
- import static org.hamcrest.MatcherAssert.assertThat;
-
- /**
- * Unit test for simple App.
- */
- public class NoetPadTest {
- /**
- * Create the test case
- *
- * @param testName name of the test case
- */
- private AppiumDriver driver;
-
- @Before
- public void setUp() throws Exception {
- // set up appium
- File classpathRoot = new File(System.getProperty("user.dir"));
- File appDir = new File(classpathRoot, "apps");
- File app = new File(appDir, "NotePad.apk");
- DesiredCapabilities capabilities = new DesiredCapabilities();
- capabilities.setCapability("deviceName","iPad Simulator");
- //capabilities.setCapability("platformVersion", "4.2");
- capabilities.setCapability("platformName", "Android");
- capabilities.setCapability("app", app.getAbsolutePath());
- //capabilities.setCapability("appPackage", "com.example.android.notepad");
- //capabilities.setCapability("appActivity", "com.example.android.notepad.NotesList");
- //capabilities.setCapability("appActivity", ".NotesList");
- driver = new AppiumDriver(new URL("http://127.0.0.1:4723/wd/hub"), capabilities);
- }
-
- @After
- public void tearDown() throws Exception {
- driver.quit();
- }
-
- @Test
- public void addContact() throws InterruptedException{
- driver.sendKeyEvent(82);
-
-
- try {
- Thread.sleep(3000);
- }catch(Exception e) {
- System.out.println(e.getMessage());
- }
-
- WebElement el = driver.findElement(By.name("Add note"));
- el.click();
- try {
- Thread.sleep(60000);
- }catch(Exception e) {
- System.out.println(e.getMessage());
- }
-
- }
-
- }
下面我們就通過分析Log把Appium Server所做的事情分步驟描述一下。
1. 啟動REST http伺服器,預設監聽本地4723連接埠,用於接收用戶端(Test Case+Selenium/Appium Driver)發過來的JSON格式的命令指示。
2. 根據用戶端提供的capabilities指示建立一個Android Sesision用於跟用戶端保持後續通訊
3. 通過”adb devices“命令檢查安卓手機是否已經準備好
4.使用工具“aapt dump badging NotePad.apk"來獲得Notepad的packageName和launchable activityName,注意範例程式碼中是沒有指定這個兩個capabilities的
5. 安卓手機shell調用命令獲得機器的API Level是否已經超過16:"adb.exe -s HT21atd05099 shell getprop ro.build.version.sdk"
6. 通過adb執行相應的shell命令檢查目標應用是否已經存在:“pm list packages -3 com.example.android.notepad"
7. 目標機器上清理目標應用運行環境:該停止就停止該清空資料就清空資料
8. 建立Appium Server到目標機器上的連接埠轉寄
9. 把AppiumBootStrap.apk push到目標裝置:這是目標機器上通過uiautomator工具(架構)啟動並執行服務端,用於接受處理client端發送過來的命令
10. 把settings_apk-debuug.apk和unlock_apk-debug.apk push到目標設別:TBD
11. 保證uiautomator沒有已經在跑
12. 通過adb把目標機器上的AppiumBootStrap跑起來:"uiautomator runtest AppiumBootstrap.jar -c io.appium.android.bootstrap.Rootstrap".
13.通過adb在目標機器上 Launch notepad應用
14. 通知PC端目標應用已經在目標機器啟動成功
15. 處理用戶端發過來的”按下系統功能表“的命令:bootstrap把接受到的命令入隊列,執行完成後通知用戶端執行結果
16.定位”Add Note“功能表按鈕:Bootstrap通過的UIAutomator的UISelector類根據Text獲得功能表按鈕的ID並返回給用戶端
17. BootStrap執行”點擊 Add Note菜單"命令
18. 測試完成,目標機器類比點擊Home按鈕把目標應用放在後台
19. 關閉logcat
20. 關閉Uiautomator進程
Appium伺服器端從啟動到case完成的活動分析