appium ios 真机自动化环境搭建

近期由于工作需要,本小菜在弄appium+ios+iphone真机的移动自动化,在网上找寻各种资料,发现针对IOS方面的资料少之又少,公司其它部门的弄过的同事也寥寥无几,即使有,也是安卓方面的。本次书写此文章,是为了帮助依然在坑里摸爬滚打的伙伴们,早日出坑。

一、环境:

macBook Pro:10.13.4

iphone真机:iphone6 plus 11.3.1

appium 1.8.1

xcode 9.3.1

二、appium原理(转自https://blog.csdn.net/achang21/article/details/60956618的介绍)

Appium是一个开源、跨平台的测试框架,可以用来测试原生及混合的移动端应用。Appium支持IOS、Android及FirefoxOS平台。Appium使用WebDriver的json wire协议,来驱动Apple系统的UIAutomation库、Android系统的UIAutomator框架。Appium对IOS系统的支持得益于Dan Cuellar’s对于IOS自动化的研究。Appium也集成了Selendroid,来支持老android版本。

Appium支持Selenium WebDriver支持的所有语言,如java、Object-C、JavaScript、Php、Python、Ruby、C#、Clojure,或者Perl语言,更可以使用Selenium WebDriver的Api。Appium支持任何一种测试框架。如果只使用Apple的UIAutomation,我们只能用javascript来编写测试用例,而且只能用Instruction来运行测试用例。同样,如果只使用Google的UIAutomation,我们就只能用java来编写测试用例。Appium实现了真正的跨平台自动化测试。

appium选择了client-server的设计模式。只要client能够发送http请求给server,那么的话client用什么语言来实现都是可以的,这就是appium及webdriver如何做到支持多语言的;

三、环境搭建步骤:

---------------------必要的库安装--------------------------------------

1.xcode安装,app store里安装xcode

2.如果没有安装 过homebrew,请先安装

/usr/bin/ruby -e "$(curl –fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

3.如果没有安装过npm及node.js,请先安装

brew install npm,此命令执行后,npme和node.js会全部安装完毕

4.安装依赖库

brew install libimobiledevice --HEAD

npm install -g ios-deploy  #如果是iOS10以上的系统才需要安装

如果没有安装 libimobiledevice,会导致Appium无法连接到iOS的设备,所以必须要安装,如果要在iOS10+的系统上使用appium,则需要安装ios-deploy

5.appium-doctor 安装

npm install appium-doctor -g

安装后执行appium-doctor --ios指令,可以查看与iOS相关配置是否完整,下图是全部配置都成功,如果有哪一项是打叉的,则进行安装就可以了。比如如果carthage项是打叉的,则需要安装:

brew install carthage

---------------------webdriverAgent--------------------------------------

1.安装webdriverAgent

(1)在github上下载最新webdriverAgent代码

git clone https://github.com/facebook/WebDriverAgent

(2)下载依赖

cd /Users/yourname/WebDriverAgent

mkdir -p Resources/WebDriverAgent.bundle

sh ./Scripts/bootstrap.sh

该脚本会使用Carthage下载所有的依赖,使用npm打包响应的js文件。执行完成后,直接双击打开WebDriverAgent.xcodeproj这个文件。

2.配置WebDriverAgent

配置WebDriverAgentLib,选择开发者账号

配置WebDriverAgentRunner,选择开发者账号

3.连接并选择自己的ios设备,运行

运行成功后,iphone手机上会新建一个无图标的WebDriverAgent的应用,自动打开后马上又返回桌面

而在xcode控制台会打印如下日志:里面有IP地址与端口号

4.在网址上输入http://(ip地址):(端口号)/status,如果网页上返回一些json格式的数据,说明运行成功http://10.0.223.58:8100/status,有些iphone手机通过手机的IP和端口号还不能访问,此时需要将手机的端口转发到mac上

iproxy 8100 8100

执行命令后,通过访问 http://localhost:8100/ status来验证, 如果网页上返回一些json格式的数据,说明运行成功

而如果是想查看UI的图层,则可访问http://localhost:8100/inspector,方便书写测试用例

备注:通常来说为了持续集成,自动化会比较好一些,我们不必每次都通过这种方式来启动xcode、WebDriverAgent,这种方式只在第1次搭建环境时运行即可,我们可以在自动化脚本中加入如下代码,这样只要在以后启动appium后,运行自动化脚本,就会直接启动WebDriverAgent

desiredCapabilities.setCapability("useNewWDA", true);

如果xcode在先启动wda,而代码中又用此行代码,运行时xcode中会显示执行失败,报出冲突的错误哦,所以后期只在代码中启动WebDriverAgent即可,不再需要用xcode启动

---------------------appium--------------------------------------

  1. appium安装

我是使用源码安装的,在appium的版本选择上,我不建议一味的追求最新版,因为最新的版本相配套的其它依赖有可能还没有同步更新,可能会报各种各样的错误,而且最新版可能还不稳定,在此次搭建环境过程中,我用最新版appium会发现appium的bug,经在github上与appium开发者反复讨论,修复bug,才能解决问题。所以在版本的选择上,我建议使用稳定版本,而不必一味追求最新,小白鼠的角色并不好做,稳定才是最好的~

npm install –g appium

启动appium

appium --address 127.0.0.1 --port 4723

2.appium环境搭建的其它问题和调试方法:

(1)在appium执行过程中,我们可以根据appium的日志来查看哪个环节有错误,以下是我在网上随便找的一些日志分析,https://blog.csdn.net/jffhy2017/article/details/69372064,可以google找哦,网上关于日志分析的内容很多。

如果在appium执行中哪个环节出错,我们可以将post的命令直接输入在url中,看看返回的json串中的详细错误信息,根据此错误信息排错。

http://10.0.223.58:8100/(POST的命令)

(2)可以在github上给appium的开发者留言,来解决问题。自己的英文+google翻译,appium的开发者还是很耐心的,而且解决问题一针见血,非常对症~

附上我一个问题:https://github.com/appium/appium/issues/10775

---------------------appium实践实例-解锁九宫格-----------------------------------

(附上动态效果图:以后再加。。。)

代码如下:

public class SampleTest1 {

    private IOSDriver driver;

    @Before

    public void setUp() throws MalformedURLException {

        DesiredCapabilities desiredCapabilities = new DesiredCapabilities();

        desiredCapabilities.setCapability("deviceName", "iphone 6 Plus");

        desiredCapabilities.setCapability("platformVersion", "11.3.1");

        desiredCapabilities.setCapability("platformName", "iOS");

        desiredCapabilities.setCapability("app", "/Users/yangyang50/Desktop/work/JDMEIphone_4.6.0.ipa");

        desiredCapabilities.setCapability("udid", "*****************");//请填写手机的udid

        desiredCapabilities.setCapability("autoLaunch", false);

        desiredCapabilities.setCapability("useNewWDA", true);

        desiredCapabilities.setCapability("xcodeOrgId","******");//请填写开发者帐号对应的OrgId

        desiredCapabilities.setCapability("xcodeSigningId","iPhone Developer");

        URL remoteUrl = new URL("http://localhost:4723/wd/hub");

        driver = new IOSDriver(remoteUrl, desiredCapabilities);

    }

    @Test

    public void sampleTest1() throws InterruptedException{

        MobileElement element_cancel = (MobileElement) driver.findElementByAccessibilityId("取消");

        element_cancel.click();

        Thread.sleep(2000);

        MobileElement element_1 = (MobileElement) driver.findElementByXPath("(//XCUIElementTypeButton[@name=\"lock botton unselected\"])[1]");

        MobileElement element_3 = (MobileElement) driver.findElementByXPath("(//XCUIElementTypeButton[@name=\"lock botton unselected\"])[3]");

        MobileElement element_6 = (MobileElement) driver.findElementByXPath("(//XCUIElementTypeButton[@name=\"lock botton unselected\"])[6]");

        TouchAction action = new TouchAction(driver);

        action.press(element_1).waitAction(500).moveTo(element_3).waitAction(500).moveTo(element_6).release().perform();

        Thread.sleep(1000);

    }

    @After

    public void tearDown() {

        driver.quit();

    }

}

猜你喜欢

转载自blog.csdn.net/u012873868/article/details/81132413
今日推荐