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_ ...
随机推荐
- jqgrid--api,官网demo,编辑
api参考: http://blog.csdn.net/hurryjiang/article/details/7551477 官网demo: http://www.trirand.com/blog/j ...
- 如何得到DataTable的列名
foreach (DataColumn dc in dtfood.Columns) { string lm = dc.ColumnName; }
- CUDA V9.2 sample编译问题
这个哥们也遇到一样的问题 CUDA 9.1/9.2 与 Visual Studio 2017 (VS2017 15.6.4) 的不兼容问题 错误有显示 #if _MSC_VER < 1600 | ...
- UI面试题(1)
1.请创建一个数组对象[@“ad”,@“bc”,@“sdf”,@“yu”],并且对该数组对象进行排序(使用冒泡排序); NSMutableArray *array = [NSMutableArraya ...
- NEKOGAMES
http://bbs.3dmgame.com/thread-4133434-1-1.html
- [Uva10641]Barisal Stadium(区间dp)
题意:按照顺时针给出操场的周边点,然后给出周围可以建设照明灯的位置,以及在该位置建设照明灯的代价,照明灯照射的范围与操场的边界相切,现在要求一个最小的花费,要求操场的所有边都被照射到. 解题关键:预处 ...
- IoC概述
---------------siwuxie095 IoC,即 Inversion of Control,控制反转,它是 Spring 容器的内核 AOP.声明式事务等功能都是在此基础上开花结果,即 ...
- 使用LookAndFeel为界面更换皮肤
----------------siwuxie095 在 Windows 系统中,默认的 Java 运行环境(JRE)会为当前的窗体程序 指定一 ...
- 数据库导入sql文件
数据库导入sql文件包括两种方式: 一.命令行导入 二.数据库工具导入 后续完善
- Java Synchronized的原理
我们先通过反编译下面的代码来看看Synchronized是如何实现对代码块进行同步的: public class SynchronizedDemo{ public void method(){ syn ...