• 【转】Appium 服务器端从启动到case完成的活动分析


    原文地址:http://blog.csdn.net/zhubaitian/article/details/39474151

    此文的目的主要是通过分析Appium Server打印出来的log,加深对Appium Server所扮演角色的理解。

    这整一个过程是由一个Test Case开始执行到结束,测试的对象是SDK自带的NotePad.apk。 Test Case很简单:打开Notepad程序,然后点击安卓的Menu Options按钮调出“Add Note”菜单按钮,然后点击该按钮,然后完成测试。

    [java] view plaincopy
     
     
    1. package majcit.com.AppiumDemo;  
    2.   
    3. import io.appium.java_client.AppiumDriver;  
    4.   
    5. import java.io.File;  
    6. import java.net.URL;  
    7. import java.util.List;  
    8.   
    9. import org.junit.Test;  
    10. import org.junit.After;  
    11. import org.junit.Before;  
    12. import org.openqa.selenium.By;  
    13. import org.openqa.selenium.WebElement;  
    14. import org.openqa.selenium.remote.CapabilityType;  
    15. import org.openqa.selenium.remote.DesiredCapabilities;  
    16. import org.openqa.selenium.remote.RemoteWebDriver;  
    17. import org.openqa.selenium.*;  
    18.   
    19. import static org.hamcrest.Matchers.*;  
    20. import static org.hamcrest.MatcherAssert.assertThat;  
    21.   
    22. /** 
    23.  * Unit test for simple App. 
    24.  */  
    25. public class NoetPadTest {  
    26.     /** 
    27.      * Create the test case 
    28.      * 
    29.      * @param testName name of the test case 
    30.      */  
    31.     private AppiumDriver driver;  
    32.   
    33.     @Before  
    34.     public void setUp() throws Exception {  
    35.         // set up appium  
    36.         File classpathRoot = new File(System.getProperty("user.dir"));  
    37.         File appDir = new File(classpathRoot, "apps");  
    38.         File app = new File(appDir, "NotePad.apk");  
    39.         DesiredCapabilities capabilities = new DesiredCapabilities();  
    40.         capabilities.setCapability("deviceName","iPad Simulator");  
    41.         //capabilities.setCapability("platformVersion", "4.2");  
    42.         capabilities.setCapability("platformName", "Android");  
    43.         capabilities.setCapability("app", app.getAbsolutePath());  
    44.         //capabilities.setCapability("appPackage", "com.example.android.notepad");  
    45.         //capabilities.setCapability("appActivity", "com.example.android.notepad.NotesList");  
    46.         //capabilities.setCapability("appActivity", ".NotesList");  
    47.         driver = new AppiumDriver(new URL("http://127.0.0.1:4723/wd/hub"), capabilities);  
    48.     }  
    49.   
    50.     @After  
    51.     public void tearDown() throws Exception {  
    52.         driver.quit();  
    53.     }  
    54.   
    55.     @Test  
    56.     public void addContact() throws InterruptedException{  
    57.         driver.sendKeyEvent(82);  
    58.   
    59.           
    60.         try {  
    61.             Thread.sleep(3000);  
    62.         }catch(Exception e) {  
    63.             System.out.println(e.getMessage());  
    64.         }  
    65.          
    66.         WebElement el = driver.findElement(By.name("Add note"));  
    67.         el.click();  
    68.         try {  
    69.             Thread.sleep(60000);  
    70.         }catch(Exception e) {  
    71.             System.out.println(e.getMessage());  
    72.         }  
    73.           
    74.     }  
    75.       
    76. }  

    下面我们就通过分析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进程

  • 相关阅读:
    201521123115《Java程序设计》第7周学习总结
    201521123115《Java程序设计》第6周学习总结
    201521123115 《Java程序设计》第5周学习总结
    201521123115 《Java程序设计》第4周学习总结
    201521123115 《Java程序设计》第3周学习总结
    201521123115《Java程序设计》第2周学习总结
    201521123114 《Java程序设计》第13周学习总结
    201521123114 《Java程序设计》第12周学习总结
    201521123114 《Java程序设计》第11周学习总结
    201521123114 《Java程序设计》第10周学习总结
  • 原文地址:https://www.cnblogs.com/xiaoluosun/p/4519262.html
Copyright © 2020-2023  润新知