Unittest组织用例的姿势
本文我们将会讲解Python Unittest 里组织用例的5种姿势。
环境准备:
python 3.0以上
python requests库
小编的环境:
python 3.6.4
一、TestLoader
- 当 import unittest 时 ,会自动导入TestLoader类
- TestLoader这个类下,封装了 5 种组织用例的方法
loader.py
class TestLoader(object):
"""
该类负责根据各种标准加载测试并将它们包装在TestSuite中
"""
def loadTestsFromTestCase(self, testCaseClass):
"""
返回testCaseClass中包含的所有测试用例的套件
"""
def loadTestsFromModule(self, module, *args, pattern=None, **kws):
"""
返回给定模块中包含的所有测试用例的套件
"""
def loadTestsFromName(self, name, module=None):
"""
返回给定用例名的测试用例的套件
"""
def loadTestsFromNames(self, names, module=None):
"""
返回给定的一组用例名的测试用例的套件
"""
def discover(self, start_dir, pattern='test*.py', top_level_dir=None):
"""
查找并返回指定的起始目录中的所有测试模块,递归到子目录中以查找它们并返回在其
中找到的所有测试。仅加载与模式匹配的测试文件。
必须可以从项目的顶层导入测试模块。如果起始目录不是顶级目录,则必须单独指定顶级目录。
"""
defaultTestLoader = TestLoader()
"""
当执行 import unittest 时
会自动导入 defaultTestLoader
defaultTestLoader是TestLoader()的实例对象
"""
### 二、unittest组织用例方法演示
#### 项目目录
```
how_to_run_test_case
test_case
__init__.py
test_add.py
test_sub.py
run_from_test_case_class.py
run_from_test_case_moudle.py
run_from_case_name.py
run_from_case_names.py
run_from_discover.py
```
test_add.py
# encoding:utf8
import unittest
class AddCase(unittest.TestCase):
def add_fun(self, a, b):
return a + b
def test_add_1(self):
'''加法冒烟测试'''
ret = self.add_fun(1, 2)
self.assertEqual(3, ret)
def test_add_2(self):
ret = self.add_fun(1, 2)
self.assertEqual(6, ret)
test_sub.py
# encoding:utf8
import unittest
class SubCase(unittest.TestCase):
def add_fun(self, a, b):
return a - b
def test_sub_1(self):
'''减法冒烟测试'''
ret = self.add_fun(1, 2)
self.assertEqual(-1, ret)
def test_sub_2(self):
ret = self.add_fun(1, 2)
self.assertEqual(6, ret)
### 1、加载测试类中的用例
```
loadTestsFromTestCase(self, testCaseClass)
```
- 使用loadTestsFromTestCase这个方法,需传入unittest测试类的类名
- 以项目为例子,传入 testCaseClass :AddCase
例子:
run_from_test_case_class.py
# encoding:utf8
import unittest
from test_case.test_add import AddCase
cases = unittest.TestLoader().loadTestsFromTestCase(AddCase)
runner = unittest.TextTestRunner(verbosity=2)
runner.run(cases)
1.1 运行 run_from_test_case_class.py
python run_from_test_case_class.py
1.2 运行结果
test_add_1 (test_case.test_add.AddCase)
加法冒烟测试 ... ok
test_add_2 (test_case.test_add.AddCase) ... FAIL
### 2、加载模块中的测试用例
```
loadTestsFromModule(self, module, *args, pattern=None, **kws)
```
- 使用loadTestsFromModule这个方法,需传入被测试模块
- 以项目为例子,传入参数 module :test_add
例子:
run_from_test_case_moudle.py
# encoding:utf8
import unittest
from test_case import test_add
cases = unittest.TestLoader().loadTestsFromModule(test_add)
runner = unittest.TextTestRunner(verbosity=2)
runner.run(cases)
2.1 运行 run_from_test_case_moudle.py
python run_from_test_case_moudle.py
2.2 运行结果
test_add_1 (test_case.test_add.AddCase)
加法冒烟测试 ... ok
test_add_2 (test_case.test_add.AddCase) ... FAIL
### 3、加载指定的单个测试用例
```
loadTestsFromName(self, name, module=None)
```
- 使用loadTestsFromName这个方法,需传入测试用例的方法名
- 传入测试用例的方法名格式:moudleName.testCaseClassName.testCaseName
- 以项目为例子,我想测试test_add.py 里面的用例 test_add_1
- 我需要传入的参数 name:test_add.AddCase.test_add_1
- loadTestsFromName这个方法是在 sys.path 里面的路径去寻找测试模块test_add.py,然后再寻找测试类AddCase
最后再寻找测试用例test_add_1
例子:
run_from_case_name.py
# encoding:utf8
import unittest
import os
import sys
# 获取 "how_to_run_test_case" 的绝对路径
dir_run_test_case = os.path.dirname(os.path.abspath(__file__))
# 获取 "test_case" 的绝对路径
dir_test_case = dir_run_test_case + '/test_case'
# 把 "test_case" 的绝对路径 加入 sys.path
sys.path.insert(0,dir_test_case)
case= unittest.TestLoader().loadTestsFromName('test_add.AddCase.test_add_1')
runner = unittest.TextTestRunner(verbosity=2)
runner.run(cases)
3.1 运行 run_from_case_name.py
python run_from_case_name.py
3.2 运行结果
test_add_1 (test_add.AddCase)
加法冒烟测试 ... ok
### 4、加载指定的多个测试用例
```
loadTestsFromNames(self, names, module=None)
```
- 使用loadTestsFromNames这个方法,需要传入一个数组
- 数组里面里面的元素必须是字符串
- 数组元素可以是模块、类、方法
- 数组元素 - 传入格式1:moudleName
- 数组元素 - 传入格式2:moudleName.testCaseClassName
- 数组元素 - 传入格式3:moudleName.testCaseClassName.testCaseName
- 以项目为例,我想测试test_add.py 里面的用例 test_add_1 ,以及test_sub.py 里面的用例 test_sub_1
- 我需要传入的参数 names:['test_sub.SubCase.test_sub_2','test_add.AddCase.test_add_1']
- loadTestsFromNames这个方法是在 sys.path 里面的路径去寻找匹配的测试用例
- 执行用例是根据数组元素的的顺序执行
例子:
run_from_case_names.py
# encoding:utf8
import unittest
import sys
import os
# 获取 "how_to_run_test_case" 的绝对路径
dir_run_test_case = os.path.dirname(os.path.abspath(__file__))
# 获取 "test_case" 的绝对路径
dir_test_case = dir_run_test_case + '/test_case'
# 把 "test_case" 的绝对路径 加入 sys.path
sys.path.insert(0,dir_test_case)
cases = ['test_sub.SubCase.test_sub_1','test_add.AddCase.test_add_1']
suite = unittest.TestLoader().loadTestsFromNames(cases)
runner = unittest.TextTestRunner(verbosity=2)
runner.run(suite)
4.1 运行 run_from_case_names.py
python run_from_case_names.py
4.2 运行结果
test_sub_1 (test_sub.SubCase)
减法冒烟测试 ... ok
test_add_1 (test_add.AddCase)
加法冒烟测试 ... ok
### 5、加载指定目录下所有的测试用例
```
discover(self, start_dir, pattern='test*.py', top_level_dir=None)
```
- start_dir : 查找用例的起始目录
- pattern='test*py' : 查找模块名为test开头的python文件
- top_level_dir=None :测试模块顶级目录
例子:
run_from_discover.py
# encoding:utf8
import unittest
import os
dir_how_to_run_test_case = os.path.dirname(os.path.abspath(__file__))
dir_test_case = dir_how_to_run_test_case + '/test_case'
cases = unittest.defaultTestLoader.discover(dir_test_case)
runner = unittest.TextTestRunner(verbosity=2)
runner.run(cases)
5.1 运行 run_from_discover.py
python run_from_discover.py
5.2 运行结果
test_add_1 (test_add.AddCase)
加法冒烟测试 ... ok
test_add_2 (test_add.AddCase) ... FAIL
test_sub_1 (test_sub.SubCase)
减法冒烟测试 ... ok
test_sub_2 (test_sub.SubCase) ... FAIL
### 6、 Github 源码地址: [https://github.com/SEtester/how_to_run_test_case](https://github.com/SEtester/how_to_run_test_case)
Unittest组织用例的姿势的更多相关文章
- python+unittest 控制用例的执行顺序
unittest的main()方法执行用例的顺序是按照测试类.测试方法的名字的ASCII顺序来执行测试方法.所以可能执行的顺序和你想要的顺序不一样,可能通过下面两种方法修改执行顺序 1. 通过Test ...
- python 接口自动化测试(六)使用unittest 批量用例管理
我们日常项目中的接口测试案例肯定不止一个,当案例越来越多时我们如何管理这些批量案例?如何保证案例不重复?如果案例非常多(成百上千,甚至更多)时如何保证案例执行的效率?如何做(批量)测试数据的管理?如何 ...
- python接口自动化测试十六:unittest完成用例
import unittestimport requests def add(a, b): print('前置条件!!!!!:如登录') return a + b class TestAAA(unit ...
- python+selenium 组织用例方式 总结
1.unittest.main() 将一个单元测试模块变为可直接运行的测试脚本,main()方法使用TestLoader类来搜索所有包含在该模块中以“test”命名开头的测试方法,并自动执行他们.执行 ...
- unittest执行用例方法
#coding=utf-8 from selenium import webdriver from time import sleep import unittest#导入unittest库 impo ...
- unittest管理用例生成测试报告
#登录方法的封装 from appium import webdriver from time import sleep from python_selenium.Slide import swipe ...
- unittest 管理用例生成测试报告
# 登录方法的封装 from appium import webdriver from time import sleep from python_selenium.Slide import swip ...
- python unittest控制用例的执行顺序
为什么要进行顺序控制呢?使用过testng的同学就知道,它相对于junit来说有更强大的功能,其中的一个功能就是依赖测试.什么是依赖测试呢?简单的说一下就是,A方法运行时,其中有个变量的取值是B方法的 ...
- python selenium-5根据unittest组织测试用例
driver:浏览器driver存放地址 testcase:测试用例目录 report:测试结果保存目录 runtest.py:执行文件 test_search1.py搜索selenium,test_ ...
随机推荐
- 洛谷 2822 组合数问题——质因数有关的dp
题目:https://www.luogu.org/problemnew/show/P2822 发现 k 都是一样的.所以可以设dp[ i ][ j ]表示 n<=i,m<=j 的答案.发现 ...
- art-template-loader:template
ylbtech-art-template-loader: 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 6.返回顶部 作者:ylbtech出处:ht ...
- Python函数(十二)-迭代器
字符串,列表,元组,字典,集合,生成器这些能通过for循环来遍历的数据类型都是可迭代对象 可通过isinstance判断是不是可迭代对象 >>> from collections i ...
- pycharm ubuntu安装
https://www.cnblogs.com/iamjqy/p/7000874.html
- 记一次SQL xml字段关联查询
需求: 一张表是APP表,结构如下: app_category为该游戏所属的类别ID,xml字段类型 另一张表是类别表,就ID对应名称,这就不上图了. 还有一张表是每个游戏的下载记录,结构如下: Do ...
- 第四篇 express 安装esasticsearch
1.首先,我们创建一个Express应用程序!我将使用express.js生成器. npm install -g express-generator express ./autocompleter c ...
- JavaScript的内部对象
JavaScript的内部对象 按创建方式不同分为:使用变量声明的隐性对象,使用new创建的显性对象 隐性对象 在赋值和声明后就是一个隐性对象,隐性对象不支持prototype属性,也无法随意扩展对象 ...
- C++11新标准
1. 新类型 long long和unsigned long long: char16_t 和 char32_t: 新增原始字符串: 2. 统一的初始化 C++11扩大了用大括号括起的列表(初始化列表 ...
- 11、比对软件STAR(https://github.com/alexdobin/STAR)
转载:https://mp.weixin.qq.com/s?__biz=MzI1MjU5MjMzNA==&mid=2247484731&idx=1&sn=b15fbee5910 ...
- python包管理
如果是python 项目目录,例如pycharm里新建的python项目,则可以通过from,import导入目录下的文件夹. 如果是普通文件目录,则代码里不能相对方式导入该目录下的文件夹,需要加入要 ...