咱們平常項目中的接口測試案例確定不止一個,當案例愈來愈多時咱們如何管理這些批量案例?如何保證案例不重複?若是案例很是多(成百上千,甚至更多)時如何保證案例執行的效率?如何作(批量)測試數據的管理?如何作到數據與腳本分離?框架
以上這些問題纔是咱們自動化測試中要重點考慮的問題,單個用例其實並不難。測試
來看一下在unittest框架中如何管理批量案例:ui
1、手工加載批量用例:spa
# -*- coding:utf-8 -*- # 批量用例執行--手工加載 import unittest class TestOne(unittest.TestCase): def setUp(self): print '\ncases 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__': # 一、構造用例集 suite = unittest.TestSuite() # 二、執行順序是安加載順序:先執行test_sub,再執行test_add suite.addTest(TestOne("test_sub")) suite.addTest(TestOne("test_add")) # 三、實例化runner類 runner = unittest.TextTestRunner()
# 四、執行測試 runner.run(suite)
2、自動加載批量用例:code
# -*- coding:utf-8 -*- # 批量用例執行--自動加載 import unittest import os class TestOne(unittest.TestCase): def setUp(self): print '\ncases 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__': # 一、設置待執行用例的目錄 test_dir = os.path.join(os.getcwd()) # 二、自動搜索指定目錄下的cas,構造測試集,執行順序是命名順序:先執行test_add,再執行test_sub discover = unittest.defaultTestLoader.discover(test_dir, pattern='test_*.py') # 實例化TextTestRunner類 runner = unittest.TextTestRunner() # 使用run()方法運行測試套件(即運行測試套件中的全部用例) runner.run(discover)
以上只是解決了如何管理批量案例的問題,其它的問題如何作(批量)測試數據的管理?如何作到數據與腳本分離?後續在介紹。blog