前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >自动化-Appium-第一个Demo-原生(Python版)

自动化-Appium-第一个Demo-原生(Python版)

作者头像
wangmcn
发布2022-07-25 12:50:58
2.1K0
发布2022-07-25 12:50:58
举报
文章被收录于专栏:AllTests软件测试

第一个Demo-原生

本章原生所指的就是App移动应用本身。

第1章 Android

1.1创建项目

1、启动PyCharm,创建My_Appium_Demo项目。创建demo包,之后创建脚本文件。例如:模拟器示例为Android_App_Simulator,真机示例为Android_App_RealMachine

如图所示:

2、创建app文件夹,用来存放应用程序。把应用程序testApp.apk拷贝到文件夹里。

3、打开项目解释器(File--->Settings...--->Project:--->Project Interpreter),确保Appium-Python-Client包已经被项目引用。

1.2编写脚本

1.2.1模拟器

1、本章示例模拟器使用的是Genymotion,首先打开Genymotion模拟器,打开指定的Android版本。

2、首先获取模拟器设备标识,命令行输入命令 adb devices

如图所示,只查询到1台此模拟器,在脚本里可以不用添加此参数

desired_caps['udid'] = '192.168.89.101:5555'

就可以指定此台模拟器执行。

如果是多台设备,如图所示,查询到2台(1台模拟器192.168.89.101:5555、1台真机MYV0215825000026),在脚本就要添加此参数

desired_caps['udid'] = '192.168.89.101:5555'

测试执行的时候来指定这台模拟器执行。

3、模拟器里没有要测试的应用程序,可以在执行自动化测试前先安装到模拟器里,输入安装命令 adb install -r 进行安装,或者使用手机助手进行安装,或者直接将.apk应用程序拖拽到模拟器上进行安装。

4、模拟器里没有要测试的应用程序,想在自动化测试执行的时候自动安装。则需要在脚本里添加如下代码:

代码语言:javascript
复制
# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('C:\\PycharmProjects\\My_Appium_Demo\\app\\testApp.apk')

5、当模拟器里有要测试的应用程序,每次执行测试脚本可以不用安装被测应用,只要指定appPackage和appActivity就可以了。

6、接下来开始使用查找元素定位工具来获取元素的属性值等信息。例如使用Android SDK的uiautomatorviewer工具查找元素。

7、脚本代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
import os
import time
"""
Android-原生-模拟器
"""
# 定义启动设备需要的参数
desired_caps = {}

# 使用哪个自动化测试引擎
# 默认为Appium,或Selendroid或UiAutomator2或Espresso用于Android;或XCUITest用于IOS
desired_caps['automationName'] = 'Appium'

# 使用哪个移动操作系统平台 iOS, Android, FirefoxOS
desired_caps['platformName'] = 'Android'

# 移动操作系统版本
desired_caps['platformVersion'] = '6.0'

# 使用的移动设备或模拟器的类型
# iPhone Simulator, iPad Simulator, iPhone Retina 4-inch, Android Emulator, Galaxy S4 等等
# 在IOS上,这个关键字的值必须是使用`instruments -s devices`得到的可使用的设备名称之一
# 在Android上,这个关键字目前不起作用
desired_caps['deviceName'] = 'honor'

# 连接的物理设备的唯一设备标识
desired_caps['udid'] = '192.168.89.101:5555'

# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('C:\\PycharmProjects\\My_Appium_Demo\\app\\testApp.apk')

# 要运行Android应用的包名
desired_caps['appPackage'] = 'com.example.testapp'

# 要从包中启动的Android activity的活动名称
desired_caps['appActivity'] = 'com.example.testapp.MainActivity'

# 启用Unicode输入法,设置为true可以输入中文字符,默认为false
desired_caps['unicodeKeyboard'] = True

# 在设定了`unicodeKeyboard`关键字运行Unicode测试结束后,将键盘重置为其原始状态
# 如果单独使用,将会被忽略,默认值`false`
desired_caps['resetKeyboard'] = True

# 在此会话之前不要重置应用程序状态
# Android 不要停止应用程序,不要清除应用程序数据,也不要卸载apk
# IOS 测试后不要销毁或关闭SIM卡。开始测试运行在任何模拟运行,或设备插入
desired_caps['noReset'] = True

# 执行完整的重置
# Android 停止应用程序,清除应用程序数据并在测试后卸载apk
# IOS 在真机设备测试后卸载应用程序,在模拟器测试后摧毁模拟器
desired_caps['fullReset'] = False

# 设置命令超时时间,单位:秒
# 达到超时时间仍未接收到新的命令时Appium会假设客户端退出然后自动结束会话
desired_caps['newCommandTimeout'] = 60

driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
print("启动应用程序")

# 输入框输入百度首页
driver.find_element_by_id("com.example.testapp:id/urlField").send_keys("https://www.baidu.com/")

# 点击GO
driver.find_element_by_id("com.example.testapp:id/goButton").click()

time.sleep(2)
driver.quit()

1.2.2真机

1、首先获取真机设备标识,命令行输入命令 adb devices

2、真机设备里没有要测试的应用程序,可以在执行自动化测试前先安装到设备里,输入安装命令 adb install -r 进行安装,或者使用手机助手进行安装。

3、真机设备里没有要测试的应用程序,想在自动化测试执行的时候自动安装。则需要在脚本里添加如下代码:

代码语言:javascript
复制
# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('C:\\PycharmProjects\\My_Appium_Demo\\app\\testApp.apk')

4、当真机设备里有要测试的应用程序,每次执行测试脚本可以不用安装被测应用,只要指定appPackage和appActivity就可以了。

5、接下来开始使用查找元素定位工具来获取元素的属性值等信息。例如使用Android SDK的uiautomatorviewer工具查找元素。

6、脚本代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
import os
import time
"""
Android-原生-真机
"""
# 定义启动设备需要的参数
desired_caps = {}

# 使用哪个自动化测试引擎
# 默认为Appium,或Selendroid或UiAutomator2或Espresso用于Android;或XCUITest用于IOS
desired_caps['automationName'] = 'Appium'

# 使用哪个移动操作系统平台 iOS, Android, FirefoxOS
desired_caps['platformName'] = 'Android'

# 移动操作系统版本
desired_caps['platformVersion'] = '6.0'

# 使用的移动设备或模拟器的类型
# iPhone Simulator, iPad Simulator, iPhone Retina 4-inch, Android Emulator, Galaxy S4 等等
# 在IOS上,这个关键字的值必须是使用`instruments -s devices`得到的可使用的设备名称之一
# 在Android上,这个关键字目前不起作用
desired_caps['deviceName'] = 'honor'

# 连接的物理设备的唯一设备标识
desired_caps['udid'] = 'MYV0215825000026'

# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('C:\\PycharmProjects\\My_Appium_Demo\\app\\testApp.apk')

# 要运行Android应用的包名
desired_caps['appPackage'] = 'com.example.testapp'

# 要从包中启动的Android activity的活动名称
desired_caps['appActivity'] = 'com.example.testapp.MainActivity'

# 启用Unicode输入法,设置为true可以输入中文字符,默认为false
desired_caps['unicodeKeyboard'] = True

# 在设定了`unicodeKeyboard`关键字运行Unicode测试结束后,将键盘重置为其原始状态
# 如果单独使用,将会被忽略,默认值`false`
desired_caps['resetKeyboard'] = True

# 在此会话之前不要重置应用程序状态
# Android 不要停止应用程序,不要清除应用程序数据,也不要卸载apk
# IOS 测试后不要销毁或关闭SIM卡。开始测试运行在任何模拟运行,或设备插入
desired_caps['noReset'] = True

# 执行完整的重置
# Android 停止应用程序,清除应用程序数据并在测试后卸载apk
# IOS 在真机设备测试后卸载应用程序,在模拟器测试后摧毁模拟器
desired_caps['fullReset'] = False

# 设置命令超时时间,单位:秒
# 达到超时时间仍未接收到新的命令时Appium会假设客户端退出然后自动结束会话
desired_caps['newCommandTimeout'] = 60

driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
print("启动应用程序")

# 输入框输入百度首页
driver.find_element_by_id("com.example.testapp:id/urlField").send_keys("https://www.baidu.com/")

# 点击GO
driver.find_element_by_id("com.example.testapp:id/goButton").click()

time.sleep(2)
driver.quit()

1.3执行脚本

1.3.1模拟器

1、开启Appium服务(任选一种即可)

方式一:开启Appium Server

打开命令行,输入 appium --address 127.0.0.1 --port 4723 --no-reset --session-override

如图所示,Appium服务开启。

方式二:开启Appium Desktop

打开Appium Desktop

如服务IP和端口默认的情况下,直接点击Start Server v1.8.0来开启Appium服务,如图所示。

2、选中脚本鼠标右键Run,执行测试脚本。

脚本执行步骤:

(1)打开testApp.apk应用程序

(2)输入框输入百度首页

(3)点击GO

(4)关闭应用程序

1.3.2真机

1、开启Appium服务(任选一种即可)

方式一:开启Appium Server

打开命令行,输入 appium --address 127.0.0.1 --port 4723 --no-reset --session-override

如图所示,Appium服务开启。

方式二:开启Appium Desktop

打开Appium Desktop

如服务IP和端口默认的情况下,直接点击Start Server v1.8.0来开启Appium服务,如图所示。

2、选中脚本鼠标右键Run,执行测试脚本。

脚本执行步骤:

(1)打开testApp.apk应用程序

(2)输入框输入百度首页

(3)点击GO

(4)关闭应用程序

第2章 IOS

2.1创建项目

1、启动PyCharm,创建My_Appium_Demo项目。创建demo包,之后创建脚本文件。例如:模拟器示例为IOS_App_Simulator,真机示例为IOS_App_RealMachine

如图所示:

2、打开项目解释器(PyCharm--->Preferences...--->Project:--->Project Interpreter),确保Appium-Python-Client包已经被项目引用。

2.2编写脚本

2.2.1模拟器

1、使用Xcode创建模拟器,例如:本章示例模拟器名iPhone 8,IOS版本11.3。

2、关于测试的应用程序:

(1)如果是在模拟器上运行,需要装.app的应用程序文件。

要想在IOS模拟器中运行应用,则必须在Xcode中编译时选择模拟器类型,编译生成的文件后缀为.app

(2)如果是在真机上运行,需要装.ipa的应用程序文件。分为正式版和开发版。

正式版(已经发布到App Store上),可以直接在App Store上下载安装或者可以获取.ipa应用程序文件用命令安装到真机上。

开发版(没有发布到App Store上),只能获取.ipa应用程序文件,并且苹果开发者账号添加此真机的UDID,才可以用命令安装到此真机上。

3、本章示例使用的是模拟器,直接将.app应用程序拖拽到模拟器上进行安装即可。

4、在模拟器里测试应用程序,需要指定应用程序的bundleId,因为.app为测试版应用程序,所以bundleId可以询问开发人员提供。

例如:本章贝壳测试版应用bundleId为com.xiaoV.conchBeta。

代码语言:javascript
复制
# 被测应用的bundle ID
# 用于在真实设备中启动测试,也用于使用其他需要bundle ID的关键字启动测试
# 在使用bundle ID在真实设备上执行测试时,你可以不提供`app`关键字,但你必须提供`udid`
desired_caps['bundleId'] = 'com.xiaoV.conchBeta'

5、接下来开始使用查找元素定位工具来获取元素的属性值等信息。例如使用Appium Desktop的Inspector工具查找元素。

首先打开Appium Desktop,点击Start Server v1.8.0来开启Appium服务。

点击放大镜(Start Inspector Session)。

输入Desired Capabilities相关参数信息。例如:

代码语言:javascript
复制
{
  "platformName": "iOS",
  "platformVersion": "11.3",
  "deviceName": "iPhone 8",
  "automationName": "XCUITest",
  "bundleId": "com.xiaoV.conchBeta"
}

之后点击Start Session。

获取指定的元素信息。

6、脚本代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
import time
"""
IOS-原生-模拟器
"""
# 定义启动设备需要的参数
desired_caps = {}

# 使用哪个自动化测试引擎
# 默认为Appium,或Selendroid或UiAutomator2或Espresso用于Android;或XCUITest用于IOS
desired_caps['automationName'] = 'Appium'

# 使用哪个移动操作系统平台 iOS, Android, FirefoxOS
desired_caps['platformName'] = 'iOS'

# 移动操作系统版本
desired_caps['platformVersion'] = '11.3'

# 使用的移动设备或模拟器的类型
# iPhone Simulator, iPad Simulator, iPhone Retina 4-inch, Android Emulator, Galaxy S4 等等
# 在IOS上,这个关键字的值必须是使用`instruments -s devices`得到的可使用的设备名称之一
# 在Android上,这个关键字目前不起作用
desired_caps['deviceName'] = 'iPhone 8'

# 被测应用的bundle ID
# 用于在真实设备中启动测试,也用于使用其他需要bundle ID的关键字启动测试
# 在使用bundle ID在真实设备上执行测试时,你可以不提供`app`关键字,但你必须提供`udid`
desired_caps['bundleId'] = 'com.xiaoV.conchBeta'

# 在此会话之前不要重置应用程序状态
# Android 不要停止应用程序,不要清除应用程序数据,也不要卸载apk
# IOS 测试后不要销毁或关闭SIM卡。开始测试运行在任何模拟运行,或设备插入
desired_caps['noReset'] = True

# 执行完整的重置
# Android 停止应用程序,清除应用程序数据并在测试后卸载apk
# IOS 在真机设备测试后卸载应用程序,在模拟器测试后摧毁模拟器
desired_caps['fullReset'] = False

# 设置命令超时时间,单位:秒
# 达到超时时间仍未接收到新的命令时Appium会假设客户端退出然后自动结束会话
desired_caps['newCommandTimeout'] = 60

# 当IOS的个人信息访问警告(如:位置、联系人、图片)出现时,自动选择接受(Accept),默认值`false`
desired_caps['autoAcceptAlerts'] = False

driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
print("启动贝壳应用程序")
time.sleep(5)

# 点击马上借钱
driver.find_element_by_name("马上借钱").click()

time.sleep(2)
driver.quit()

2.2.2真机

1、首先获取真机udid设备标识,终端输入 idevice_id -l

如图所示:显示该真机的udid信息。

2、关于测试的应用程序:

(1)如果是在模拟器上运行,需要装.app的应用程序文件。

要想在IOS模拟器中运行应用,则必须在Xcode中编译时选择模拟器类型,编译生成的文件后缀为.app

(2)如果是在真机上运行,需要装.ipa的应用程序文件。分为正式版和开发版。

正式版(已经发布到App Store上),可以直接在App Store上下载安装或者可以获取.ipa应用程序文件用命令安装到真机上。

开发版(没有发布到App Store上),只能获取.ipa应用程序文件,并且苹果开发者账号添加此真机的UDID,才可以用命令安装到此真机上。

3、本章示例使用的是真机,测试正式版微博应用(真机通过访问App Store下载微博应用安装即可)。

4、获取应用程序的bundleId,打开终端,输入 ideviceinstaller -l

如图所示:本章示例微博应用的bundleId为com.sina.weibo。

代码语言:javascript
复制
# 被测应用的bundle ID
# 用于在真实设备中启动测试,也用于使用其他需要bundle ID的关键字启动测试
# 在使用bundle ID在真实设备上执行测试时,你可以不提供`app`关键字,但你必须提供`udid`
desired_caps['bundleId'] = 'com.sina.weibo'

5、接下来开始使用查找元素定位工具来获取元素的属性值等信息。例如使用Appium Desktop的Inspector工具查找元素。

首先打开Appium Desktop,点击Start Server v1.8.0来开启Appium服务。

点击放大镜(Start Inspector Session)。

输入Desired Capabilities相关参数信息。例如:

代码语言:javascript
复制
{
  "platformName": "iOS",
  "platformVersion": "11.1",
  "deviceName": "test",
  "automationName": "XCUITest",
  "bundleId": "com.sina.weibo",
  "udid": "c5dc675bddf7d1ac6d91783d5224d72b427f8d04"
}

之后点击Start Session。

获取指定的元素信息。

6、脚本代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
import time
"""
IOS-原生-真机
"""
# 定义启动设备需要的参数
desired_caps = {}

# 使用哪个自动化测试引擎
# 默认为Appium,或Selendroid或UiAutomator2或Espresso用于Android;或XCUITest用于IOS
desired_caps['automationName'] = 'Appium'

# 使用哪个移动操作系统平台 iOS, Android, FirefoxOS
desired_caps['platformName'] = 'iOS'

# 移动操作系统版本
desired_caps['platformVersion'] = '11.1'

# 使用的移动设备或模拟器的类型
# iPhone Simulator, iPad Simulator, iPhone Retina 4-inch, Android Emulator, Galaxy S4 等等
# 在IOS上,这个关键字的值必须是使用`instruments -s devices`得到的可使用的设备名称之一
# 在Android上,这个关键字目前不起作用
desired_caps['deviceName'] = 'test'

# 连接的物理设备的唯一设备标识
desired_caps['udid'] = 'c5dc675bddf7d1ac6d91783d5224d72b427f8d04'

# 被测应用的bundle ID
# 用于在真实设备中启动测试,也用于使用其他需要bundle ID的关键字启动测试
# 在使用bundle ID在真实设备上执行测试时,你可以不提供`app`关键字,但你必须提供`udid`
desired_caps['bundleId'] = 'com.sina.weibo'

# 在此会话之前不要重置应用程序状态
# Android 不要停止应用程序,不要清除应用程序数据,也不要卸载apk
# IOS 测试后不要销毁或关闭SIM卡。开始测试运行在任何模拟运行,或设备插入
desired_caps['noReset'] = True

# 执行完整的重置
# Android 停止应用程序,清除应用程序数据并在测试后卸载apk
# IOS 在真机设备测试后卸载应用程序,在模拟器测试后摧毁模拟器
desired_caps['fullReset'] = False

# 设置命令超时时间,单位:秒
# 达到超时时间仍未接收到新的命令时Appium会假设客户端退出然后自动结束会话
desired_caps['newCommandTimeout'] = 60

# 当IOS的个人信息访问警告(如:位置、联系人、图片)出现时,自动选择接受(Accept),默认值`false`
desired_caps['autoAcceptAlerts'] = False

driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
print("启动微博应用程序")
time.sleep(5)

# 点击发现
driver.find_element_by_name("发现").click()

time.sleep(5)
driver.quit()

2.3执行脚本

2.3.1模拟器

1、开启Appium服务(任选一种即可)

方式一:开启Appium Server

打开终端,输入 appium --address 127.0.0.1 --port 4723 --no-reset --session-override

如图所示,Appium服务开启。

方式二:开启Appium Desktop

打开Appium Desktop

如服务IP和端口默认的情况下,直接点击Start Server v1.8.0来开启Appium服务,如图所示。

2、选中脚本鼠标右键Run,执行测试脚本。

脚本执行时,Appium Desktop或Appium Server自动将WDA(WebDriverAgent)安装到模拟器上。

脚本执行步骤:

(1)打开贝壳应用程序

(2)点击马上借钱

(3)关闭贝壳应用程序

2.3.2真机

1、开启Appium服务(任选一种即可)

方式一:开启Appium Server

打开终端,输入 appium --address 127.0.0.1 --port 4723 --no-reset --session-override

如图所示,Appium服务开启。

方式二:开启Appium Desktop

打开Appium Desktop

如服务IP和端口默认的情况下,直接点击Start Server v1.8.0来开启Appium服务,如图所示。

2、选中脚本鼠标右键Run,执行测试脚本。

脚本执行步骤:

(1)打开微博应用程序

(2)点击发现

(3)关闭微博应用程序

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-12-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AllTests软件测试 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 第1章 Android
  • 1.1创建项目
  • 第2章 IOS
  • 2.1创建项目
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档