概述

利用python进行测试时,测试用例的加载方式有2种:

一种是通过unittest.main()来启动所需测试的测试模块,上篇文章就是使用的这种方式;

一种是添加到testsuite集合中再加载所有的被测试对象,而testsuit里存放的就是所需测试的用例,下面具体介绍这种方式。

通过suit.addTest()/suit.addTests()加载用例到suit

suit.addTest()用于添加单个测试类或者测试类中的单个方法,suit.addTests()用于添加一个列表。

案例1:通过class("test_xxx")来加载测试用例,如下:

 1 # coding:utf-8
2
3 import unittest
4
5 #被测试方法
6 def cal(a,b):
7 return a+b
8
9 class singletest(unittest.TestCase):
10
11 def setUp(self):
12 print "setUp"
13 pass
14
15 def tearDown(self):
16 print "tearDown"
17 pass
18
19 def test_01(self):
20 print ("test_01")
21 expected = 6
22 result = cal(2, 4)
23 self.assertEqual(expected, result)
24
25 def test_02(self):
26 print ("test_02")
27 expected = 3
28 result = cal(2, 1)
29 self.assertEqual(expected, result)
30
31 if __name__ == '__main__':
32 suite = unittest.TestSuite()
33 suite.addTest(singletest("test_01"))
34 suite.addTest(singletest("test_02"))
35 runner = unittest.TextTestRunner()
36 runner.run(suite)

运行结果如下:

 1 setUp
2 test_01
3 tearDown
4 setUp
5 test_02
6 tearDown
7 ..
8 ----------------------------------------------------------------------
9 Ran 2 tests in 0.000
10
11 OK
12
13 Process finished with exit code 0

全部运行通过!

案例2:将class("test_xxx")格式的方法定义为列表,如下:

 1 # coding:utf-8
2
3 import time,random
4 import HTMLTestRunner
5 import unittest
6 import os
7
8 #被测试方法
9 def cal(a,b):
10 return a+b
11
12 class singletest(unittest.TestCase):
13
14 def setUp(self):
15 print "setUp"
16 pass
17
18 def tearDown(self):
19 print "tearDown"
20 pass
21
22 def test_01(self):
23 print ("test_01")
24 expected = 6
25 result = cal(2, 4)
26 self.assertEqual(expected, result)
27
28 def test_02(self):
29 print ("test_02")
30 expected = 3
31 result = cal(2, 1)
32 self.assertEqual(expected, result)
33
34 if __name__ == '__main__':
35 suite = unittest.TestSuite()
36 tests = [singletest("test_01"),singletest("test_02")]
37 suite.addTests(tests)
38 runner = unittest.TextTestRunner()
39 runner.run(suite)

运行结果如下:

 1 setUp
2 test_01
3 tearDown
4 setUp
5 test_02
6 tearDown
7 ..
8 ----------------------------------------------------------------------
9 Ran 2 tests in 0.000s
10
11 OK
12
13 Process finished with exit code 0

案例3:通过makeSuite方式加载测试用例,如下:

 1 # coding:utf-8
2
3 import time,random
4 import HTMLTestRunner
5 import unittest
6 import os
7
8 #被测试方法
9 def cal(a,b):
10 return a+b
11
12 class singletest(unittest.TestCase):
13
14 def setUp(self):
15 print "setUp"
16 pass
17
18 def tearDown(self):
19 print "tearDown"
20 pass
21
22 def test_01(self):
23 print ("test_01")
24 expected = 6
25 result = cal(2, 4)
26 self.assertEqual(expected, result)
27
28 def test_02(self):
29 print ("test_02")
30 expected = 3
31 result = cal(2, 1)
32 self.assertEqual(expected, result)
33
34 if __name__ == '__main__':
35 suite = unittest.TestSuite()
36 suite.addTest(unittest.makeSuite(singletest))
37 runner = unittest.TextTestRunner()
38 runner.run(suite)

运行结果如下:

 1 setUp
2 test_01
3 tearDown
4 setUp
5 test_02
6 tearDown
7 ..
8 ----------------------------------------------------------------------
9 Ran 2 tests in 0.000s
10
11 OK
12
13 Process finished with exit code 0

 案例4:通过TestLoader().loadTestsFromTestCase()方式加载测试用例,如下:

 1 # coding:utf-8
2
3 import unittest
4
5 #被测试方法
6 def cal(a,b):
7 return a+b
8
9 class TestCase1(unittest.TestCase):
10
11 def setUp(self):
12 print "setUp"
13 pass
14
15 def tearDown(self):
16 print "tearDown"
17 pass
18
19 def test_01(self):
20 print ("test_01")
21 expected = 6
22 result = cal(2, 4)
23 self.assertEqual(expected, result)
24
25 def test_02(self):
26 print ("test_02")
27 expected = 3
28 result = cal(2, 1)
29 self.assertEqual(expected, result)
30
31 class TestCase2(unittest.TestCase):
32
33 def setUp(self):
34 print "setUp"
35 pass
36
37 def tearDown(self):
38 print "tearDown"
39 pass
40
41 def test_03(self):
42 print ("test_03")
43 expected = 8
44 result = cal(3, 5)
45 self.assertEqual(expected, result)
46
47 def test_04(self):
48 print ("test_04")
49 expected = 10
50 result = cal(5, 5)
51 self.assertEqual(expected, result)
52
53 if __name__ == '__main__':
54 suite1 = unittest.TestLoader().loadTestsFromTestCase(TestCase1)
55 suite2 = unittest.TestLoader().loadTestsFromTestCase(TestCase2)
56 suite = unittest.TestSuite([suite1, suite2])
57 unittest.TextTestRunner().run(suite)

运行结果如下:

 1 ....
2 ----------------------------------------------------------------------
3 Ran 4 tests in 0.000s
4
5 OK
6 setUp
7 test_01
8 tearDown
9 setUp
10 test_02
11 tearDown
12 setUp
13 test_03
14 tearDown
15 setUp
16 test_04
17 tearDown
18
19 Process finished with exit code 0

全部运行通过!

 案例5:通过TestLoader().loadTestsFromName()方式加载测试用例,如下:

 1 # coding:utf-8
2
3 import time,random
4 import HTMLTestRunner
5 import unittest
6 import os
7
8 #被测试方法
9 def cal(a,b):
10 return a+b
11
12 class singletest(unittest.TestCase):
13
14 def setUp(self):
15 print "setUp"
16 pass
17
18 def tearDown(self):
19 print "tearDown"
20 pass
21
22 def test_01(self):
23 print ("test_01")
24 expected = 6
25 result = cal(2, 4)
26 self.assertEqual(expected, result)
27
28 def test_02(self):
29 print ("test_02")
30 expected = 3
31 result = cal(2, 1)
32 self.assertEqual(expected, result)
33
34 if __name__ == '__main__':
35 suite = unittest.TestLoader().loadTestsFromName('testcase.singletest')#文件名为testcase
36 runner = unittest.TextTestRunner()
37 runner.run(suite)

运行结果如下:

 1 ..
2 ----------------------------------------------------------------------
3 setUp
4 test_01
5 tearDown
6 setUp
7 test_02
8 tearDown
9 Ran 2 tests in 0.000s
10
11 OK
12
13 Process finished with exit code 0

案例6:通过TestLoader().loadTestsFromNames()方式加载测试用例,如下:

 1 # coding:utf-8
2
3 import time,random
4 import HTMLTestRunner
5 import unittest
6 import os
7
8 #被测试方法
9 def cal(a,b):
10 return a+b
11
12 class singletest(unittest.TestCase):
13
14 def setUp(self):
15 print "setUp"
16 pass
17
18 def tearDown(self):
19 print "tearDown"
20 pass
21
22 def test_01(self):
23 print ("test_01")
24 expected = 6
25 result = cal(2, 4)
26 self.assertEqual(expected, result)
27
28 def test_02(self):
29 print ("test_02")
30 expected = 3
31 result = cal(2, 1)
32 self.assertEqual(expected, result)
33
34 if __name__ == '__main__':
35 suite = unittest.TestLoader().loadTestsFromNames(['testcase.singletest'])#testcase为当前文件名
36 runner = unittest.TextTestRunner()
37 runner.run(suite)

运行结果如下:

 1 ..
2 ----------------------------------------------------------------------
3 setUp
4 test_01
5 tearDown
6 setUp
7 test_02
8 tearDown
9 Ran 2 tests in 0.000s
10
11 OK
12
13 Process finished with exit code 0

下面针对上述脚本中应用到的unittest模块下的几个成员进行简单的介绍,以便于理解上述代码:
 TestCase:所有测试用例的基本类,给一个测试方法的名字,就会返回一个测试用例实例;
 TestSuit:组织测试用例的实例,支持测试用例的添加和删除,最终将传递给  testRunner进行测试执行;
 TextTestRunner:进行测试用例执行的实例,其中Text的意思是以文本形式显示测试结果。测试的结果会保存到TextTestResult实例中,包括运行了多少测试用例,成功了多少,失败了多少等信息;
 TestLoader:用来加载TestCase到TestSuite中的,其中有几个  loadTestsFrom__()方法,就是从各个地方寻找TestCase,创建它们的实例,然后add到TestSuite中,再返回一个TestSuite实例。

Python单元测试框架unittest之单用例管理(二)的更多相关文章

  1. Python单元测试框架unittest之单用例管理(一)

    一.概述 本文介绍python的单元测试框架unittest,unittest原名为PyUnit,是由java的JUnit衍生而来,这是Python自带的标准模块unittest.unittest是基 ...

  2. Python单元测试框架unittest之批量用例管理(discover)

    前言 我们在写用例的时候,单个脚本的用例好执行,那么多个脚本的时候,如何批量执行呢?这时候就需要用到unittet里面的discover方法来加载用例了.加载用例后,用unittest里面的TextT ...

  3. Python单元测试框架unittest之深入学习

    前言 前几篇文章该要地介绍了python单元测试框架unittest的使用,本篇文章系统介绍unittest框架. 一.unittest核心工作原理 unittest中最核心的四个概念是:test c ...

  4. Python单元测试框架unittest使用方法讲解

    这篇文章主要介绍了Python单元测试框架unittest使用方法讲解,本文讲解了unittest概述.命令行接口.测试案例自动搜索.创建测试代码.构建测试套件方法等内容,需要的朋友可以参考下   概 ...

  5. Python单元测试框架unittest重要属性 与 用例编写思路

    前言 本文为转载,原文地址作者列举python unittest这个测试框架的主要属性和 测试用例思路 unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行, ...

  6. Python单元测试框架unittest

    学习接口自动化测试时接触了unittest单元测试框架,学习时参照了虫师编写的<selenium2自动化测试实战>,个人觉得里面讲的例子还比较容易理解的. 一.基础 1.main()和框架 ...

  7. python单元测试框架-unittest(一)

    简介 unittest单元测试框架不仅可以适用于单元测试,还可以使用WEB自动化测试用例的开发与执行,该测试框架可组织执行测试用例,并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果. ...

  8. python单元测试框架-unittest(四)之用例综合框架管理

    简述为何如要框架? 前面测试用例与执行都是写在一个文件,当用例数量不断增加的时候,用例的执行与管理变得非常麻烦,因此需要对用例根据具体的功能模块来使用单独的模块来管理.就像一所学校要根据不同年级进行分 ...

  9. python单元测试框架-unittest(三)之用例执行顺序

    执行顺序规则: 测试类或测试方法的数字与字母顺序0~9,A-Z 执行如下脚本,理解用例执行顺序 #coding=utf-8 import unittest class Test1(unittest.T ...

随机推荐

  1. 对狂神说java的springboot中spring security的总结

    1.spring security的环境搭建 首先新建一个springboot项目,只够选web中的spring web依赖 然后在pom.xml导入相关依赖 <!--thymeleaf模块-- ...

  2. Spring Mvc Long类型精度丢失

    背景 在使用Spring Boot Mvc的项目中,使用Long类型作为id的类型,但是当前端使用Number类型接收Long类型数据时,由于前端精度问题,会导致Long类型数据转换为Number类型 ...

  3. .Net Core Api发布时报502.5 [The Application process failed to Start]问题的解决原因

       碰到这样的错误,在网上找了很久很久.我自己在部署的时候已经把Core 部署需要的环境包在服务器安装好了.还会报这个错,然后在网上找的安装了一个系统补丁包!安装之后还是不行.最后我把服务器重启了一 ...

  4. 策略模式干掉if-else,switch

    1.传统if -else 写法 String nodeModelStr = ""; if (nodeType == NodeType.START){ StartModel star ...

  5. python_selenium_PO模式下显示等待、隐式等待封装,结合Excel读取元素可取默认等待时间配置

    basepage中等待的封装 def implicitly_wait(self): self.driver.implicitly_wait(5)def wait(self): time.sleep(5 ...

  6. python+selenium_鼠标事件

    引言--在实际的web产品测试中,对于鼠标的操作,不单单只有click(),有时候还要用到右击.双击.拖动等操作,这些操作包含在ActionChains类中. 一.ActionChains类中鼠标操作 ...

  7. Selenium-python 之 frame定位元素

    定位元素时经常会出现定位不到元素,这时候我们需要观察标签的上下文,一般情况下这些定位不到的元素存放在了frame或者放到窗口了,只要我们切入进去就可以很容易定位到元素. 处理frame时主要使用到sw ...

  8. 编译原理-确定有穷自动机(deterministic finite automata ,DFA)

    是一个五元组 M=(S,∑,f,S0,F) 其中 S:有穷状态集 ∑:输入字母表(有穷) f:状态转换函数.f(S,a)=S' 是单值部分映射,每个状态面临一个输入符号时,转入的后继状态是确定的. S ...

  9. JAVA 进行图片中文字识别(准确度高)!!!

    OCR 识别文字项目 该项目 可以进行两种方式进行身份证识别 1. 使用百度接口 1.1 application-dev.yml配置 ocr: # 使用baiduOcr 需要有Ocr服务器 使用百度需 ...

  10. Boost 矩形布尔运算

    本文主要介绍boost库中矩形布尔运算的思路和代码解析.在此感谢Intel对开源事业的贡献. 基本概念 图形的插入 所有的操作的第一步都是进行图形的插入,我们需要声明定义好我们要使用的图形类型,以矩形 ...