本文我们将会讲解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组织用例的姿势的更多相关文章

  1. python+unittest 控制用例的执行顺序

    unittest的main()方法执行用例的顺序是按照测试类.测试方法的名字的ASCII顺序来执行测试方法.所以可能执行的顺序和你想要的顺序不一样,可能通过下面两种方法修改执行顺序 1. 通过Test ...

  2. python 接口自动化测试(六)使用unittest 批量用例管理

    我们日常项目中的接口测试案例肯定不止一个,当案例越来越多时我们如何管理这些批量案例?如何保证案例不重复?如果案例非常多(成百上千,甚至更多)时如何保证案例执行的效率?如何做(批量)测试数据的管理?如何 ...

  3. python接口自动化测试十六:unittest完成用例

    import unittestimport requests def add(a, b): print('前置条件!!!!!:如登录') return a + b class TestAAA(unit ...

  4. python+selenium 组织用例方式 总结

    1.unittest.main() 将一个单元测试模块变为可直接运行的测试脚本,main()方法使用TestLoader类来搜索所有包含在该模块中以“test”命名开头的测试方法,并自动执行他们.执行 ...

  5. unittest执行用例方法

    #coding=utf-8 from selenium import webdriver from time import sleep import unittest#导入unittest库 impo ...

  6. unittest管理用例生成测试报告

    #登录方法的封装 from appium import webdriver from time import sleep from python_selenium.Slide import swipe ...

  7. unittest 管理用例生成测试报告

    # 登录方法的封装 from appium import webdriver from time import sleep from python_selenium.Slide import swip ...

  8. python unittest控制用例的执行顺序

    为什么要进行顺序控制呢?使用过testng的同学就知道,它相对于junit来说有更强大的功能,其中的一个功能就是依赖测试.什么是依赖测试呢?简单的说一下就是,A方法运行时,其中有个变量的取值是B方法的 ...

  9. python selenium-5根据unittest组织测试用例

    driver:浏览器driver存放地址 testcase:测试用例目录 report:测试结果保存目录 runtest.py:执行文件 test_search1.py搜索selenium,test_ ...

随机推荐

  1. jqgrid--api,官网demo,编辑

    api参考: http://blog.csdn.net/hurryjiang/article/details/7551477 官网demo: http://www.trirand.com/blog/j ...

  2. 如何得到DataTable的列名

    foreach (DataColumn dc in dtfood.Columns) { string lm = dc.ColumnName; }

  3. CUDA V9.2 sample编译问题

    这个哥们也遇到一样的问题 CUDA 9.1/9.2 与 Visual Studio 2017 (VS2017 15.6.4) 的不兼容问题 错误有显示 #if _MSC_VER < 1600 | ...

  4. UI面试题(1)

    1.请创建一个数组对象[@“ad”,@“bc”,@“sdf”,@“yu”],并且对该数组对象进行排序(使用冒泡排序); NSMutableArray *array = [NSMutableArraya ...

  5. NEKOGAMES

    http://bbs.3dmgame.com/thread-4133434-1-1.html

  6. [Uva10641]Barisal Stadium(区间dp)

    题意:按照顺时针给出操场的周边点,然后给出周围可以建设照明灯的位置,以及在该位置建设照明灯的代价,照明灯照射的范围与操场的边界相切,现在要求一个最小的花费,要求操场的所有边都被照射到. 解题关键:预处 ...

  7. IoC概述

    ---------------siwuxie095 IoC,即 Inversion of Control,控制反转,它是 Spring 容器的内核 AOP.声明式事务等功能都是在此基础上开花结果,即 ...

  8. 使用LookAndFeel为界面更换皮肤

    ----------------siwuxie095                             在 Windows 系统中,默认的 Java 运行环境(JRE)会为当前的窗体程序 指定一 ...

  9. 数据库导入sql文件

    数据库导入sql文件包括两种方式: 一.命令行导入 二.数据库工具导入 后续完善

  10. Java Synchronized的原理

    我们先通过反编译下面的代码来看看Synchronized是如何实现对代码块进行同步的: public class SynchronizedDemo{ public void method(){ syn ...