Android使用Appium进行自动化测试
Appium的介绍和工作原理暂且不说,本篇只为说明Appium的简单使用方法(mac版本)。
1、Appium的下载安装
Appium官方网址
http://appium.io/
客户端下载地址
https://github.com/appium/appium-desktop/releases/tag/v1.5.0
建议使用客户端进行操作,当然你也可以使用命令行的方式
> brew install node # get node.js
> npm install -g appium # get appium
> npm install wd # get appium client
> appium & # start appium
> node your-appium-test.js
2、简单使用Appium客户端
打开Appium客户端,默认Host为0.0.0.0 ,Port为4723,不需更改,直接点击下方的Start Server按钮开启即可。(也可将Host改为127.0.0.1)
开启后的Appium如下图
appium.jpeg
如图则表示appium已正式运行,下面用客户端来进行自动化打开Android模拟器的计算器程序
1.点击Appium右上角的放大镜(Start Inspector Session)按钮,进入服务设定页面
2.Desired Capabilities 配置
Desired Capabilities 在启动 session 的时候是必须提供的。
Desired Capabilities 本质上是以 key value 字典的方式存放,客户端将这些键值对发给服务端,告诉服务端我们想要怎么测试。它告诉 appium Server这样一些事情:
本次测试是启动浏览器还是启动移动设备。
是启动Andorid还是启动iOS。
启动Android时,app的package是什么。
启动Android时,app的activity是什么。
…
我们配置如下参数
{
"deviceName": "deviceName",
"automationName": "Appium",
"platformName": "Android",
"platformVersion": "7.0",
"appPackage": "com.android.calculator2",
"appActivity": ".Calculator"
}
-
deviceName:启动哪种设备,是真机还是模拟器?iPhone Simulator,iPad Simulator,iPhone Retina 4-inch,Android Emulator,Galaxy S4…
-
automationName:使用哪种自动化引擎。appium(默认)还是Selendroid。
-
platformName:使用哪种移动平台。iOS, Android, orFirefoxOS。
-
platformVersion:指定平台的系统版本。例如指的Android平台,版本为5.1。
-
appActivity:待测试的app的Activity名字。比如MainActivity、.Settings。注意,原生app的话要在activity前加个”.“。
-
appPackage:待测试的app的Java package。比如com.example.android.myApp, com.android.settings。
更多的参数配置 ,参考 这里
3.点击右下角Start Session(确保移动平台,如模拟器等处于开启状态),成功开启如下页面则表示计算器自动启动成功。
end.jpeg到此,已成功使用Appium自动化启动程序,下面我们开始使用脚本语言来进行自动化的测试学习。
3、使用脚本语言来使用Appium进行自动化测试
由于是进行Android的自动化测试,我们来直接使用java的语言进行编写脚本语言,这里我们使用Android Studio来进行简单的尝试。
1.创建Android工程
我们创建一个名如AppiumTest的Android工程,使用junit测试包,来进行测试的操作,记得导入引用包,现在一般新建的项目都自带junit的引用包,即:
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
defaultConfig里也要设置
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
2.编写简单的测试脚本
在工程的test文件夹下,添加一个测试类,如AppTest类,如图
apptest.jpeg
添加如下代码
@Test
public void main() throws MalformedURLException, InterruptedException {
DesiredCapabilities capabilities = new DesiredCapabilities();
capabilities.setCapability("deviceName", "Android Emulator");
capabilities.setCapability("automationName", "Appium");
capabilities.setCapability("platformName", "Android");
capabilities.setCapability("platformVersion", "7.0");
capabilities.setCapability("appPackage", "com.android.calculator2");
capabilities.setCapability("appActivity", ".Calculator");
AndroidDriver driver = new AndroidDriver(new URL("http://127.0.0.1:4723/wd/hub"), capabilities);
driver.findElementById("com.android.calculator2:id/digit_1").click();
driver.findElementById("com.android.calculator2:id/digit_5").click();
driver.findElementById("com.android.calculator2:id/digit_9").click();
driver.findElementById("com.android.calculator2:id/del").click();
driver.findElementById("com.android.calculator2:id/op_sub").click();
driver.findElementById("com.android.calculator2:id/digit_9").click();
driver.findElementById("com.android.calculator2:id/digit_5").click();
driver.findElementById("com.android.calculator2:id/op_add").click();
driver.findElementById("com.android.calculator2:id/digit_7").click();
driver.findElementById("com.android.calculator2:id/digit_3").click();
driver.findElementById("com.android.calculator2:id/digit_6").click();
driver.findElementById("com.android.calculator2:id/eq").click();
Thread.sleep(2000);
String result = driver.findElementById("com.android.calculator2:id/result").getText();
System.out.println(result);
driver.quit();
}
注意此类里需要引用两个jar包
image.png
没有jar的同学可在以下地址下载,分别是
java-client-6.0.0-BETA4.jar http://mvnrepository.com/artifact/io.appium/java-client
selenium-server-standalone-3.11.0.jar https://www.seleniumhq.org/download/
代码说明:
driver.findElementById("com.android.calculator2:id/digit_1").click();
这里的Id,可在上面用客户端打开的页面中查找,如
image.png
是指1按钮的id,以此类推。
3.运行尝试
点击运行,如下
image.png
4.运行结果
如下显示则表明运行成功,并可以看到模拟器的计算器自动打开并点击运行。
image.png
至此,Appium的简单使用,便告一段落,如有问题,请指正,谢谢!