【Mac Appium Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

时间:2022-05-15 05:14:13

前提条件:

===========================================

1.Xcode版本为Xcode10及以上
2.Appium版本必须为1.9及以上,因为Xcode为10.0

3.appium-desktop
4.安装所需依赖库,包括:

a.Homebrew

b.Git

c.node (brew install node

d.npm (brew install npm)
e.carthage (brew install carthage)
f.libimobiledevice(真机测试需要)(brew install libimobiledevice)
g.ios-deploy(真机测试需要)(brew install ios-deploy

5、WDA配置

===========================================

上面的环境配置具体参考:

【Mac Appium学习(一)】之安装Appium环境前提准备

【Mac Appium Python3.6学习(三)】之IOS自动化测试环境配置

环境:

  • MacOS:10.13.6
  • Appium:1.9.1
  • Appium-desktop:1.7.1
  • Java:1.8
  • XCode:10.0

 

一、安装测试环境

1、配置上面都有就不一一描述了,下面来看一下IOS模拟器:

1)打开Xcode,选择如下图所示,打开模拟器:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

会启动一个模拟器:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

模拟器的版本可以自行选择,这里我选择iPhone7:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

 

如果想关闭某个模拟器,则点击要关闭的窗口再关闭,如下图:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写( 

下面去appium官网下载IOS演示程序:

地址:https://github.com/appium/ios-uicatalog

项目clone到本地环境:

$ git clone https://github.com/appium/ios-uicatalog.git
Cloning into ‘ios-uicatalog‘...
remote: Enumerating objects: 294, done.
remote: Total 294 (delta 0), reused 0 (delta 0), pack-reused 294
Receiving objects: 100% (294/294), 6.63 MiB | 1.35 MiB/s, done.
Resolving deltas: 100% (159/159), done.

命令打开项目:

$ open UICatalog.xcodeproj/

2、模拟器上跑自动化

1)刚刚的项目在模拟器中进行编译:

点击红框

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

会自动启动模拟器:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

 

2)然后拷贝项目app的xpath,来配置在参数中:

①拷贝到参数中

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

会报错:

Original error: ‘10.3.1‘ does not exist in the list of simctl SDKs. Only the following Simulator SDK versions are available on your system: 10.3, 12.0

 意思是没有‘10.3.1‘,只有‘10.3、12.0‘版本的SDK,所以手动修改:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

又报错:

Original error: Could not create simulator with name ‘appiumTest-iPhone7‘, device type id ‘iPhone7‘ and runtime id ‘10.3.1‘. Reason: ‘simctl error running ‘create‘: Invalid device type: iPhone7‘

经过查询得知:

感谢:每天1990:《Appium1.6启动iOS真机*很重要

解决方法: Appium参数也必须设置udid,在启动的Desired Capabilities增加udid

②udid通过命令获取:

参考:《 基于Appium WDA Python搭建IOS自动化测试全纪录(二):模拟器demo运行
instruments -s devices

获取你打开的模拟器的id。

再运行session:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

完整参数如下:

{
  "platformName": "iOS",
  "platformVersion": "10.3",
  "deviceName": "iPhone7",
  "automationName": "XCUITest",
  "app": "/Users/xxx/Library/Developer/Xcode/DerivedData/UICatalog-hiixtcsjcynttngjfqlnzjjtpxkv/Build/Products/Debug-iphonesimulator/UICatalog.app",
  "udid": "D3062BB8-5627-4867-8E97-AEDF6D953353"
}

3)并且输入地址:http://localhost:8100/inspector,也会有检查器显示。

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

4)设置log路径,如图:

①第一种在appium桌面程序设置log路径:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

②第二种用命令行重新启动一个自己的appium(相当于新建一个appium服务5723

输入命令:

$ appium -g /Users/xxx/Desktop/mine/Stu资料/Git/git—download/project/appium2.log -p 5723
[Appium] Welcome to Appium v1.9.1
[Appium] Non-default server args:
[Appium]   port: 5723
[Appium]   log: /Users/xxx/Desktop/mine/Stu资料/Git/git—download/project/appium2.log
[Appium] Appium REST http interface listener started on 0.0.0.0:5723

再设置参数启动:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

同样可以启动app,并且生成appium2.log文件。

5)扩展:对Simulator控制

https://github.com/facebook/FBSimulatorControl/blob/master/fbsimctl/README.md

6)编写用例

利用IDEA编辑器,在之前《【Mac Appium Java1.8学习(一)】之Android自动化环境安装配置以及IDEA配置(附录扩展Selenium Java自动化)》已经介绍如何使用配置IDEA。

之前在appium-desktop中可以自动生成代码,把它复制到IDEA中,如图:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

但是,从现在开始先暂时不用appium-desktop,用XCode自带的查看元素工具。

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

如图步骤:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

 

上代码:

解释=>findElementByAccessibilityId,如果包含name属性则可以使用。

参考官网:http://appium.io/docs/en/writing-running-appium/finding-elements/

package IOS_Simulator;

import io.appium.java_client.ios.IOSDriver;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.openqa.selenium.remote.DesiredCapabilities;

import java.net.MalformedURLException;
import java.net.URL;

public class DemoTest {

    private IOSDriver driver;

    @Before
    public void setUp() throws MalformedURLException {
        DesiredCapabilities desiredCapabilities = new DesiredCapabilities();
        desiredCapabilities.setCapability("platformName", "iOS");
        desiredCapabilities.setCapability("platformVersion", "10.3");
        desiredCapabilities.setCapability("deviceName", "iPhone7");
        desiredCapabilities.setCapability("automationName", "XCUITest");
        desiredCapabilities.setCapability("app", "/Users/xxx/Library/Developer/Xcode/DerivedData/UICatalog-hiixtcsjcynttngjfqlnzjjtpxkv/Build/Products/Debug-iphonesimulator/UICatalog.app");
        desiredCapabilities.setCapability("udid", "D3062BB8-5627-4867-8E97-AEDF6D953353");

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

        driver = new IOSDriver(remoteUrl, desiredCapabilities);
    }

    @Test
    public void sampleTest() {
//        MobileElement el1 = (MobileElement) driver.findElementByXPath("//XCUIElementTypeApplication[@name="UICatalog"]/XCUIElementTypeWindow[1]/XCUIElementTypeOther/XCUIElementTypeOther/XCUIElementTypeOther/XCUIElementTypeTable/XCUIElementTypeCell[4]");
//        el1.click();
//        MobileElement el2 = (MobileElement) driver.findElementByXPath("(//XCUIElementTypeButton[@name="Button"])[2]");
//        el2.click();
        driver.findElementByAccessibilityId("Buttons").click();
//        driver.getPageSource().sout ===> System.out.println(driver.getPageSource());
        System.out.println(driver.getPageSource());
        driver.findElementByXPath("//*[@label=‘Button‘]").click();
        driver.findElementByAccessibilityId("UICatalog").click();
    }

    @After
    public void tearDown() {
//        driver.quit();
    }
}

运行结果:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

3、真机上跑自动化

真机官网地址说明:http://appium.io/docs/en/drivers/ios-xcuitest-real-devices/

1)配置参数

为了入门学习,还是要启动appium-desktop,完整参数:app参数有坑

{
  "platformName": "iOS",
  "platformVersion": "10.3",
  "deviceName": "iPhone5s",
  "automationName": "XCUITest",
  "app": "/Users/xxx/Library/Developer/Xcode/DerivedData/UICatalog-hiixtcsjcynttngjfqlnzjjtpxkv/Build/Products/Debug-iphonesimulator/UICatalog.app",
  "udid": "42ebab931b6b2d6a140b1a4f5bd55305dbfe2ff0"
}

启动session,报错:

Original error: Could not install app: ‘Command ‘ios-deploy --id 42ebab931b6b2d6a140b1a4f5bd55305dbfe2ff0 --bundle /Users/zhangc/Library/Developer/Xcode/DerivedData/UICatalog-hiixtcsjcynttngjfqlnzjjtpxkv/Build/Products/Debug-iphonesimulator/UICatalog.app‘ exited with code 253‘

因为这个app当时是在模拟器进行的配置,所以我们还要配置真机,如下:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

但是报错:

Signing for "UICatalog" requires a development team. Select a development team in the project editor. (in target ‘UICatalog‘)

 

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

如图修改就不报错了:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

再一次运行,真机配置安装app成功:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

复制app的Path到appium-desktop的参数中:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

启动session后,可以加载app,如图:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

2)编写自动化脚本

(1)WebView自动化

需要安装以下几个命令:

①安装依赖库:libimobiledevice

brew install libimobiledevice --HEAD 

②安装ios-webkit-debug-proxy:

官网为:

https://github.com/google/ios-webkit-debug-proxy

http://appium.io/docs/en/writing-running-appium/web/ios-webkit-debug-proxy/

# 调试转换
brew install ios-webkit-debug-proxy

并且IOS手机设置一下Web检查器:设置->safari浏览器->高级->Web检查器->打开

# 扩展:手机截图
idevicescreenshot

安装完成后,进行appium-desktop参数配置:

{
  "platformName": "iOS",
  "platformVersion": "10.3",
  "deviceName": "iPhone5s",
  "automationName": "XCUITest",
  "udid": "auto",  # 默认第一台连接设备 "startIWDP": true,
  "browserName": "Safari"
}

启动session后,成功:

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(

③编写脚本

package IOS.Real;

import io.appium.java_client.ios.IOSDriver;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.openqa.selenium.remote.DesiredCapabilities;

import java.net.MalformedURLException;
import java.net.URL;

public class DemoTest_WebView {

    private IOSDriver driver;

    @Before
    public void setUp() throws MalformedURLException {
        DesiredCapabilities desiredCapabilities = new DesiredCapabilities();
        desiredCapabilities.setCapability("platformName", "iOS");
//        desiredCapabilities.setCapability("platformVersion", "10.3");
        desiredCapabilities.setCapability("deviceName", "auto");
        desiredCapabilities.setCapability("automationName", "XCUITest");
        desiredCapabilities.setCapability("udid", "auto");
        desiredCapabilities.setCapability("startIWDP", true);
        desiredCapabilities.setCapability("browserName", "Safari");
//        42ebab931b6b2d6a140b1a4f5bd55305dbfe2ff0
        URL remoteUrl = new URL("http://localhost:4723/wd/hub");

        driver = new IOSDriver(remoteUrl, desiredCapabilities);
    }

    @Test
    public void web(){
        driver.get("https://testerhome.com");
        driver.findElementByXPath("//*[contains(@title,‘北京管理沙龙‘)]").click();
//        driver.get("https://appium.io/");
//        driver.findElementByXPath("(//XCUIElementTypeOther[@name="导航"])[1]").click();
    }

    @After
    public void tearDown() {
//        driver.quit();
    }
}

运行代码后一直报错,后来经过痛苦的查询得知:

参考解决地址:《AppiumDriver driver = new AppiumDriver 的AppiumDriver报错问题解决

WebDriverException: An unknown server-side error occurred while processing the command. Original error: Unhandled endpoint 

错误日志:org.openqa.selenium.WebDriverException: An unknown server-side error occurred while processing the command. Original error: Unhandled endpoint: /session/763C2E9E-9078-4931-BDF3-A05C2E3AF2E5/wda/screen -- http://localhost:8100/ with parameters {
wildcards = (
"session/763C2E9E-9078-4931-BDF3-A05C2E3AF2E5/wda/screen"
);
}

代码执行到这里就报错:

driver = new IOSDriver(remoteUrl, desiredCapabilities);

因为使用的appium-client版本太高导致的,后来在Maven中由6.1.0版本降到5.0.4版本再运行就好了

【Mac   Appium   Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(