python unittest单元测试框架-1
Test Case、Test Suite、Test Runner、Test Fixture
- Test Case:单个测试用例
- Test Suite:测试组合。可以把多个测试用例集合在一起执行。
- Test Runner:通过Test Runner的run()方法来执行test suite/test case,可以使用图形界面、文本界面,或返回一个特殊的值来表示测试执行的结果。
- Test Fixture:测试用例环境的搭建和销毁。如果测试用例中需要访问数据库,可以在setUp中建立数据库连接,在tearDown中清除数据库产生的数据,并断开连接
1.单元测试
calculator.py
class Count:
def __init__(self,a,b):
self.a = a
self.b = b
def add(self):
return self.a + self.b
def sub(self):
return self.a - self.b
test.py
from book.calculator import Count
import unittest
class TestCount(unittest.TestCase):
def setUp(self):
print("test start")
def test_add(self):
j = Count(2,3)
self.assertEqual(j.add(),5)
def test_add2(self):
j = Count(54,49)
self.assertEqual(j.add(),103)
def tearDown(self):
print("test end")
if __name__=="__main__":
#__name__是内置属性,使用__main__就是直接使用。
#main()方法可以将一个单元测试模块变成可以直接运行的测试脚本,执行所有以test命令开头的方法
unittest.main()

2.使用Test Suite组织测试用例,Test Runner运行
2.1基于1中calculator.py执行测试集
test.py
from calculator import Count
import unittest
class TestCount(unittest.TestCase):
def setUp(self):
print("test start")
def test_add(self):
j = Count(2,3)
self.assertEqual(j.add(),5)
print("test_add执行完毕")
def test_add2(self):
j = Count(54,49)
self.assertEqual(j.add(),103)
print("test_add2执行完毕")
def tearDown(self):
print("test end")
if __name__=="__main__":
#构造测试集
suite = unittest.TestSuite()
suite.addTest(TestCount("test_add2"))
#执行测试集
runner = unittest.TextTestRunner()
runner.run(suite)

### 2.2编写新的计算类,并组织测试集

### 2.3基于2.2,修改test.py,将测试加减的用例分离

### 2.4基于2.2,如果每个类的初始化和回复一样,可以封装setUp和tearDown
test.py
from calculator import Count
import unittest
class MyTest(unittest.TestCase):
def setUp(self):
print("test start")
def tearDown(self):
print("test end")
class TestAdd(MyTest):
def test_add(self):
j = Count(2,3)
self.assertEqual(j.add(),5)
print("test_add执行完毕")
def test_add2(self):
j = Count(54,49)
self.assertEqual(j.add(),103)
print("test_add2执行完毕")
class TestSub(MyTest):
def test_sub(self):
j = Count(4,1)
self.assertEqual(j.sub(),3)
print("test_sub执行完毕")
def test_sub2(self):
j = Count(5,9)
self.assertEqual(j.sub(),-4)
print("test_sub2执行完毕")
if __name__=="__main__":
#构造测试集
suite = unittest.TestSuite()
suite.addTest(TestAdd("test_add2"))
suite.addTest(TestSub("test_sub2"))
#执行测试
runner = unittest.TextTestRunner()
runner.run(suite)
2.5基于2.3,修改test.py,将测试加减的用例分离到不同的脚本中
calculator.py
class Count:
def __init__(self,a,b):
self.a = int(a)
self.b = int(b)
def add(self):
return self.a + self.b
def sub(self):
return self.a - self.b
testadd.py
from calculator import Count
import unittest
class TestAdd(unittest.TestCase):
def setUp(self):
print("test add start")
def test_add(self):
j = Count(2,3)
self.assertEqual(j.add(),5)
print("test_add执行完毕")
def test_add2(self):
j = Count(54,49)
self.assertEqual(j.add(),103)
print("test_add2执行完毕")
def tearDown(self):
print("test add end")
if __name__=="__main__":
unittest.main()
testsub.py
from calculator import Count
import unittest
class TestSub(unittest.TestCase):
def setUp(self):
print("test sub start")
def test_sub(self):
j = Count(4,1)
self.assertEqual(j.sub(),3)
print("test_sub执行完毕")
def test_sub2(self):
j = Count(5,9)
self.assertEqual(j.sub(),-4)
print("test_sub2执行完毕")
def tearDown(self):
print("test sub end")
if __name__=="__main__":
unittest.main()
runtest.py
import unittest
from testadd import TestAdd
from testsub import TestSub
suite = unittest.TestSuite()
suite.addTest(TestAdd("test_add"))
suite.addTest(TestAdd("test_add2"))
suite.addTest(TestSub("test_sub"))
suite.addTest(TestSub("test_sub2"))
if __name__=="__main__":
runner = unittest.TextTestRunner()
runner.run(suite)

python unittest单元测试框架-1的更多相关文章
- python unittest单元测试框架-2discover
基于TestLoader提供的discover方法实现用例执行 当用例达达到数十条后,在runtest.py文件中通过addTest()添加/删除测试用例就非常麻烦.此时可以使用discover方法找 ...
- python unittest单元测试框架-3用例执行顺序、多级目录、装饰器、fixtures
1.用例执行顺序 unittest默认会按照ascii码的顺序,依次执行.类名--方法名排序,使用discover也是默认排序.如果不想使用默认排序,就使用testsuite测试集的方式. impor ...
- Python+selenium之简单介绍unittest单元测试框架
Python+selenium之简单介绍unittest单元测试框架 一.unittest简单介绍 unittest支持测试自动化,共享测试用例中的初始化和关闭退出代码,在unittest中最小单元是 ...
- Python+Selenium框架设计篇之-简单介绍unittest单元测试框架
前面文章已经简单介绍了一些关于自动化测试框架的介绍,知道了什么是自动化测试框架,主要有哪些特点,基本组成部分等.在继续介绍框架设计之前,我们先来学习一个工具,叫unittest. unit ...
- Python+Selenium ----unittest单元测试框架
unittest是一个单元测试框架,是Python编程的单元测试框架.有时候,也做叫做“PyUnit”,是Junit的Python语言版本.这里了解下,Junit是Java语言的单元测试框架,Java ...
- Python 单元测试框架系列:聊聊 Python 的单元测试框架(一):unittest
作者:HelloGitHub-Prodesire HelloGitHub 的<讲解开源项目>系列,项目地址:https://github.com/HelloGitHub-Team/Arti ...
- Selenium+Python ---- 免登录、等待、unittest单元测试框架、PO模型
1.免登录在进行测试的过程中难免会遇到登录的情况,给测试工作添加了工作量,本文仅提供一些思路供参考解决方式:手动请求中添加cookies.火狐的profile文件记录信息实现.人工介入.万能验证码.去 ...
- Selenium基于Python web自动化基础二 -- 免登录、等待及unittest单元测试框架
一.免登录在进行测试的过程中难免会遇到登录的情况,给测试工作添加了工作量,本文仅提供一些思路供参考解决方式:手动请求中添加cookies.火狐的profile文件记录信息实现.人工介入.万能验证码.去 ...
- Python+Selenium学习笔记16 - unittest单元测试框架
unittest单元测试框架包括 Test Case, Test Suite, Test Runner, Test Fixture Test Cases 组成Test Suite, Test Run ...
随机推荐
- L1-052 2018我们要赢
2018年天梯赛的注册邀请码是“2018wmyy”,意思就是“2018我们要赢”.本题就请你用汉语拼音输出这句话. 输入格式: 本题没有输入. 输出格式: 在第一行中输出:“2018”:第二行中输出: ...
- DevExpress v18.1新版亮点——WinForms篇(五)
用户界面套包DevExpress v18.1日前终于正式发布,本站将以连载的形式为大家介绍各版本新增内容.本文将介绍了DevExpress WinForms v18.1 的新功能,快来下载试用新版本! ...
- CUDA ---- Memory Model
Memory kernel性能高低是不能单纯的从warp的执行上来解释的.比如之前博文涉及到的,将block的维度设置为warp大小的一半会导致load efficiency降低,这个问题无法用war ...
- Java一个简单的线程池实现
线程池代码 import java.util.List; import java.util.Vector; public class ThreadPool { private static ...
- squeeze()
一.说明 B = squeeze(A),B与A有相同的元素,但所有只有一行或一列的维度(a singleton dimension)被去除掉了.A singleton dimension的特征是siz ...
- shell 脚本实战笔记(3)--集群机器的时间同步设置
背景: 有些分布式服务(比如HBase服务), 依赖于系统时间戳, 如果集群各个节点, 系统时间不一致, 导致服务出现诡异的情况. 解决方案: 那如何同步集群各个节点之间的时间? 采用NTP(Netw ...
- 批量分割视频opencv
前言 视频处理过程中,会用到对等长的视频进行处理,此时要对大视频进行分割. 实现步骤 1.批量读取视频集: 2.视频分割: 测试代码 1.批量读取视频集: /********************* ...
- 51Nod 1058: N的阶乘的长度(斯特林公式)
1058 N的阶乘的长度 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 输入N求N的阶乘的10进制表示的长度.例如6! = 720,长度为3. Inp ...
- .net core grpc 实现通信(一)
现在系统都服务化,.net core 实现服务化的方式有很多,我们通过grpc实现客户端.服务端通信. grpc(https://grpc.io/)是google发布的一个开源.高性能.通用RPC(R ...
- 八皇后 递归or迭代
递归: #include <iostream> #include <cstdlib> #include <cstdio> using namespace std; ...