今天了解下测试套件Test Suite,什么是测试套件,测试套件是由多个Test Case测试用例组成的,当然也可以由多个子测试套件组成。

接下来看下如果构建测试套件,构建测试套件的方法:

1、用unittest.TestSuite()实例化测试套件对象后,内部的addTest()方法对测试类内部的测试案例进行逐一添加。

 import unittest                     #导入unittest
import time as t #导入time 设置别名 t
from selenium import webdriver #导入selenium中的webdriver class page_baidu(unittest.TestCase): #定义一个类,并继承unittest.TestCase类 @classmethod #使用 @classmethod 装饰器函数,把方法变成类方法,可以直接调用方法,不需要实例化类对象就可以调用方法
def setUp(cls):
cls.driver = webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicitly_wait(15)
cls.driver.get(r'http://www.baidu.com')
t.sleep(2)
@classmethod
def tearDown(cls):
cls.driver.quit() '''以下案例是测试百度首页链接'''
def test_baidu_001(self): #案例001 测试进入百度新闻界面
'''测试百度首新闻链接'''
self.driver.find_element_by_link_text('新闻').click() #点击百度页面,超链接【新闻】两个字
t.sleep(2) #设置强制等待2秒,就是必须等待,用导入的time中的sleep方法,不是全局性,哪里需要设置到哪里,局部的
self.driver.back()
def test_baidu_002(self): #案例002 测试进入百度地图界面
'''测试百度首地图链接'''
self.driver.find_element_by_link_text('地图').click() ##点击百度页面,超链接【地图】两个字
t.sleep(2)
self.driver.back() '''以下案例是测试百度首页搜索'''
def test_baidu_003(self):
'''测试百度首页搜索功能'''
self.driver.find_element_by_id('kw').send_keys('你好朋友')
self.driver.back()
if __name__ =='__main__':
suite =unittest.TestSuite() #对测试套件这个类进行实例化对象的操作,方便后面调用它里面的方法
suite.addTest(page_baidu('test_baidu_001')) #addTest()是TestSuite()类中的添加测试用例的方法
suite.addTest(page_baidu('test_baidu_002')) #我们用addTest()方法添加page_baidu()这个测试类中的测试案例
suite.addTest(page_baidu('test_baidu_003'))
unittest.TextTestRunner(verbosity=2).run(suite) #用TextTestResult生成测试结果,结果是根据测试套件中的案例生成

这样的方法很奇怪,如果测试类中有100个测试案例,我要这样suite.addTest(page_baidu('第N个测试点')) 去添加100个吗?这样的代码冗余是不是太多了~

所以接下来我们看第二个方法:一次性将整个测试案例类中的所有案例都添加到测试套件中

 import unittest                     #导入unittest
import time as t #导入time 设置别名 t
from selenium import webdriver #导入selenium中的webdriver class page_baidu(unittest.TestCase): #定义一个类,并继承unittest.TestCase类 @classmethod #使用 @classmethod 装饰器函数,把方法变成类方法,可以直接调用方法,不需要实例化类对象就可以调用方法
def setUp(cls):
cls.driver = webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicitly_wait(15)
cls.driver.get(r'http://www.baidu.com')
t.sleep(2)
@classmethod
def tearDown(cls):
cls.driver.quit() '''以下案例是测试百度首页链接'''
def test_baidu_001(self): #案例001 测试进入百度新闻界面
'''测试百度首新闻链接'''
self.driver.find_element_by_link_text('新闻').click() #点击百度页面,超链接【新闻】两个字
t.sleep(2) #设置强制等待2秒,就是必须等待,用导入的time中的sleep方法,不是全局性,哪里需要设置到哪里,局部的
self.driver.back()
def test_baidu_002(self): #案例002 测试进入百度地图界面
'''测试百度首地图链接'''
self.driver.find_element_by_link_text('地图').click() ##点击百度页面,超链接【地图】两个字
t.sleep(2)
self.driver.back() '''以下案例是测试百度首页搜索'''
def test_baidu_003(self):
'''测试百度首页搜索功能'''
self.driver.find_element_by_id('kw').send_keys('你好朋友')
self.driver.back()
if __name__ =='__main__':
suite =unittest.TestSuite() #对测试套件这个类进行实例化对象的操作,方便后面调用它里面的方法
suite.addTest(page_baidu()) #addTest()是TestSuite()类中的添加测试用例的方法,用addTest()方法添加page_baidu()这个测试类中的所有测试案例
unittest.TextTestRunner(verbosity=2).run(suite) #用TextTestResult生成测试结果,结果是根据测试套件中的案例生成

一般在将测试类中的所有测试案例放入套件中用makeSuite()方法,他是unittest中的方法。

makeSuite():一次性将整个,测试类文件下所有测试用例到suite中去。代码:注意!!makeSuite()  这个方法括号中的参数是一个类哦!!!

 import unittest                     #导入unittest
import time as t #导入time 设置别名 t
from selenium import webdriver #导入selenium中的webdriver class page_baidu(unittest.TestCase): #定义一个类,并继承unittest.TestCase类 @classmethod #使用 @classmethod 装饰器函数,把方法变成类方法,可以直接调用方法,不需要实例化类对象就可以调用方法
def setUp(cls):
cls.driver = webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicitly_wait(15)
cls.driver.get(r'http://www.baidu.com')
t.sleep(2)
@classmethod
def tearDown(cls):
cls.driver.quit() '''以下案例是测试百度首页链接'''
def test_baidu_001(self): #案例001 测试进入百度新闻界面
'''测试百度首新闻链接'''
self.driver.find_element_by_link_text('新闻').click() #点击百度页面,超链接【新闻】两个字
t.sleep(2) #设置强制等待2秒,就是必须等待,用导入的time中的sleep方法,不是全局性,哪里需要设置到哪里,局部的
self.driver.back()
def test_baidu_002(self): #案例002 测试进入百度地图界面
'''测试百度首地图链接'''
self.driver.find_element_by_link_text('地图').click() ##点击百度页面,超链接【地图】两个字
t.sleep(2)
self.driver.back() '''以下案例是测试百度首页搜索'''
def test_baidu_003(self):
'''测试百度首页搜索功能'''
self.driver.find_element_by_id('kw').send_keys('你好朋友')
self.driver.back()
if __name__ =='__main__':
# suite =unittest.TestSuite() #对测试套件这个类进行实例化对象的操作,方便后面调用它里面的方法
# suite.unittest.makeSuite(page_baidu) #一次性将整个,测试类文件下所有测试用例到suite中去。
suite = unittest.TestSuite(unittest.makeSuite(page_baidu)) #将上面的两行代码合并成一行来写
unittest.TextTestRunner(verbosity=2).run(suite) #用TextTestResult生成测试结果,结果是根据测试套件中的案例生成

我们再看看TestLoader()这个类中提供的几种创建测试套件(test Suite)的方法:

1、TestLoader().loadTestsFromTestCase(testCaseClass)   :该方法是可以将类中的案例都加载到测试套件中,括号中的参数是类

 import unittest                     #导入unittest
import time as t #导入time 设置别名 t
from selenium import webdriver #导入selenium中的webdriver class page_baidu(unittest.TestCase): #定义一个类,并继承unittest.TestCase类 @classmethod #使用 @classmethod 装饰器函数,把方法变成类方法,可以直接调用方法,不需要实例化类对象就可以调用方法
def setUp(cls):
cls.driver = webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicitly_wait(15)
cls.driver.get(r'http://www.baidu.com')
t.sleep(2)
@classmethod
def tearDown(cls):
cls.driver.quit() '''以下案例是测试百度首页链接'''
def test_baidu_001(self): #案例001 测试进入百度新闻界面
'''测试百度首新闻链接'''
self.driver.find_element_by_link_text('新闻').click() #点击百度页面,超链接【新闻】两个字
t.sleep(2) #设置强制等待2秒,就是必须等待,用导入的time中的sleep方法,不是全局性,哪里需要设置到哪里,局部的
self.driver.back()
def test_baidu_002(self): #案例002 测试进入百度地图界面
'''测试百度首地图链接'''
self.driver.find_element_by_link_text('地图').click() ##点击百度页面,超链接【地图】两个字
t.sleep(2)
self.driver.back()
if __name__ =='__main__':
suite = unittest.TestLoader().loadTestsFromTestCase(page_baidu) #TestLoader()这个类提供了loadTestsFromTestCase()方法,参数是类或者子类。
unittest.TextTestRunner(verbosity=2).run(suite) #用TextTestResult生成测试结果,结果是根据测试套件中的案例生成

2、TestLoader().loadTestsFromModule(module, pattern=None)   :该方法是加载一个模块文件中的所有测试类,一个  .py文件就是一个模块哦,前面笔记有详细说过。

我们看下,下面的笔记,笔记中的.py文件的名字是:bokeyuan--unitagin.py     此模块下面有两个测试类,第一个类是:page_baidu_lianjie

第二个类是:page_baidu_sousuo     所以加载的是这个模块下面的两个类中的所有测试案例方法。记住,括号中的参数是.py文件名,另外记得带英文引号!!!

看代码:

 import unittest                     #导入unittest
import time as t #导入time 设置别名 t
from selenium import webdriver #导入selenium中的webdriver class page_baidu_lianjie(unittest.TestCase): #定义一个类,并继承unittest.TestCase类
'''这个类中的方法是测试百度首页链接'''
@classmethod #使用 @classmethod 装饰器函数,把方法变成类方法,可以直接调用方法,不需要实例化类对象就可以调用方法
def setUp(cls):
cls.driver = webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicitly_wait(15)
cls.driver.get(r'http://www.baidu.com')
t.sleep(2)
@classmethod
def tearDown(cls):
cls.driver.quit() '''以下案例是测试百度首页链接'''
def test_baidu_001(self): #案例001 测试进入百度新闻界面
'''测试百度首新闻链接'''
self.driver.find_element_by_link_text('新闻').click() #点击百度页面,超链接【新闻】两个字
t.sleep(2) #设置强制等待2秒,就是必须等待,用导入的time中的sleep方法,不是全局性,哪里需要设置到哪里,局部的
self.driver.back()
def test_baidu_002(self): #案例002 测试进入百度地图界面
'''测试百度首地图链接'''
self.driver.find_element_by_link_text('地图').click() ##点击百度页面,超链接【地图】两个字
t.sleep(2)
self.driver.back() class page_baidu_sousuo(unittest.TestCase): #定义一个类,并继承unittest.TestCase类
'''这个类中的方法是测试百度首页搜索功能'''
@classmethod #使用 @classmethod 装饰器函数,把方法变成类方法,可以直接调用方法,类本身就不在需要实例化类对象就可以调用此方法
def setUp(cls):
cls.driver = webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicitly_wait(15)
cls.driver.get(r'http://www.baidu.com')
t.sleep(2)
@classmethod
def tearDown(cls):
cls.driver.quit() '''以下案例是测试百度首页搜索功能'''
def test_baidu_003(self):
'''测试百度首页搜索功能'''
self.driver.find_element_by_id('kw').send_keys('你好朋友') if __name__ =='__main__':
suite = unittest.TestLoader().loadTestsFromModule('bokeyuan--unitagin.py') #TestLoader()类中的loadTestsFromModule方法,提供加载模块中的所有测试类,括号中的参数是模块文件名称
unittest.TextTestRunner(verbosity=2).run(suite) #用TextTestResult生成测试结果,结果是根据测试套件中的案例生成

代码越来越长,所以截图是截取重要部分~~~

接下来我们优化之前的代码,将测试套件这部分代码,封装成方法:

 import unittest                     #导入unittest
import time as t #导入time 设置别名 t
from selenium import webdriver #导入selenium中的webdriver
class page_baidu_sousuo(unittest.TestCase): #定义一个类,并继承unittest.TestCase类
'''这个类中的方法是测试百度首页搜索功能'''
@classmethod #使用 @classmethod 装饰器函数,把方法变成类方法,可以直接调用方法,类本身就不在需要实例化类对象就可以调用此方法
def setUp(cls):
cls.driver = webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicitly_wait(15)
cls.driver.get(r'http://www.baidu.com')
t.sleep(2)
@classmethod
def tearDown(cls):
cls.driver.quit() '''以下案例是测试百度首页搜索功能'''
def test_baidu_003(self):
'''测试百度首页搜索功能'''
self.driver.find_element_by_id('kw').send_keys('你好朋友') @staticmethod #静态方法分离测试套件,不需要表示自身对象的self和自身类的cls参数,就跟使用函数一样。类.方法().看最后的代码调用:page_baidu_lianjie.suite()
def suite():
suite = unittest.TestSuite(unittest.makeSuite(page_baidu_sousuo)) #将测试套件单独分离出,封装成方法,直接调用,以后就不用再每次都写
return suite #将测试套件返回,如果不写return返回,那么将不会将内容返回给调用方下面的run() if __name__ =='__main__':
unittest.TextTestRunner(verbosity=2).run(page_baidu_sousuo.suite()) #run()接收封装的suite()方法的返回参数,进行测试套件的执行载入,然后生成报告
总结:
1、TestSuite类中的addTest()方法来载入单体案例
2、TestSuite类中的addTest()方法来载入类中的整个案例,就是直接写测试类的类名
3、TestSuite类中的makeSuite()方法,一次性将整个,测试类文件下所有测试用例到suite中去。代码:注意!!makeSuite()  这个方法括号中的参数是一个类哦!!!
4、利用unittest中的TestLoader()类的loadTestsFromTestCase(testCaseClass)方法   :该方法是可以将类中的案例都加载到测试套件中,括号中的参数是类名
5、利用unittest中的TestLoader()类的loadTestsFromModule(module, pattern=None)方法 :该方法是加载一个模块文件中的所有测试类,一个 .py文件就是一个模块哦
6、测试套件可以单独分离出去,利用静态函数,将它封装成一个方法,可以直接类.函数()的调用方式,不需要实例化参数,因为有装饰器函数@staticmethod
重点,重点!!!----》要使用某个类的方法,需要先实例化一个对象再调用方法。
而使用@staticmethod或@classmethod,就可以不需要实例化,直接类名.方法名()来调用。
下面是两个装饰器函数的区别:
@staticmethod不需要表示自身对象的self和自身类的cls参数,就跟使用函数一样。
@classmethod也不需要self参数,但第一个参数需要是表示自身类的cls参数。

接下来的笔记就是测试固件的分离以及后续的断言~~~

-----来自新手的笔记,希望能帮助大初学者,如果有错误的笔记,希望大家给予帮助!尽量把代码的注释写精准,方便后续学习,也方便其他初学者参考~~谢谢各位!

python+unittest框架第二天unittest之简单认识Test Suite:测试套件的更多相关文章

  1. python+unittest框架第一天unittest之简单认识Test Fixure:测试固件【8月17更新】

    20万的慢慢会实现的吧,hhh unittest框架,我就不在介绍了,百度有很详细的介绍. 我们只要了解: 1.unittest是单元测试框架 2.它提供用例组织与执行:在实际工作中案例可能有上百条, ...

  2. Python+Selenium框架 ---一个类文件多个测试方法情况下测试固件的写法

    我们测试中,肯定需要,打开一个页面,然后测试这个页面的多个用例,才关闭这个页面,去测试其他页面,在unittest是有相关测试固件方法去支持这种行为.请看下面 # coding=utf-8 impor ...

  3. python3的unittest中使用test suite(测试套件)执行指定测试用例

    示例代码 module.py class baidumodule(): def __init__(self,driver,): self.dr = driver #不能在类中再次导入webdriver ...

  4. selenium自动化测试、Python单元测试unittest框架以及测试报告和日志输出

    部分内容来自:https://www.cnblogs.com/klb561/p/8858122.html 一.基础介绍 核心概念:test case, testsuite, TestLoder,Tex ...

  5. python unittest框架理解与总结(二)

    unittest基本原理: ♦整个平台的搭建使用的是python的unittest测试框架,这里简单介绍下unittest模块的简单应用. ♦unittest是python的标准测试库,相比于其他测试 ...

  6. Python单元测试框架unittest重要属性 与 用例编写思路

    前言 本文为转载,原文地址作者列举python unittest这个测试框架的主要属性和 测试用例思路 unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行, ...

  7. Selenium with Python 010 - unittest 框架(又称PyUnit 框架)

    unittest进行python代码单元测试 calculator.py--被测试类 #!/usr/bin/env python # -*- coding: utf-8 -*- # 将要被测试的类 c ...

  8. python接口自动化测试 - unittest框架suite、runner详细使用

    test suite 测试套件,理解成测试用例集 一系列的测试用例,或测试套件,理解成测试用例的集合和测试套件的集合 当运行测试套件时,则运行里面添加的所有测试用例 test runner 测试运行器 ...

  9. unittest框架概要

    unittest是Python语言自带的单元测试框架,原名PyUnit. 认识unittest 在unittest框架中有4个重要概念:test fixture.test case.test suit ...

随机推荐

  1. Jenkins+Sonar搭建持续集成和代码质量检查环境

    Jenkins+Sonar搭建 一.相关环境及下载地址 系统:Ubuntu JDK:1.8 MySQL:5.7 软件包: jenkins_2.121.3_all.deb sonarqube-7.3.z ...

  2. 个人永久性免费-Excel催化剂功能第70波-工作薄外部链接维护管理

    Excel在数据领域万物互联的特性,其中一个使用场景是连接非本工作薄的外部性文件内容,如其他Excel工作薄文件里的内容或直接用OLE对象的方式嵌入一个文件链接,使其在不离开Excel环境,也可提供类 ...

  3. 个人永久性免费-Excel催化剂功能第68波-父子结构表转换之父子关系BOM表拆分篇

    Excel中制造业行业中,有一个非常刚需的需求是对BOM(成品物料清单)的拆解,一般系统导出的BOM表,是经过压缩处理的,由父子表结构的方式存储数据.对某些有能力使用SAP等专业ERP软件的工厂来说, ...

  4. windows和linux下如何对拍

    对拍是各种计算机考试检查时必备工具,实际上十分强大,只要你的暴力没有写错就没有问题. 对拍的意思:(怎么有点语文课的意思雾) 对:看见'对'就可以知道有两个. 拍:就是把两个程序结果拍在一起,对照(有 ...

  5. [PXE] Linux(centos6)中PXE 服务器搭建,PXE安装、启动及PXE理论详解

    [PXE] Linux(centos6)中PXE 服务器搭建,PXE安装.启动及PXE理论详解 本篇blog主要讲述了[PXE] linux(centos)PXE无盘服务器搭建,安装,启动及pxe协议 ...

  6. 使用redis分布式锁解决并发线程资源共享问题

    众所周知, 在多线程中,因为共享全局变量,会导致资源修改结果不一致,所以需要加锁来解决这个问题,保证同一时间只有一个线程对资源进行操作 但是在分布式架构中,我们的服务可能会有n个实例,但线程锁只对同一 ...

  7. 实现一个Golang的reverse函数

    Reverse函数,用来反转列表,本例子用golang实现,反转一个slice列表. 因为slice是引用类型,因此直接修改参数的值即可. func myReverse(l []string) { f ...

  8. 滚动视图、列表视图[ListView、SimpleAdapter类]

    滚动视图 <ScrollView android: layout_width="fill_parent" android: layout_height="fill_ ...

  9. bean的创建(五)第二部分 寻找bean的工厂方法实例化

    instanceWrapper = createBeanInstance(beanName, mbd, args); AbstractAutowireCapableBeanFactory.create ...

  10. handlerAdapter与方法返回值的处理

    前提:处理器方法被调用并返回了结果 public void invokeAndHandle(ServletWebRequest webRequest, ModelAndViewContainer ma ...