python自动化测试(3)
自动化框架及工具
1 概述
手续的关于测试的方法论,都是建立在之前的文章里面提到的观点:
后面所谈到的 测试自动化 也将围绕着 接口自动化 来介绍。
理由如下:
- 脚本语言,开发和迭代的效率极高
- 第三方的扩展库极多,有很我现成的工具可以使用
在正式进入到 自动化测试 的领域之前,先要建立这样的价值观。在Google内部工程师发布的软件测试的出版物里面提到:
“软件的自动化测试是有成本的,而且成本不低,基本上相当于在原有的 功能开发工程 的基础上再建立一个平行的 测试开发工程 ”。
也就是说,如果你对自动化测试有你的期望值,那么就肯定是要付出相应的代价和精力的。好的东西也是需要优秀的人花大量的时间去完成的。
2 PyUnit测试框架
使用 python 作为自动化编程语言,那么就自然的使用 pyunit 作为自动化测试框架了。
unittest要达到如下目标:
为了达到以上目标,unittest支持如下几个重要概念:
3 基本示例
如下示例也来自于官方文档 basic_demo.py:
# coding:utf-8
“””
基本的自动化测试脚本 basic_demo.py
“””
__author__ = ‘zheng’
import unittest
class TestStringMethods(unittest.TestCase):
def setUp(self):
print ‘init by setUp…’
def tearDown(self):
print ‘end by tearDown…’
def test_upper(self):
self.assertEqual(‘foo’.upper(), ‘FOO’)
def test_isupper(self):
self.assertTrue(‘FOO’.isupper())
self.assertFalse(‘Foo’.isupper())
self.assertTrue(‘Foo’.isupper())
def test_split(self):
s = ‘hello world’
self.assertEqual(s.split(), [‘hello’, ‘world’])
# check that s.split fails when the separator is not a string
with self.assertRaises(TypeError):
s.split(2)
if __name__ == ‘__main__’:
unittest.main()
虽然官方文档里面介绍了几种组织测试用例脚本的方式:
- 独立测试函数
- 单用例测试类
- 多用例测试类
在控制台中运行此程序:
? src git:(master) ? python basic_demo.py
init by setUp…
Fend by tearDown…
init by setUp…
end by tearDown…
.init by setUp…
end by tearDown…
.
======================================================================
FAIL: test_isupper (__main__.TestStringMethods)
———————————————————————-
Traceback (most recent call last):
File “basic_demo.py”, line 24, in test_isupper
self.assertTrue(‘Foo’.isupper())
AssertionError: False is not true
———————————————————————-
Ran 3 tests in 0.001s
FAILED (failures=1)
? src git:(master) ?
前面的基本例子的 main 函数采用的最简单的方式,直接运行所有的测试用例,并生成默认的文本 告。其实只需要对调用函数做一些简单的修改,可以将这些测试用例进行合理组织,并获取其实有用的数据信息,以便和信息系统进行集成,形成较好的扩展。
if __name__ == ‘__main__’:
# unittest.main()
# 装载测试用例
test_cases = unittest.TestLoader().loadTestsFromTestCase(TestStringMethods)
# 使用测试套件并打包测试用例
test_suit = unittest.TestSuite()
test_suit.addTests(test_cases)
# 运行测试套件,并返回测试结果
test_result = unittest.TextTestRunner(verbosity=2).run(test_suit)
#生成测试 告
print(“testsRun:%s” % test_result.testsRun)
print(“failures:%s” % len(test_result.failures))
print(“errors:%s” % len(test_result.errors))
print(“skipped:%s” % len(test_result.skipped))
运行后生成的输出为:
? src git:(master) ? python basic_demo.py
test_isupper (__main__.TestStringMethods) … init by setUp…
FAIL
end by tearDown…
test_split (__main__.TestStringMethods) … init by setUp…
end by tearDown…
ok
test_upper (__main__.TestStringMethods) … init by setUp…
end by tearDown…
ok
======================================================================
FAIL: test_isupper (__main__.TestStringMethods)
———————————————————————-
Traceback (most recent call last):
File “basic_demo.py”, line 23, in test_isupper
self.assertTrue(‘Foo’.isupper())
AssertionError: False is not true
———————————————————————-
Ran 3 tests in 0.001s
FAILED (failures=1)
testsRun:3
failures:1
errors:0
skipped:0
显然上面的输入结果已经将测试的结果进行了统计,这些数据都是一次测试活动中的重要指标,这些数据可以入库,和测试信息管理系统集成,后期生成仪表盘或者统计 表,形成稳定和产品测试线路图,这些都是和开发相关的了,在此不再多叙述了。
结合上面的具体例子,我们也可以找到上一节的理论部分对应的具体实现对象:
4 IDE工具
既然需要开发代码的生产力,那么就需要介绍一款IDE工具– Pycharm。不可否认,它是目前最专注/专业的 Python 语言的 IDE 了。在对Pyunit 也有比较好的支持。
主要支持如下:
4.1 运行和调试
Pycharm 对测试脚本提供了灵活的运行和调试支持。
通过pycharm,开发人员可以不用编写main函数,就可以实现如下功能:
其中 “运行一个测试类的某个测试脚本” 比较有用,适合在开发阶段快速地对单个脚本进行开发和运行调试。
使用方法:
- 将光标移动到测试函数内部
- 按下运行快捷键 ctrl+shift+F10 (Eclipse快捷键方案)
如果要断点调试,则使用Debug模式,即可对单个函数运行和断点调试了。
当然,也可以不必借用IDE,而通过对testSuit操作,也可以实现以上功能,但是IDE却提供了更灵活直接的选择。这只是一些IDE使用技巧,也不多述了。
4.2 结果可视化
对于前面提到的例子,如果选择在IDE中运行此程序,会看到如下效果:
?
可以看到全部运行通过。如果刻意将其中一个弄成不通过的,则会显示如下的结果:
?
4.3 生成测试 告
Pycharm也提供了测试结果 告的导出功能,在测试结果显示框上的一个功能按钮上。
?
导出结果如下:
?
当然,如果不考虑和信息系统集成,不考虑后续的仪表盘和测试统计工作,仅仅只是要生成 告,这个功能已经足够了。
一般情况下,做自动化测试和开发,上面的那些那些技能已经完全能够满足要求了,接下来要做的事情就是利用各种计算机基本知识,面对不断增加的业务需求,而不断地增加测试用例脚本了。
功能开发项目,原理都很简单,但是随着量的增加,都会形成规模,测试开发工程也是一样。
5 项目组织
之前对测试用例的 开发调试态 的工具进行了介绍。但是如果真正的要纳入到 持续集成 的自动化体系,就显然不能依赖于 IDE 了。而是使用python 语言的组织和调用方式了,比如:要有 __main__ 函数来作为执行入口,等等。
详细的技术实现细节,在后面有机会,将再会写相应的文章进行介绍。
通过脱离IDE的项目组织方式,有如下优点:
6 测试平台
关于如何自动化生成测试 告这个测试产物,现在有一些平台能够提供接口调用及 告展示和分享功能,详情参考:
?
7 小结
本小部分的内容,主要是讲基于 python 语言的 自动化测试框架 pyunit的一些设计思想和基本使用示例。其实工具的使用方法很简单,但是如何利用好这些工具来进行软件生产,则需要其它的计算机技能了,在后续的文章中将会从工程方面和技术方面来对此框架的应用进行深入的扩展。
?
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!