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

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

[java]  view plain copy
  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进程

 

作者

自主博客

微信

CSDN

天地会珠海分舵

http://techgogogo.com


服务号:TechGoGoGo

扫描码:

©著作权归作者所有:来自51CTO博客作者zhukev的原创作品,如需转载,请注明出处,否则将追究法律责任

0

收藏

zhukev

117篇文章,7W+人气,0粉丝

Ctrl+Enter 发布

发布

取消

推荐专栏更多

5366d1f50328a62facbf5db1d91c319a.png
VMware vSAN中小企业应用案例

掌握VMware超融合技术

共41章 | 王春海
¥51.00 346人订阅
9d82eccb4e3c371eaeac41193bbef757.png
基于Kubernetes企业级容器云平台落地与实践

容器私有云平台实践之路

共15章 | 李振良OK
¥51.00 595人订阅
45862f289339dc922ffda669fd74ad9b.jpg
网工2.0晋级攻略 ——零基础入门Python/Ansible

网络工程师2.0进阶指南

共30章 | 姜汁啤酒
¥51.00 1557人订阅
629650e188ddde78b213e564c2e9ebff.jpg
负载均衡高手炼成记

高并发架构之路

共15章 | sery
¥51.00 506人订阅
dc6736c5fd50474b5df8b76b040e3d03.jpg
带你玩转高可用

前百度高级工程师的架构高可用实战

共15章 | 曹林华
¥51.00 461人订阅
f92360e227f9d91cdff7ea95120630ef.png
left-qr.jpg

扫一扫,领取大礼包

0

分享
qr-url?url=https%3A%2F%2Fblog.51cto.com%2Ftechgogogo%2F1608451
zhukev
noavatar_middle.gif