unittest框架的使用

了解

unittest 是python 的单元测试框架,unittest 单元测试提供了创建测试用例,测试套件以及批量执行的方案,unittest 在pyhton中自带了,直接import unittest使用
作为单元测试的框架, unittest 也是可以对程序最小模块的一种敏捷化的测试。在自动化测试中,虽然不需要做白盒测试,但是必须需要知道所使用语言的单元测试框架。利用单元测试框架,创建一个类,该类继承unittest的TestCase,这样可以把每个case看成是一个最小的单元, 由测试容器组织起来,到时候直接执行,同时引入测试报告

  • test fixture:初始化和清理测试环境,比如创建临时的数据库,文件和目录等
    下面的setUp(self),def tearDown(self)就是测试固件,每个类中都应该包含这两函数
  • test case:单元测试用例,TestCase 是编写单元测试用例最常用的类
    在使用类时必须继承自这个类如:chaxun(unittest.TestCase)
  • test suite:单元测试用例的集合,TestSuite 是最常用的类
    测试方法组合在一起就形成测试套件
  • test runner:执行单元测试
    批量执行套件、不同于生成测试报告的runner
  • test report:生成测试报告【可以省略】
import unittest
from selenium import webdriver
import time
class Baidu(unittest.TestCase):
    def setUp(self):
        self.driver=webdriver.Chrome()
        self.driver.implicitly_wait(5)
        self.base_url="http://www.baidu.com"
        self.driver.maximize_window()
        self.verificationErrors=[]
        self.accept_next_alert=True
    def tearDown(self):
        self.driver.quit()


    def test_hao(self):
        driver=self.driver
        driver.get(self.base_url)
        driver.find_element_by_link_text(u"hao123").click()
        time.sleep(4)
        self.assertEqual(u"hao_上网从这里开始",driver.title,msg="not equal!!!")
        time.sleep(4)

    def test_yu(self):
        driver = self.driver
        driver.get(self.base_url)
        driver.find_element_by_id("kw").send_keys(u"喻言")
        driver.find_element_by_id("su").click()
        time.sleep(2)

    def test_bai(self):
        driver = self.driver
        driver.get(self.base_url)
        driver.find_element_by_id("kw").send_keys(u"白敬亭")
        driver.find_element_by_id("su").click()
        time.sleep(5)


if __name__=="__main__":
    unittest.main(verbosity=2)

编写测试用例必须以test_开头进行命名,执行时会主动执行这些测试用例,但类中定义的方法不会主动执行。类中函数的执行顺序以ASCII码进行排序:0-9、A-Z、a-z

在main中加入verbosity=2 ,这样测试的结果就会显示的更加详细。
这里的verbosity 是一个选项, 表示测试结果的信息复杂度,有三个值:
0 ( 静默模式): 你只能获得总的测试用例数和总的结果比如总共100个失败,20 成功80
1 ( 默认模式): 非常类似静默模式只是在每个成功的用例前面有个“ . ” 每个失败的用例前面有个“F”
2 ( 详细模式): 测试结果会显示每个测试用例的所有相关的信息

批量执行脚本

完整的单元测试很少只执行一个测试用例,开发人员通常都需要编写多个测试用例才能对某一软件功能进行比较完整的测试,这些相关的测试用例称为一个测试用例集,在unittest中是用TestSuite 类来表示的

addTest

这里运行顺序按加入的顺序依次运行

makesuit

TestLoader

makesuite先生成套件再一个一个加,testloader先导入再加到测试套件中

discover
discover 是通过递归的方式到其子目录中从指定的目录开始, 找到所有测试模块并返回一个包含它们对象的TestSuite ,然后进行加载与模式匹配唯一的测试文件,discover参数分别是:discover(dir,pattern,top_level_dir=None)

找到的文件
<unittest.suite.TestSuite tests=
[<unittest.suite.TestSuite tests=[<unittest.suite.TestSuite tests=
[<baidu425.find testMethod=test_bai>, <baidu425.find testMethod=test_yu>]
]>,
<unittest.suite.TestSuite tests=
[<unittest.suite.TestSuite tests=
[<for425.find testMethod=test_Jian>, <for425.find testMethod=test_iu>,<for425.find testMethod=test_zhong>]>]>,
<unittest.suite.TestSuite tests=[]>]>

忽略用例执行

@unittest.skip(u’The function was canceled, neglects to perform thecase’)

控制台:
在这里插入图片描述

断言

自动化的测试中, 对于每个单独的case来说,一个case的执行结果中, 必然会有期望结果与实际结果, 来判断该case是通过还是失败, 在unittest 的库中提供了大量的实用方法来检查预期值与实际值, 来验证case的结果, 一般来说, 检查条件大体分为等价性, 逻辑比较以及其他, 如果给定的断言通过, 测试会继续执行到下一行的代码, 如果断言失败, 对应的case测试会立即停止或者生成错误信息( 一般打印错误信息即可) ,但是不要影响其他的case执行

断言描述
assertEqual(arg1, arg2, msg=None)验证arg1=arg2,不等则fail
assertNotEqual(arg1, arg2, msg=None)验证arg1 != arg2, 相等则fail
assertTrue(expr, msg=None)验证expr是true,如果为false,则fail
assertFalse(expr,msg=None)验证expr是false,如果为true,则fail
HTML报告生成
   curpath=sys.path[0]
    if not os.path.exists(curpath+'resultreport'):
        os.makedirs(curpath+'/resultreport')
    now=time.strftime("%Y-%m-%d-%H %M %S",time.localtime(time.time()))
    filename=curpath+'/resultreport/'+now+'resultreport.html'
    with open(filename,'wb') as fp:
        runner=HTMLTestRunner.HTMLTestRunner(stream=fp,title=u"测试报告",description=u"测试用例",verbosity=2)
        suite=createsuit()
        runner.run(suite)
异常捕捉与错误截图

用例不可能每一次运行都成功,肯定运行时候有不成功的时候。如果可以捕捉到错误,并且把错误截图保存,会给我们错误定位带来方便

def test_hao(self):
	driver=self.driver
	driver.get(self.base_url)
	driver.find_element_by_link_text("hao123").click()
	try:
		self.assertEqual(u"hao_上网从这里开始",driver.title)
	except:
		self.savescreenshot(driver,"hao.png")


 def savescreenshot(self,driver,file_name):
	 if not os.path.exists('./image'):
		 os.makedirs('./image')
	 now=time.strftime("%Y%m%d-%H%M%S",time.localtime(time.time()))
 		#截图保存
 	 driver.get_screenshot_as_file('./image/'+now+'-'+file_name)
 	 time.sleep(1)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值