单元测试,集成测试,功能测试
Unittest的重要组成部分
断言的使用
测试用例方法的命名规则
执行测试用例
原始的测试报告和第三方的html格式报告
读取xml文件数据进行单元测试
读取csv文件数据进行单元测试
-----------------------------------------------------------------------------------------------
单元测试:
颗粒度最小,一般由开发小组采用白盒方式来测试,主要测试单元是否符合
“
设计
”
;是指对软件中的最小可测试单元进行检查和验证
集成测试:
介于单元测试和系统测试之间,一般由开发小组采用白盒
+
黑盒的方法来测试,即验证
“
设计
”
又验证
“
需求
”
。主要用来测试模板与模板之间的接口,同时还要测试一些主要的业务功能。
功能测试:
颗粒度最大,一般由独立的测试小组采用黑盒的方式来测试,主要测试系统是否符合
“
需求规格说明书
Unittest
重要组成 :
Python
中有一个自带的单元测试框架是
unittest
模块,用它来做单元测试,它里面封装好了一些校验返回的结果方法(断言)和一些用例执行前的初始化操作。
unittest
中最核心的部分是:
TestFixture
、
TestCase
、
TestSuite
、
TestRunner
TestFixture :
当测试用例每次执行之前需要准备测试环境,每次测试完成后还原测试环境,比如执行前连接数据库、打开浏览器等,执行完成后需要还原数据库、关闭浏览器等操作。这时候就可以启
testfixture
主要方法
:
setUp()
:准备环境,执行每个测试用例的前置条件;
tearDown()
:环境还原,执行每个测试用例的后置条件;
setUpClass()
:必须使用
@classmethod
装饰器,所有
case
执行的前置条件,只运行一次;
tearDownClass()
:必须使用
@classmethod
装饰器,所有
case
运行完后只运行一次;
TestCase:
测试用例命名规则 :
继承自
unittest.TestCase
的类中,
测试方法的名称要以test开头
。且只会执行以
test
开头定义的
方法(测试方法)
,
测试用例执行的顺序会按照方法名的
ASCII
值排序。
如果想跳过某个测试用例,需要添加
@unittest.skip)(‘
描述信息
')
-------------------------------------------------------------------------------------------
import
unittest
class
Calc_testcase
(
unittest
.
TestCase
):
def
setUp
(
self
) :
#
测试用例方法执行前的操作
print
(
"start"
)
def
test1
(
self
):
#
测试用例
resl
=
4
self
.
assertEqual
(
resl
,
5
)
def
tearDown
(
self
) :
#
测试用例方法执行后的操作
print
(
"end"
)
if
__name__
==
"__main__"
:
unittest
.
main
()
#
调用测试用例中以
test
开头的方法
-------------------------------------------------------------------------------------------
TestSuite:
测试套件,可以将多个测试用例集合在一起,能一起执行选中的测试用例
---------------------------------------------------------------------------------------------------------
suite
=
unittest
.
TestSuite
()
#
创建测试套件
case_list
= [
“test1”
,
”test2”…
.]
For case
in
case_list
:
suite
.
addTest
(
类名
(
case
))
---------------------------------------------------------------------------------------------------------
TextRunner :
执行测试用例
通过
TextTestRunner
类提供的
run()
方法来执行
test suite/test cas
verbosity
:表示测试报告信息的详细程度,一共三个值,默认是
2
0 (
静默模式
)
:你只能获得总的测试用例数和总的结果,如:总共
100
个 失败
10
成功
90
1 (
默认模式
)
:类似静默模式,只是在每个成功的用例前面有个
.
每个失败的用例前面有个
F
2 (
详细模式
)
:测试结果会显示每个测试用例的所有相关的信息
---------------------------------------------------------------------------------------------------------
runner
=
unittest
.
TextTestRunner
(
verbosity
=
2
)
runner
.
run
(
suite
)
---------------------------------------------------------------------------------------------------------
断言 :
assertEqual(a,b):
断言
a
和
b
是否相等,相等则测试用例通过。
assertNotEqual(a,b):
断言
a
和
b
是否相等,不相等则测试用例通过。
assertTrue(x)
:断言
x
是否
True
,是
True
则测试用例通过。
assertFalse(x)
:断言
x
是否
False
,是
False
则测试用例通过。
assertIs(a,b):
断言
a
是否是
b
,是则测试用例通过。
assertNotIs(a,b):
断言
a
是否是
b
,不是则测试用例通过。
assertIsNone(x)
:断言
x
是否
None
,是
None
则测试用例通过。
assertIsNotNone(x)
:断言
x
是否
None
,不是
None
则测试用例通过。
assertIn(a,b)
:断言
a
是否在
b
中,在
b
中则测试用例通过。
assertNotIn(a,b)
:断言
a
是否在
b
中,不在
b
中则测试用例通过。
assertIsInstance(a,b)
:断言
a
是是
b
的一个实例,是则测试用例通过。
assertNotIsInstance(a,b)
:断言
a
是是
b
的一个实例,不是则测试用例通过。
生成测试报告:
html
格式的就是
HTMLTestRunner
了,
HTMLTestRunner
是
Python
标准库的
unittest
框架的
一个扩展,它可以生成一个直观清晰的
HTML
测试报告。使用的前提就是要下载
HTMLTestRunner.py
---------------------------------------------------------------------------------------------------------------
with
open
(
"../report.html"
,
"wb"
)
as
f
:
HTMLTestRunner
(
stream
=
f
,
title
=
"
单元测试
"
,
description
=
"
测试一期
"
,
verbosity
=
2
).
run
(
suite
)
----------------------------------------------------------------------------------------------------------------
读取文件 :
--------------------------------------------------------------------------------------------------
from
xml
.
dom
import
minidom
class
Readxml
():
def
read_xml
(
self
,
filename
,
onename
,
twoname
):
root
=
minidom
.
parse
(
filename
)
firstnode
=
root
.
getElementsByTagName
(
onename
)[
0
]
secondnode
=
firstnode
.
getElementsByTagName
(
twoname
)[
0
].
firstChild
.
data
return
secondnode
------------------------------------------------------------------------------------------------------
读取csv文件 :
-----------------------------------------------------------------------------------
import
csv
#
导入
csv
模块
class
ReadCsv
():
def
read_csv
(
self
):
item
=[]
#
定义一个空列表
c
=
csv
.
reader
(
open
(
"../commonDemo/test1.csv"
,
"r"
))
#
得到
csv
文件对象
for
csv_i
in
c
:
item
.
append
(
csv_i
)
#
将获取的数据添加到列表中
return
item
r
=
ReadCsv
()
print
(
r
.
read_csv
())
--------------------------------------------------------------------------------------
作业: