单元测试

  unittest单元测试是基于java的JUnit思想框架开发出来的测试框架

使用示例1

import  unittest
class Mytest1(unittest.TestCase):
def test_a(self):#用例必须已test开头
self.assertEqual(1,1,msg='错误提示信息,如果校验失败,出现这个')
print('a')
def test_c(self):
self.assertEqual(1,2,msg='失败')#如果校验结果不正确,不会执行后面的代码
print('c')#这条代码不会执行
def test_z(self):#函数执行优先级:按照函数的首字母顺序依次执行A-Z-a-z
self.assertEqual(4,4)
print('z')
def test_G(self):
self.assertEqual(3,3)
print('G')
if __name__ == "__main__":
suite = unittest.TestSuite()
#suite.addTest(Mytest1('test_a')) #添加一个测试类中的一个方法
testlist = [Mytest1('test_c'),Mytest1('test_d')]
suite.addTests(testlist) #加载多个测试类的方法
unittest.TextTestRunner().run(suite)

使用示例2

import  unittest
class Mytest1(unittest.TestCase):
def test_a(self):#用例必须已test开头
self.assertEqual(1,1,msg='错误提示信息,如果校验失败,出现这个')
print('a')
def test_c(self):
self.assertEqual(1,2,msg='失败')#如果校验结果不正确,不会执行后面的代码
print('c')#这条代码不会执行
def test_z(self):#函数执行优先级:按照函数的首字母顺序依次执行A-Z-a-z
self.assertEqual(4,4)
print('z')
def test_G(self):
self.assertEqual(3,3)
print('G')
if __name__ == "__main__":
#suite = unittest.TestLoader().loadTestsFromTestCase(Mytest1) #指定类的加载
#suite = unittest.TestLoader().loadTestsFromName('a') #导入模块名
#suite = unittest.TestLoader().loadTestsFromName('a.Mytest1.test_a') #也可以这样导入 test_list = ['a.Mytest1.test_a','a.Mytest1.test_z']
suite = unittest.TestLoader().loadTestsFromNames(test_list) #导入多个模块
unittest.TextTestRunner().run(suite)

跳过skip的使用

import  unittest
a = 1
b = 2
class Mytest1(unittest.TestCase):
@unittest.skip('该函数已经弃用,跳过该方法') #表示跳过test_a函数,不会被执行
def test_a(self):#用例必须已test开头
self.assertEqual(1,1,msg='错误提示信息,如果校验失败,出现这个')
print('a')
@unittest.skipIf(b>a,'判断后执行') #如果b大于a,跳过执行,反之执行, skipUnless是skip相反的方法
def test_c(self):
self.assertEqual(1,2,msg='失败')#如果校验结果不正确,不会执行后面的代码
print('c')#这条代码不会执行
@unittest.expectedFailure #不用执行,直接为false
def test_z(self):#函数执行优先级:按照函数的首字母顺序依次执行A-Z-a-z
self.assertEqual(4,4)
print('z')
def test_G(self):
self.assertEqual(3,3)
print('G')
if __name__ == "__main__":
unittest.main() #运行所有测试用例 #unittest命令行方式
#python -m unittest a b 执行多个单元测试模块
#python -m unitest a.test_a b.test_b 执行模块类或者方法

HTMLTestRunner以及美化报告

import  unittest
import HTMLTestRunner
class Mytest1(unittest.TestCase):
def test_a(self):#用例必须已test开头
self.assertEqual(1,1,msg='错误提示信息,如果校验失败,出现这个')
print('a')
def test_c(self):
self.assertEqual(1,2,msg='失败')#如果校验结果不正确,不会执行后面的代码
print('c')#这条代码不会执行
def test_z(self):#函数执行优先级:按照函数的首字母顺序依次执行A-Z-a-z
self.assertEqual(4,4)
print('z')
def test_G(self):
self.assertEqual(3,3)
print('G')
#unittest.main()#运行所有函数
#unittest.defaultTestLoader.discover()#可以指定一个文件夹,在指定目录下找到测试用例
f = open('a.html','wb')#创建文件
runner = HTMLTestRunner.HTMLTestRunner(f,title='rainbol_test',description='这是一个接口测试用例')#实例化用例报告,并传入文件,title标题,description描述
suite = unittest.makeSuite(Mytest1)#把要生成报告的类变成一个测试集合,
runner.run(suite)#运行测试用例 import BeautifulReport
#美化报告
class Mytest2(unittest.TestCase):
def test_a(self):
'''test_a用例'''#添加用例描述,可以在测试报告中显示
self.assertEqual(1,1,msg='错误提示信息,如果校验失败,出现这个')
def test_c(self):
'''test_c用例'''
self.assertEqual(1,2,msg='失败')
print('c')
def test_z(self):
'''test_z用例'''
self.assertEqual(4,4)
print('z') new_suite= unittest.makeSuite(Mytest2)
report = BeautifulReport.BeautifulReport(new_suite)
report.report(filename='new_report.html',description='这个是新接口测试报告') class Mytest3(unittest.TestCase):
def setUp(self):#每条用例前执行,比如检测接口连接是否正常
print('setUp')
def tearDown(self):#每条用例后执行,比如清理缓存,cookie,redis的信息
print('tearDown')
@classmethod  #注意加入装饰器
def setUpClass(cls):#这个类里面的用例先执行,比如连接数据库
print('setUpClass')
@classmethod  #注意加入装饰器
def tearDownClass(cls):#这个类里面的用例最后执行,比如关闭数据库
print('tearDownClass')

  def test_c(self):
'''test_c用例'''
self.assertEqual(1, 2, msg='失败')
print('c')
def test_z(self):
'''test_z用例'''
self.assertEqual(4,4)
print('z')
unittest.main()
#执行顺序 setUpClass→setUp→test_c→tearDown→setUp→test_z→tearDown→tearDownClass

 

注意点

import unittest

#python不支持多函数传参的方式用在unittest上
class Mytest2(unittest.TestCase):
def test_a(self):
self.a = 2
self.assertEqual(1, 1, msg='错误提示信息,如果校验失败,出现这个')
print('') def test_c(self):
print(self.a)
self.assertEqual(1, 2, msg='失败')
print('')
#这样写运行就会报找不到self.a
  @classmethod  
  def setUpClass(cls):
  cls.res = '1'
  print('setUpClass')
  def test_d(self):
    print(self.res) #但是这些除外,可以找到

数据驱动ddt  pip install ddt

#数据驱动ddt
import ddt
import unittest
@ddt.ddt
class Mytest1(unittest.TestCase):
@ddt.data(*[x for x in range(2)])
def test_a(self,value):
self.assertEqual(10,value,'xx')
#如上执行我们可以看到只要几行代码就可以把重复的测试用例,只是参数不同,把参数传递给一个方法中执行,运行的结果实现了多个用例的单元测试 @ddt.data([1,2,3],[2,4,6])
@ddt.unpack #一条以上数据要用unpack
def test_b(self,value1,value2,value3):
self.assertEqual(value1+value2,value3)
if __name__ == "__main__":
unittest.main()

单元测试覆盖率

  度量的方式

    1.语句覆盖:被度量的代码中每个都执行到

    2.判定覆盖:被称为分支覆盖,即每个分支都会被测到

    3.条件覆盖:如果在判断覆盖中又存在多个表达式的情况,也要被测试到,如 if a = 1 and b = 2

    其他等等...

  coverage的使用(语句覆盖)

    下载

      pip install coverage

    帮助

      coverage help

    运行

      coverage run

    demo实例

#demo.py

import unittest

class Mytest1(unittest.TestCase):
def test_a(self): # 用例必须已test开头
self.assertEqual(1, 1, msg='错误提示信息,如果校验失败,出现这个')
print('a') def test_c(self):
self.assertEqual(1, 1, msg='失败') # 如果校验结果不正确,不会执行后面的代码
print('c') # 这条代码不会执行 def test_z(self): # 函数执行优先级:按照函数的首字母顺序依次执行A-Z-a-z
self.assertEqual(4, 4)
print('z') def test_G(self):
self.assertEqual(3, 3)
print('G') def other1(self):
print('其他的方法') def other2(self):
print('其他的方法') def other3(self):
print('其他的方法') def other4(self):
print('其他的方法') class Mytest2(unittest.TestCase):
def test_a(self): # 用例必须已test开头
self.assertEqual(1, 1, msg='错误提示信息,如果校验失败,出现这个')
print('a') def test_c(self):
self.assertEqual(1, 1, msg='失败') # 如果校验结果不正确,不会执行后面的代码
print('c') # 这条代码不会执行 def test_z(self): # 函数执行优先级:按照函数的首字母顺序依次执行A-Z-a-z
self.assertEqual(4, 4)
print('z') def test_G(self):
self.assertEqual(3, 3)
print('G') if __name__ == '__main__':
unittest.main()

    coverage run demo.py #运行单测代码

    coverage report #生成命令行结果

    coverage html -d xxx.html        #生成html文件   -d 指定html名称

可以看到没有执行的代码被高亮出来

    coverage xml #生成xml文件

# 封装api的方式
import unittest
import coverage cover = coverage.coverage(source=['test_demo'])
cover.start()
suite = unittest.defaultTestLoader.discover(start_dir='.', pattern='test_*.py')
unittest.TextTestRunner().run(suite) cover.stop()
cover.report()
cover.html_report(directory='report')

版权声明:本文原创发表于 博客园,作者为 RainBol本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。

unittest单元测试笔记的更多相关文章

  1. Python+Selenium学习笔记16 - unittest单元测试框架

    unittest单元测试框架包括 Test Case,  Test Suite, Test Runner, Test Fixture Test Cases 组成Test Suite, Test Run ...

  2. python学习笔记(十五)-unittest单元测试的一个框架

    unittest 单元测试的一个框架什么框架 一堆工具的集合. TestCase TestSuite 测试套件,多个用例在一起 TestLoader是用来加载TestCase到TestSuite中的 ...

  3. Node.js的UnitTest单元测试

    body{ font: 16px/1.5em 微软雅黑,arial,verdana,helvetica,sans-serif; } 在专业化的软件开发过程中,无论什么平台语言,现在都需要UnitTes ...

  4. 我的TDD实践---UnitTest单元测试

    我的TDD实践---UnitTest单元测试 “我的TDD实践”系列之UnitTest单元测试 写在前面: 我的TDD实践这几篇文章主要是围绕测试驱动开发所展开的,其中涵盖了一小部分测试理论,更多的则 ...

  5. unittest单元测试框架总结

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

  6. unittest单元测试框架详解

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

  7. Selenium+Python ---- 免登录、等待、unittest单元测试框架、PO模型

    1.免登录在进行测试的过程中难免会遇到登录的情况,给测试工作添加了工作量,本文仅提供一些思路供参考解决方式:手动请求中添加cookies.火狐的profile文件记录信息实现.人工介入.万能验证码.去 ...

  8. unittest单元测试框架

    unittest单元测试框架 概述: 单元测试框架主要用来完成以下三件事: 提供用例组织与执行:当测试用例只有几条时,可以不必考虑用例的组织,但是当用例达到成百上千条时,大量的用例堆砌在一起,就产生了 ...

  9. python unittest单元测试

    unittest单元测试框架:包含测试用例编写.测试收集\测试用例加载.执行测试用例.生成测试用例报告,同时,更提供了添加断言,异常处理等. 第一:创建测试类,创建测试用例 第二:收集测试用例,加载测 ...

随机推荐

  1. 关于反向生成url

    1.模板渲染 <form action="{% url "bieming" 参数 %}" > <input type="text&q ...

  2. InstallerProjects打包

    C#—使用InstallerProjects打包桌面应用程序   前言 打包桌面应用程序实在是一个不常使用的东西,偶尔使用起来经常会忘东忘西的耽误时间,因此,这篇文章多以图片记录过程,也是用于备忘. ...

  3. Git使用总结(二):分支管理

    1.创建分支 a.直接创建 git branch dev(分支名) b.基于某个历史版本创建分支 git branch dev HEAD 2.查看分支 git branch -av 3.删除分支 gi ...

  4. FZU2018级算法第三次作业 3.16 station

    题目大意: 给出1-n共n个数的入栈顺序,可以随时出栈,求出栈的最大字典序. 输入示例 输出示例 51 2 3 4 5 5 4 3 2 1 54 2 5 3 1 5 3 2 4 1 题目分析: 假设目 ...

  5. Python中创建数值列表——参考Python编程从入门到实践

    1. 函数range( )的使用 range( )函数可以生成一系列的数字: for value in range(1, 5): print(value) Note:运行结果是打印数字1到4,即该函数 ...

  6. 15 飞机大战:pygame入门、python基础串连

    0 pygame模块的导入 import pygame导入pygame包 使用pygame.init()导入pygame的所有模块.只有导入模块pygame才能使用. 使用pygame.quit()卸 ...

  7. PAT(B) 1027 打印沙漏(Java)

    题目链接:1027 打印沙漏 (20 point(s)) 题目描述 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个"*",要求按下列格式打印 ***** *** * ...

  8. PAT甲级题分类汇编——线性

    本文为PAT甲级分类汇编系列文章. 线性类,指线性时间复杂度可以完成的题.在1051到1100中,有7道: 题号 标题 分数 大意 时间 1054 The Dominant Color 20 寻找出现 ...

  9. Hibernate持久化,生命周期

    一 .生命周期   1.1  . 说明 持久化类就是我们所说的实体类,实体类(持久化类)对象是有状态的. 为什么实体类对象会有状态? 答:由于HIbernate框架是一个先映射,后操作的框架.所谓的状 ...

  10. (转)高效线程池之无锁化实现(Linux C)

    本文链接:https://blog.csdn.net/xhjcehust/article/details/45844901 笔者之前照着通用写法练手写过一个小的线程池版本,最近几天复习了一下,发现大多 ...