一、安装与配置
1、安装 appium:
npm install -g appium
2、安装 appium-doctor:
npm install -g appium-doctor
3、执行 appium-doctor:
appium-doctor
会检测所需的环境是否安装及配置完成,如有提示缺失环境就要安装相应的环境。
二、appium基础
1、初始化一个Driver
在使用appium时,我们一定会选择客户端来打开一个手机 APP,并对其进行测试或操作,接下来我们就来讲讲如何初始化一个 Driver。
from appium import webdriver
desired_caps = {
'platformName': 'Android',
'platformVersion': '9.0',
'deviceName': 'Pixel_2_API_28',
'appPackage': 'com.android.settings',
'appActivity': 'com.android.settings.Settings'
}
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
2、查找元素
查找元素是自动化测试的核心,appium 提供了很多方法来查找元素,如:ById、ByClassName、ByName等,下面是一个使用 ById 查找元素的实例:
element = driver.find_element_by_id('com.example:id/button')
三、appium常用操作
1、滑动屏幕
有时我们需要模拟用户滑动屏幕的操作,appium提供了 swipe 方法来完成滑动屏幕的操作,下面是一个简单的方法:
driver.swipe(start_x, start_y, end_x, end_y)
2、输入文本
appium提供了 send_keys 方法来完成输入文本的操作,下面是一个使用 send_keys 方法的实例:
element = driver.find_element_by_id('com.example:id/edit_text')
element.send_keys('hello appium')
3、截图
对于自动化测试,偶尔需要查看完整的屏幕快照,以便了解当前屏幕中的元素分布情况,appium提供了 get_screenshot_as_file() 方法来截取屏幕快照,下面是一个使用 get_screenshot_as_file 方法的实例:
driver.get_screenshot_as_file('screenshot.png')
四、进阶应用
1、多平台支持
appium不仅支持 Android 平台,还支持 iOS 平台,下面是一个简单的多平台测试脚本示例:
from appium import webdriver
desired_caps = {
'platformName': 'iOS',
'platformVersion': '12.0',
'deviceName': 'iPhone XR',
'app': 'app_path'
}
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
2、运行测试套件
在实际的测试中,我们往往需要运行多个测试脚本组成的测试套件,appium 支持 unittest、nose和py.test 等测试框架,下面是一个执行测试套件的示例:
import unittest
from appium import webdriver
class TestApp(unittest.TestCase):
def setUp(self):
desired_caps = {
'platformName': 'Android',
'platformVersion': '9.0',
'deviceName': 'Pixel_2_API_28',
'appPackage': 'com.android.settings',
'appActivity': 'com.android.settings.Settings'
}
self.driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
def test_case1(self):
element = self.driver.find_element_by_id('com.example:id/button')
element.click()
assert element.text == 'clicked'
def tearDown(self):
self.driver.quit()
if __name__ == '__main__':
suite = unittest.TestLoader().loadTestsFromTestCase(TestApp)
unittest.TextTestRunner(verbosity=2).run(suite)
3、并发执行测试用例
并发执行测试用例可以缩短测试用例的执行时间,提高测试效率。appium 支持多种语言的客户端,并且很容易地支持并发执行测试用例,下面是一个 python 并发执行测试用例的示例:
from appium import webdriver
import threading
desired_caps_android = {
'platformName': 'Android',
'platformVersion': '9.0',
'deviceName': 'Pixel_2_API_28',
'appPackage': 'com.android.settings',
'appActivity': 'com.android.settings.Settings'
}
desired_caps_ios = {
'platformName': 'iOS',
'platformVersion': '12.0',
'deviceName': 'iPhone XR',
'app': 'app_path'
}
def test_android():
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps_android)
element = driver.find_element_by_id('com.example:id/button')
element.click()
assert element.text == 'clicked'
driver.quit()
def test_ios():
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps_ios)
element = driver.find_element_by_name('element_name')
element.click()
assert element.text == 'clicked'
driver.quit()
threads = []
t1 = threading.Thread(target=test_android, args=())
threads.append(t1)
t2 = threading.Thread(target=test_ios, args=())
threads.append(t2)
for t in threads:
t.start()
for t in threads:
t.join()
总结
本文详细介绍了 appium 的安装、基本使用、常见操作、进阶应用等方面,读者可以通过本文快速掌握 appium 的使用方法,并在实际项目中进行应用。