原文地址: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”菜单按钮,然后点击该按钮,然后完成测试。

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

下面我们就通过分析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完成的活动分析的更多相关文章

  1. Appium服务器端从启动到case完成的活动分析

    此文的目的主要是通过分析Appium Server打印出来的log,加深对Appium Server所扮演角色的理解. 这整一个过程是由一个Test Case开始执行到结束,测试的对象是SDK自带的N ...

  2. Python+Appium学习之启动手机APP或者浏览器

    一.启动浏览器:pycharm中python脚本如下: from appium import webdriver desired_caps ={ 'platformName':'Android', ' ...

  3. Appium 命令行启动配置

    Appium 安装过后,会有图形界面,同样也支持命令行参数的启动和配置 Windws: 在windows 安装配置Appium有三种方式: Node install -g appium .exe文件安 ...

  4. Appium 的安装启动

    Appium 的安装方式根据官网提供的是使用nodejs 安装,但是官方给出了三种方法 参考网址: appium下载地址: https://bitbucket.org/appium/appium.ap ...

  5. Appium之连续启动多个应用(APP)

    我们知道Appium应用启动时自带的caps可以先行启动某个应用(基于appPackage和appActivity),那么如何用其连续启动多个应用呢? 这里就需要用到start_activity()方 ...

  6. Appium + python自动化 - 启动app

    各种百度将Appium + python的环境搭建好后,开启移动app自动化的探索(基于Android),首先来记录下如何启动待测的app吧! 如何启动app呢?首先要获取包名,然后获取launche ...

  7. Appium命令行启动,提示找不到命令,本地没有appium.cmd文件

    安装appium时,直接从github上下载的appium-desktop-windows版本,安装后,从打开桌面端Server,能启动服务,appium-doctor也能正常运行. 但奇怪的地方来了 ...

  8. python appium server代码启动和关闭遇到的坑

    第一次使用博客,小白级,互相交流,有说的不对的地方欢迎来喷!!! 自动化的目的就是减少人工成本,如果每次跑自动化用例时都要手动起appium客户端,太费事了~~故,将appium server的调起和 ...

  9. Appium——解决每次启动时都安装setting和unlock app方法

    找到appium安装目录 C:\Program Files (x86)\Appium\node_modules\appium\lib\devices\android 修改代码,注释掉弹出setting ...

随机推荐

  1. c# socket udp广播

    一.广播消息 由于Tcp是有连接的,所以不能用来发送广播消息.发送广播消息,必须用到Udp,Udp可以不用建立连接而发送消息.广播消息的目的IP地址是一种特殊IP地址,称为广播地址.广播地址由IP地址 ...

  2. ISAPI_Rewrite 3 伪静态软件

    下载地址 http://www.helicontech.com/isapi_rewrite/download.html

  3. 从jdbc到mybatis

    前面我已经写了几篇文章介绍mybatis的使用方法, 现准备从原理上分析mybatis, 本篇将会解说JDBC演变到mybatis的过程. JDBC查询 使用jdbc查询数据库一般有下面七个步骤: 1 ...

  4. 妈蛋:kinMaxShow旋转木马异常,WebUploader图片上传坑爹,图像被压缩

    今天晚上在改造轮播图. 原来的代码是这种: <div> <img src="${static}/image/index/banner/`.jpg" /> & ...

  5. 推断序列的端部的大小C规划

    概念 big-endian格式:高字节字符数据被存储在低地址.字数据的低字节存放在高地址. 小尾数格式:相较于大端存储格式,在小尾数格式.低地址存储在字数据的低字节.的是字数据的高字节. 如5A6C中 ...

  6. IOS 多于UIImageView 当加载较大的高清闪存管理

    当我们是一家人View  多于UIImageView,和UIImageView表明一个更大的HD,可能存在的存储器的警告的问题.假设第一次走进这个view,无记忆出现预警.当重新进入view,在那曾经 ...

  7. HDOJ 4745 Two Rabbits DP

    Two Rabbits Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others) Tot ...

  8. SynchronousQueue、LinkedBlockingQueue、ArrayBlockingQueue性能测试(转)

    听说JDK6对SynchronousQueue做了性能优化,避免对竞争资源加锁,所以想试试到底平时是选择SynchronousQueue还是其他BlockingQueue. 对于容器类在并发环境下的比 ...

  9. 一起写2048(160行python代码)

    前言: Life is short ,you need python. --Bruce Eckel 我与2048的缘,不是缘于一个玩家.而是一次,一次,重新的ACM比赛.四月份校赛初赛,第一次碰到20 ...

  10. 【蓝桥杯】 PREV-1 核桃数

    主题链接:http://lx.lanqiao.org/problem.page?gpid=T24   历届试题 核桃的数量   时间限制:1.0s   内存限制:256.0MB        问题描写 ...