Appium+python的单元测试框架unittest(3)——discover(转)
(原文:https://www.cnblogs.com/fancy0158/p/10047906.html)
TestSuite套件可以添加很多个用例后运行,但是每个用例都需要调用addTest()函数。当测试用例很多时,需要把用例拆分,写到不同的.py文件中。
一个简单的测试项目目录如下:

测试用例放在同一个文件夹或不同目录下,此时可以使用unittest的TestLoader类加载测试用例。TestLoader类负责根据各种标准加载测试用例,并将它们返回给测试套件。unittest提供了共享的defaultTestLoader类,可调用discover()加载指定的case文件。
discover(start_dir, pattern = 'test*.py', top_level_dir = None)
1.start_dir:测试用例的目录或测试的模块名
2.pattern = ‘test*.py’:表示用例文件名的匹配原则,目录下以 "test" 开头的 ".py"文件
3.top_level_dir = None:测试模块的顶层目录,默认为None
runAllTest.py 如下:
# conding:utf-8
import unittest test_dir = './test_case' #用例目录
discover = unittest.defaultTestLoader.discover(test_dir, pattern='test*.py') #加载所有的测试类并返回测试套件discover if __name__ == '__main__':
runner = unittest.TextTestRunner()
runner.run(discover) #运行测试套件discover
在 runAllTest.py 文件中使用TestLoader类的discover()方法加载 test_case/ 目录下的所有用例文件,然后通过TextTestRunner运行。
这样,只需运行runAllTest.py文件,即可自动执行所有的测试用例。
附test_case1.py 和 test_case2.py
test_case1.py 如下:
# coding:utf-8
from appium import webdriver
import unittest, time class TestFixture(unittest.TestCase):
@classmethod
def setUpClass(cls):
desired_caps = {}
desired_caps['platformName'] = 'Android'
desired_caps['platformVersion'] = '4.4.2'
desired_caps['deviceName'] = 'Android Emulator'
desired_caps['appPackage'] = 'com.android.calculator2'
desired_caps['appActivity'] = '.Calculator'
cls.driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps) @classmethod
def tearDownClass(cls):
print('class end')
cls.driver.quit()#加号运算case
def test_add(self):
self.driver.find_element_by_name("1").click()
self.driver.find_element_by_name("+").click()
self.driver.find_element_by_name("8").click()
self.driver.find_element_by_android_uiautomator("new UiSelector().text(\"=\")").click()
self.driver.find_element_by_name("CLR").click() #减运算case
def test_sub(self):
self.driver.find_element_by_name("2").click()
self.driver.find_element_by_xpath("//android.widget.Button[contains(@content-desc,'minus')]").click()
self.driver.find_element_by_name("1").click()
self.driver.find_element_by_name("=").click()
self.driver.find_element_by_name("CLR").click() if __name__ == '__main__':
suite = unittest.TestSuite()
suite.addTest(TestFixture('test_add'))
suite.addTest(TestFixture('test_sub'))
runner = unittest.TextTestRunner()
runner.run(suite)
test_case2.py 如下:
# coding:utf-8
from appium import webdriver
import unittest, timeclass TestFixture(unittest.TestCase):
@classmethod
def setUpClass(cls):
desired_caps = {}
desired_caps['platformName'] = 'Android'
desired_caps['platformVersion'] = '4.4.2'
desired_caps['deviceName'] = 'Android Emulator'
desired_caps['appPackage'] = 'com.android.settings'
desired_caps['appActivity'] = '.Settings'
cls.driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps) @classmethod
def tearDownClass(cls):
cls.driver.quit() #开关蓝牙测试case
def test_bluetooth(self):
driver = self.driver
driver.find_element_by_id("com.android.settings:id/switchWidget").click()
time.sleep(1)
driver.find_element_by_id("com.android.settings:id/switchWidget").click()
driver.find_element_by_name("Bluetooth").click()
time.sleep(1)
driver.keyevent(4) #返回键
driver.keyevent(4) # 返回键 #开关data usage
def test_dataUsage(self):
driver = self.driver
driver.find_element_by_name("Data usage").click()
time.sleep(1)
driver.find_element_by_class_name('android.widget.Switch') #开关data usage
time.sleep(1)
driver.find_element_by_class_name('android.widget.Switch') # 开关data usage
driver.keyevent(4) # 返回键
driver.keyevent(4) # 返回键 if __name__ == '__main__':
suite = unittest.TestSuite()
suite.addTest(TestFixture('test_bluetooth'))
suite.addTest(TestFixture('test_dataUsage'))
runner = unittest.TextTestRunner()
runner.run(suite)
Appium+python的单元测试框架unittest(3)——discover(转)的更多相关文章
- Appium+python的单元测试框架unittest(1)(转)
unittest为python语言自带的单元测试框架,python把unittest封装为一个标准模块封装在python开发包中.unittest中常用的类有:unittest.TestCase.un ...
- Appium+python的单元测试框架unittest(4)——断言(转)
(原文:https://www.cnblogs.com/fancy0158/p/10051576.html) 在我们编写的测试用例中,测试步骤和预期结果是必不可少的.当我们运行测试用例时,得到一个运行 ...
- Appium+python的单元测试框架unittest(2)——fixtures(转)
(原文:https://www.cnblogs.com/fancy0158/p/10046333.html) unittest提供的Fixtures用以在测试执行前和执行后进行必要的准备和清理工作,可 ...
- python之单元测试框架—unittest(补充)
一. unittest最核心的四个概念 unittest中最核心的四个概念是:test case,test suite,test runner,test fixture TestCase:一个test ...
- Python之单元测试框架unittest
创建class继承unittest,每一个测试用例是以test开头的函数,先执行setup,然后用例按照字母的顺序执行,然后执行teardown import unittest class demo( ...
- python之单元测试框架—unittest
一. 什么是单元测试?单元测试的对象是什么? 1: 什么是单元测试? 按照定义,单元测试就是对单个模块或者单个类或者单个函数进行测试,一般是开发做的,按照阶段分,一般就是单元测试.集成测试.系统测试. ...
- Python单元测试框架unittest之单用例管理(一)
一.概述 本文介绍python的单元测试框架unittest,unittest原名为PyUnit,是由java的JUnit衍生而来,这是Python自带的标准模块unittest.unittest是基 ...
- 单元测试框架unittest
单元测试:单元测试,是指对软件中的最小可测试单元进行检查和验证,对于单元测试中单元的含义,一般来说,要根据实际情况去判定其具体含义如:c语言中单元指一个函数,java里单元指一个类,图形化的软件中可以 ...
- Python单元测试框架unittest使用方法讲解
这篇文章主要介绍了Python单元测试框架unittest使用方法讲解,本文讲解了unittest概述.命令行接口.测试案例自动搜索.创建测试代码.构建测试套件方法等内容,需要的朋友可以参考下 概 ...
随机推荐
- String 的字面量、常量池、构造函数和intern()函数
一.内存中的 String 对象 Java 的堆和栈 对于基本数据类型变量和对象的引用,也就是局部变量表属于栈内存: 而通过 new 关键字和 constructor 创建的对象存放在堆内存: 直接的 ...
- http_post_data发送数据的获取方式
private function http_get_data($url){ $ch = curl_init($url) ; curl_setopt($ch, CURLOPT_RETURNTRANSFE ...
- cesium.js 设置缩放最大最小限制
viewer.scene.screenSpaceCameraController.minimumZoomDistance = 1200;viewer.scene.screenSpaceCameraCo ...
- Dubbo实践(六)Spring加载Bean流程
根据上一小节对于spring扩展schema的介绍,大概可以猜到dubbo中相关的内容是如何实现的. 再来回顾Dubbo实践(一)中定义的dubbo-provider.xml: <?xml ve ...
- PAT——1058. 选择题
批改多选题是比较麻烦的事情,本题就请你写个程序帮助老师批改多选题,并且指出哪道题错的人最多. 输入格式: 输入在第一行给出两个正整数N(<=1000)和M(<=100),分别是学生人数和多 ...
- Git--查看,删除,添加远程分支
1. 查看远程分支: $ git branch -a 2. 删除远程分支: $ git push origin --delete <branch name> 或者 git push --d ...
- CSU 1598 最长公共前缀 (简单KMP或者暴力)
Submit Page Summary Time Limit: 1 Sec Memory Limit: 128 Mb Submitted: 226 Solved: ...
- HDU 1165 公式推导题
题目链接: acm.hdu.edu.cn/showproblem.php?pid=1165 Eddy's research II Time Limit: 4000/2000 MS (Java/Othe ...
- MongoDB简易
一 安装 1.下载 $ brew install mongodb 2.启动 $ mongod --config /usr/local/etc/mongod.conf 3.连接 $ mongo 二 ...
- linux 编译ffmpeg 支持x264, x265
1. 前言 本教程涉及的ffmpeg, x264, x265 2. 环境依赖 2.1 删除系统中安装的ffmpeg等库 sudo apt-get --purge remove ffmpeg mplay ...