python - 简述unittest框架

简述unittest框架

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

一、unittest结构概览

unittest中最核心的四个概念是:test fixture、test case, test suite, test runner/report

1、test fixture

① setup():每个测试函数运行前运行

② teardown():每个测试函数运行完后执行

③ setUpClass():必须使用@classmethod 装饰器,所有test运行前运行一次

④ tearDownClass():必须使用@classmethod装饰器,所有test运行完后运行一次

2、Testcase

a、编写自己的测试用例必须继承TestCase类

import unittest

class TestCase(unittest.TestCase)

b、编写测试case:

def test_001_case1(self):
        print("case1")

def test_002_case1(self):
        print("case2")

注:

  1、测试用例的名字必须以test开头,不以test命名的测试用例不会被加载运行(除在test命名的测试用例中调用外)

  2、测试用例的执行顺序可以自定义,如果以数字命名测试用例(如:test_001_case1、test_002_case1),则按照数字顺序执行,如果不以数字命名则按照test后的英文单词的字母顺序作为执行顺序

c、选择性的执行测试case

"""@unittest.skip(reason): skip(reason)装饰器:无条件跳过装饰的测试,并说明跳过测试的原因。

@unittest.skipIf(reason): skipIf(condition,reason)装饰器:条件为真时,跳过装饰的测试,并说明跳过测试的原因。

@unittest.skipUnless(reason): skipUnless(condition,reason)装饰器:条件为假时,跳过装饰的测试,并说明跳过测试的原因。

@unittest.expectedFailure(): expectedFailure()测试标记为失败。"""

d、测试case常用的断言

"""
assertEqual(a,b,[msg=‘测试失败时打印的信息‘]):断言a和b是否相等,相等则测试用例通过。

assertNotEqual(a,b,[msg=‘测试失败时打印的信息‘]):断言a和b是否相等,不相等则测试用例通过。

assertTrue(x,[msg=‘测试失败时打印的信息‘]):断言x是否True,是True则测试用例通过。

assertFalse(x,[msg=‘测试失败时打印的信息‘]):断言x是否False,是False则测试用例通过。

assertIs(a,b,[msg=‘测试失败时打印的信息‘]):断言a是否是b,是则测试用例通过。

assertNotIs(a,b,[msg=‘测试失败时打印的信息‘]):断言a是否是b,不是则测试用例通过。

assertIsNone(x,[msg=‘测试失败时打印的信息‘]):断言x是否None,是None则测试用例通过。

assertIsNotNone(x,[msg=‘测试失败时打印的信息‘]):断言x是否None,不是None则测试用例通过。

assertIn(a,b,[msg=‘测试失败时打印的信息‘]):断言a是否在b中,在b中则测试用例通过。

assertNotIn(a,b,[msg=‘测试失败时打印的信息‘]):断言a是否在b中,不在b中则测试用例通过。

assertIsInstance(a,b,[msg=‘测试失败时打印的信息‘]):断言a是是b的一个实例,是则测试用例通过。

assertNotIsInstance(a,b,[msg=‘测试失败时打印的信息‘]):断言a是是b的一个实例,不是则测试用例通过。
"""

E、测试case参数化操作

测试case 默认是不支持传参操作的,因此想要达到传参效果,需要用到一个第三方模块进行参数化操作。

1、下载

pip3 install nose_parameterized

2、示例:

import unittest
from nose_parameterized import parameterized

class Test(unittest.TestCase):
    @parameterized.expand(
        [
            [‘xiaogang‘,‘123456‘,True], #可以是list,也可以是元祖
            [‘‘,‘123456‘,True],
            [‘xiaogang‘,‘‘,False],
            [‘adgadg‘,‘123456‘,False]
        ]
    )
    def test_login(self,args1,args2,args3): #这里的参数对应上述列表里的元素,运行的时候会遍历上述列表里的二维列表直到所有元素都调用运行完成
        print(args1,args2)

3、Text Suite

原文地址:https://www.cnblogs.com/Keep-Ambition/p/8976583.html

时间: 2024-10-02 10:32:12

python - 简述unittest框架的相关文章

selenium + python自动化测试unittest框架学习(二)

1.unittest单元测试框架文件结构 unittest是python单元测试框架之一,unittest测试框架的主要文件结构: File >report >all_case.py >test_case >__init__.py >test_case1..... >public >__init__.py >login.py >loginout.py test_case文件夹主要存放测试用例,且测试用例命名以test_开头 public文件夹是test

selenium + python自动化测试unittest框架学习(一)selenium原理及应用

unittest框架的学习得益于虫师的<selenium+python自动化实践>这一书,该书讲得很详细,大家可以去看下,我也只学到一点点用于工作中,闲暇时记录下自己所学才能更加印象深刻.unittest框架学习需要掌握以下知识点: (1)Selenium原理及工具使用 (2)webdriver元素定位,id,name,class name,css seletor,xpath (3)python语言基础,模块,参数化,语言,装饰器 (4)unittest框架认识及学习:模块化,断言,参数化,数

Python中Unittest框架 &#203867;

原文: http://blog.gqylpy.com/gqy/483 置顶:来自一名75后老程序员的武林秘籍--必读(博主推荐) 来,先呈上武林秘籍链接:http://blog.gqylpy.com/gqy/401/ 你好,我是一名极客!一个 75 后的老工程师! 我将花两分钟,表述清楚我让你读这段文字的目的! 如果你看过武侠小说,你可以把这个经历理解为,你失足落入一个山洞遇到了一位垂暮的老者!而这位老者打算传你一套武功秘籍! 没错,我就是这个老者! 干研发 20 多年了!我也年轻过,奋斗过!我

Selenium with Python 010 - unittest 框架(又称PyUnit 框架)

unittest进行python代码单元测试 calculator.py--被测试类 #!/usr/bin/env python # -*- coding: utf-8 -*- # 将要被测试的类 class Calculator(object): 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 d

python单元测试unittest框架

环境:PyCharm 2016.2 + python 3.5 待测试的类:(Widget.py) 测试类:(Auto.py) 测试结果: 总结:1.第一步:先写好测试类2.第二步:导入unittest模块及测试的类,运用setup()方法做测试前的准备工作,如建立数据库连接,运用teardown()方法做测试后的清除工作,如取消数据库的链接,再对类中的方法逐一做测试.3.第三步: 写suite()的全局方法,将要测试的方法,一一加入.测试结果,有几个测试用例就有几个. 最后显示OK,表示通过.

selenium + python自动化测试unittest框架学习(四)python导入模块及包知识点

在写脚本的时候,发现导入某些模块,经常报错提示导入模块失败,这里来恶补下python导入模块的知识点. 1.模块导入时文件查找顺序 在脚本中,import xxx模块时的具体步骤: (1)新建一个module (2)将module插入到sys.module (3)查找module的路径,查找的顺序为先查找当前使用导入模块的文件同一级目录,之后是python的搜索模块的路径集sys.path,最后是python所添加的默认环境变量的路径Python path (4)module查找到之后装载mod

selenium + python自动化测试unittest框架学习(五)webdriver的二次封装

因为webdriver的api方法很长,再加上大多数的定位方式是以xpath方式定位,更加让代码看起来超级长,为了使整体的代码看起来整洁,对webdriver进行封装,学习资料来源于虫师的<selenium +  python自动化测试>一书. 在与测试用例文件夹同一目录下新建一个文件夹package,用来放置封装方法的模块文件 我们将webdriver二次封装的文件命名为location.py from selenium import webdriver from test_case.pub

selenium + python自动化测试unittest框架学习(三)webdriver元素定位(一)

1.Webdriver原理 webdirver是一款web自动化操作工具,为浏览器提供统一的webdriver接口,由client也就是我们的测试脚本提交请求,remote server浏览器进行响应请求,相对于原来selenium1中的selenium rc更加的简便,对浏览器的操作更加灵活. 2.定位 (1)元素的定位: 元素的定位可以通过id,name,class name,tag name,link_text,partial_link_text,css selector,xpath等 语

selenium + python自动化测试unittest框架学习(六)分页

接触的项目分页的形式是以下形式: 想要获取总页数后,遍历执行翻页的功能,但由于分页是以javascript方法实现的,每次点击确定按钮后,页面就回刷新,webelement元素过期无法遍历下一个进行翻页操作,报StaleElementReferenceException的错误,所以对于这个操作折腾了半天还是放弃了. 对于分页的操作实现了以下功能: (1)获取总页数并输出 (2)遍历操作'上一页','下一页'按钮,实现翻页功能 (3)在输入页数的文本框中输入页数,点击确定,实现翻页功能 def p