unittest

作者: shirely大丫头 | 来源:发表于2018-06-10 19:42 被阅读0次

    1.一个测试类来完成对整个软件模块的,测试;

    Test fixture=setup+TestCase+tearDown

    写在前面:

    setup()---数据初始化,用于测试前数据准备,测试程序会在执行每条测试项前先调用此方法:

    处理方式:1.添加测试前需要设置参数 2.写pass 3.删除

    teardown()-释放数据,清理数据,在全部测试项执行完毕后,例如关闭数据库,关闭浏览器;

    处理方式:1.测试后清除数据 2.写pass 3.删除

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

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

    1.unittest.Testcase 建立需要测试的若干单元测试用例,即若干个执行函数;class BaiduTest(unittest,TestCase)

    2.unittest.Testsuite--Testsuite类用来创建测试套件,用最多的函数是addTest(),

    addTest(self,test)将测试用例添加到测试套件;

    运行方式说明:

    一.直接运行测试用例

    运行方式:if  _name_=="_main_":

                       unittest.main()

    ==unittest.main()方法会搜索该模块下所有以test开头的测试用例方法,并自动执行它;

    ==执行顺序是命名顺序:先执行test_case1,在执行test_case2

    二.将测试用例聚合成测试套件运行

          1.执行顺序是按照加载顺序:先执行test_case2,再执行test_case1

      suite.addTest(Test('test_case2'))

      suite.addTest(Test('test_case1'))

      2.执行测试用例

          3.实例化TextTestRunner类

      runner=unittest.TextTestRunner()

      4.使用run()方法运行测试套件(即运行测试套件中的所有用例)

      runner.run(suite)

    三.构造测试集(简化了第二种中要先创建测试套件然后在依次加载测试用例)

     #执行顺序同方案一:执行顺序是命名顺序:先执行test_case1,再执行test_case2

      test_dir = './'

      discover = unittest.defaultTestLoader.discover(test_dir, pattern='test_*.py')

      #8.3.2执行测试用例

      #8.3.2.1实例化TextTestRunner类

      runner=unittest.TextTestRunner()

      #8.3.2.2使用run()方法运行测试套件(即运行测试套件中的所有用例)

      runner.run(discover)

    四.嵌套测试套件

    运行方式:testsuite1=unittest.makeSuite()

    testsuite.addTest(test_smoke_test,"Time")

    testsuite.addTest(test_smoke_test,"PIN")

    testsuite=unittest.TestSuite(testsuite1,testsuite2)

    ==执行顺序:按unittest.TestSuite(testsuite1,testsuite2)中添加顺序

    使unittest框架编写测试用例实例

    # coding=utf-8

    import unittest

    import HTMLTestRunner

    class Test(unittest.TestCase):

    def setUp(self):

    #self.number = raw_input('Enter a number:')

    #self.number = int(self.number)

            self.number =20

        # 6.定义测试用例,以“test_”开头命名的方法

    # 注意,方法的入参为self

    # 可使用unittest.TestCase类下面的各种断言方法用于对测试结果的判断

    # 可定义多个测试用例

        def test_case1(self):

    print self.number

    self.assertEqual(self.number,10,msg='Your input is not 10')

    def test_case2(self):

    print self.number

    self.assertEqual(self.number,20,msg='Your input is not 20')

    @unittest.skip('暂时跳过用例3的测试')

    def test_case3(self):

    print self.number

    self.assertEqual(self.number,30,msg='Your input is not 30')

    def tearDown(self):

    print ('2')

    print ('Test over')

    if __name__ =='__main__':

    suite=unittest.TestSuite()

    suite.addTest(Test('test_case2'))

    suite.addTest(Test('test_case1'))

    filename='E:\\testresult.html'

        with open(filename,'wb')as fp:

    runner =HTMLTestRunner.HTMLTestRunner(stream=fp,title=u'测试报告',description=u'用例执行详情:')

    runner.run(suite)

    六.生成测试报告

    要用HTMLTestRunner要先下载安装

    下载地址:http://www.51testing.com/html/12/n-3715212.html

    下载完放在C:\Python27\Lib该目录。重命名为HTMLTestRunner.py文件

    接下来需要找到python的ide,敲入“import HTMLTestRunner”,没报错就代表我们导入HTMLTestRunner模块成功。如下图

    filename='E:\\testresult.html'

        with open(filename,'wb')as fp:

    runner =HTMLTestRunner.HTMLTestRunner(stream=fp,title=u'测试报告',description=u'用例执行详情:')

    runner.run(suite)

    小白避坑:

    1.代码写的没问题,执行也成功了,但就是无法生成HTMLTestRunner的报告

    原因:

    图一:执行的只是用例或者套件,而不是整个文件,写在main里的代码是不会被执行的!!自然无法生成测试报告。

    图二:中的菜单是正常情况下编辑器的右键菜单,这种情况下编辑器是执行这个文件,文件中所有的代码都会被执行到。

    一般情况下在用例的部分点击右键会出来图一菜单,在其他部分如main里点击右键会出来图二,不过也不一定,自己点点看吧。

    现在很清晰了,我们在如果想要生成测试报告,那么一定要注意右键执行时选择的右键菜单,一定要当做文件执行,不要让编辑器当做用例执行。

    然而:我点用例中的任何地方都只出现图一,并没有出现图二的情况,百度解决办法:

    生成的测试报告若有其他问题可以参考:

    https://www.cnblogs.com/8013-cmf/p/6644366.html

    https://blog.csdn.net/xie_0723/article/details/50825310

    ==暂时没有遇到其他问题;

    报告详情

    参考文档:http://www.51testing.com/html/31/n-3723931.html

    待解决问题:

    已解决,需要输入一个数字

    代码死循环,无法执行下去

    相关文章

      网友评论

          本文标题:unittest

          本文链接:https://www.haomeiwen.com/subject/ldhqeftx.html