zoukankan      html  css  js  c++  java
  • python接口自动化测试(七)-unittest-批量用例管理

      我们日常项目中的接口测试案例肯定不止一个,当案例越来越多时我们如何管理这些批量案例?如何保证案例不重复?如果案例非常多(成百上千,甚至更多)时如何保证案例执行的效率?如何做(批量)测试数据的管理?如何做到数据与脚本分离?

      以上这些问题才是我们自动化测试中要重点考虑的问题,单个用例其实并不难。

    来看一下在unittest框架中如何管理批量案例:

    一、手工加载批量用例:

    # -*- coding:utf-8 -*-
    # 批量用例执行--手工加载
    
    import unittest
    
    class TestOne(unittest.TestCase):
        def setUp(self):
            print '
    cases before'
            pass
    
        def test_add(self):
            '''test add method'''
            print 'add...'
            a = 3 + 4
            b = 7
            self.assertEqual(a, b)
    
        def test_sub(self):
            '''test sub method'''
            print 'sub...'
            a = 10 - 5
            b = 5
            self.assertEqual(a, b)
    
        def tearDown(self):
            print 'case after'
            pass
    
    if __name__ == '__main__':
        # 1、构造用例集
        suite = unittest.TestSuite()
    
        # 2、执行顺序是安加载顺序:先执行test_sub,再执行test_add
        suite.addTest(TestOne("test_sub"))
        suite.addTest(TestOne("test_add"))
    
        # 3、实例化runner类
        runner = unittest.TextTestRunner()
    # 4、执行测试 runner.run(suite)

    二、自动加载批量用例:

    # -*- coding:utf-8 -*-
    # 批量用例执行--自动加载
    import unittest
    import os
    
    class TestOne(unittest.TestCase):
        def setUp(self):
            print '
    cases before'
            pass
    
        def test_add(self):
            '''test add method'''
            print 'add...'
            a = 3 + 4
            b = 7
            self.assertEqual(a, b)
    
        def test_sub(self):
            '''test sub method'''
            print 'sub...'
            a = 10 - 5
            b = 5
            self.assertEqual(a, b)
    
        def tearDown(self):
            print 'case after'
            pass
    
    if __name__ == '__main__':
        # 1、设置待执行用例的目录
        test_dir = os.path.join(os.getcwd())
    
        # 2、自动搜索指定目录下的cas,构造测试集,执行顺序是命名顺序:先执行test_add,再执行test_sub
        discover = unittest.defaultTestLoader.discover(test_dir, pattern='test_*.py')
    
        # 实例化TextTestRunner类
        runner = unittest.TextTestRunner()
    
        # 使用run()方法运行测试套件(即运行测试套件中的所有用例)
        runner.run(discover)

    以上只是解决了如何管理批量案例的问题,其它的问题如何做(批量)测试数据的管理?如何做到数据与脚本分离?后续在介绍。

  • 相关阅读:
    表格行内编辑增删改查
    rpc远程调用开发
    gdb调试程序
    Makefile文件编写
    CentOS6.6源码编译升级GCC至4.8.2
    linux 下C语言编程库文件处理与Makefile编写
    laravel队列-让守护进程处理耗时任务
    回顾javase点滴
    服务端生成word并压缩打包下载
    pytest框架插件(用例依赖、多重校验、执行顺序、失败重跑、重复执行、标记)
  • 原文地址:https://www.cnblogs.com/puresoul/p/7490737.html
Copyright © 2011-2022 走看看