您的位置:

appium使用详解

一、安装与配置

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 的使用方法,并在实际项目中进行应用。