Python+Selenium笔记(四):unittest的Test Suite(测试套件)

(一) Test Suite测试套件

一个测试套件是多个测试或测试用例的集合,是针对被测程序的对应的功能和模块创建的一组测试,一个测试套件内的测试用例将一起执行。

应用unittest的TestSuites特性,可以将不同的测试组成一个逻辑组,然后设置统一的测试套件,并通过一个命令来执行测试。这都是通过TestSuites、TestLoader和TestRunn类来实现的。

(二) 类级别的setUp()方法和tearDown()方法

使用setUpClass()方法和tearDownClass()方法及@classmethod标识来实现各个测试方法共享初始化数据。具体看下面的代码。

(三) searchtest.py

import unittest

from selenium import webdriver

from selenium.webdriver.common.action_chains import ActionChainsimport time

class SearchTest(unittest.TestCase):
    ‘‘‘通过setUpClass()和@classmethod标识,实现
     在类级别初始化数据,所有测试方法共享这些初始化数据.
     不使用这个的话,每个测试方法都会单独创建一个实例‘‘‘
    @classmethod
    def setUpClass(cls):
        cls.driver = webdriver.Firefox()
        cls.driver.implicitly_wait(10)
        cls.driver.maximize_window()
        cls.driver.get("https://www.cnblogs.com/")
    def test_search_by_category(self):
        #读取category.txt文件,返回一个字典
        with open(‘data/category.txt‘, encoding=‘UTF-8‘) as category_file:
            category_dict = dict()
            category_data = category_file.readline().strip().split(‘,‘)
            the_class = category_data.pop(0)
            category_dict[the_class] = category_data
        #定位首页网站分类中的编程语言
        self.search_class = self.driver.find_element_by_xpath(‘//li/a[@href="/cate/2/"]‘)
        #光标悬停在“编程语言”上
        ActionChains(self.driver).move_to_element(self.search_class).perform()
        # 以列表形式返回编程语言下的所有小类
        self.search_small = self.driver.find_elements_by_xpath(
            ‘//div[@id="cate_content_block_2"]/div[@class="cate_content_block"]/ul/li‘)
        #休眠3秒
        time.sleep(3)
        small_cate = []
        for s in self.search_small:
            #去掉小类最后面的(0),并添加到列表small_cate中
            small = str(s.text).split(‘(‘)
            small_cate.append(small[0])
        #检查表达式是否为true(此处检查编程语言下的小类是否与预期结果一致)
        self.assertTrue(small_cate == category_dict["编程语言"])
        # self.assertEqual(small_cate,category_dict["编程语言"])
    def test_search_by_look(self):
        self.seach_class = self.driver.find_element_by_xpath(‘//li/a[@href="/cate/2/"]‘)
        #定位编程语言下的小类Python
        self.seach_small =self.driver.find_element_by_xpath(‘//li/a[@href="/cate/python/"]‘)
        ActionChains(self.driver).move_to_element(self.seach_class).perform()
        self.seach_small.click()
        #检查打开的网页标题是不是 Python - 网站分类 - 博客园
        # assert "Python - 网站分类 - 博客园" in self.driver.title
        self.assertEqual(self.driver.title,"Python - 网站分类 - 博客园" )
    ‘‘‘通过tearDownClass()和@classmethod标识,实现
     在类级别初始化数据,所有测试方法共享这些初始化数据‘‘‘
    @classmethod
    def tearDownClass(cls):
        cls.driver.quit()
#加上下面2句,可以通过命令行运行测试,不加的话不影响通过IDE运行测试
if __name__ == ‘__main__‘:
    #加verbosity=2参数,在命令行中显示具体的测试方法
    unittest.main(verbosity=2)
(四) homepagetest.py
import  unittest
from selenium import  webdriver
from selenium.common.exceptions import NoSuchElementException
from selenium.webdriver.common.by import By
class HomePageTest(unittest.TestCase):
    ‘‘‘通过setUpClass()和@classmethod标识,实现
     在类级别初始化数据,所有测试方法共享这些初始化数据.
     不使用这个的话,每个测试方法都会单独创建一个实例‘‘‘
    @classmethod
    def setUpClass(cls):
        cls.driver = webdriver.Firefox()
        cls.driver.implicitly_wait(10)
        cls.driver.maximize_window()
        cls.driver.get("https://www.cnblogs.com/")
    def test_search_field(self):
        #通过by,检查博客园首页有没有搜索框,is_element_present()是自定义的方法
        self.assertTrue(self.is_element_present(By.ID,"zzk_q"))
    def test_search_btn(self):
        # 通过by,检查博客园首页有没有找找看按钮
        self.assertTrue(self.is_element_present(By.CLASS_NAME,"search_btn"))
    def test_menu(self):
        #该方法检查博客园首页菜单栏信息是否与预期一致
        #读取menu.txt文件数据
        with open(‘data/menu.txt‘,encoding=‘UTF-8‘) as menu_file:
            menu_data = menu_file.readline().strip().split(‘,‘)
        #以列表形式返回博客园首页菜单栏信息
        self.check_menu = self.driver.find_elements_by_xpath(‘//div[@id="nav_menu"]/a‘)
        the_menu = []
        for c in self.check_menu:
            #将博客园首页的菜单名称和URL添加到列表the_menu
            the_menu.append(c.text + c.get_attribute(‘href‘))
        #检查2个列表是否一致(检查博客园首页的菜单名称及URL是否和预期一致)
        self.assertListEqual(the_menu,menu_data)
    def is_element_present(self,how,what):
        #找到元素,返回True,否则返回False
        try:
            self.driver.find_element(by=how,value = what)
        except NoSuchElementException as e:
            return False
        return True
    @classmethod
    def tearDownClass(cls):
        cls.driver.quit()
# 加上下面2句,可以通过命令行运行测试,不加的话不影响通过IDE运行测试
if __name__ == ‘__main__‘:
    # 加verbosity=2参数,在命令行中显示具体的测试方法
    unittest.main(verbosity=2)
(五) smoketests.py (测试套件)
import unittest
from searchtest import SearchTest
from homepagetest import HomePageTest
#获取SearchTest类 和 HomePageTest类中的所有测试方法
search_test = unittest.TestLoader().loadTestsFromTestCase(SearchTest)
home_page_test = unittest.TestLoader().loadTestsFromTestCase(HomePageTest)
#创建一个包括SearchTest和HomePageTest的测试套件
smoke_tests = unittest.TestSuite([home_page_test,search_test])
#运行测试套件
unittest.TextTestRunner(verbosity=2).run(smoke_tests)

(六) 其他说明

#另外一个文件在上一篇中已经说明

要完全使用上面的代码,需要创建一个文件menu.txt,输入以下数据:

园子https://home.cnblogs.com/,新闻https://news.cnblogs.com/,博问https://q.cnblogs.com/,闪存https://ing.cnblogs.com/,小组https://group.cnblogs.com/,收藏https://wz.cnblogs.com/,招聘https://job.cnblogs.com/,班级https://edu.cnblogs.com/,找找看http://zzk.cnblogs.com/

(七) 运行smoketests.py

原文地址:https://www.cnblogs.com/simple-free/p/8443463.html

时间: 2024-08-28 12:32:15

Python+Selenium笔记(四):unittest的Test Suite(测试套件)的相关文章

Python+Selenium笔记(十四)鼠标与键盘事件

 (一) 前言 Webdriver高级应用的API,允许我们模拟简单到复杂的键盘和鼠标事件,如拖拽操作.快捷键组合.长按以及鼠标右键操作,都是通过使用webdriver的Python API 中的ActionChains类实现的. 调用ActionChains类方法时,不会立即执行,而是将所有操作都存放在一个队列里,当调用perform()方法时,队列里的操作会依次执行 (二) 与键盘和鼠标事件有关的一些重要的方法 方法 简单说明 click(on_element=None) 单击元素 on_e

Python+Selenium笔记(九):操作警告和弹出框

#之前发的 driver.switch_to_alert() 这句虽然可以运行通过,但是会弹出警告信息(这种写法3.x不建议使用)  改成 driver.switch_to.alert就不会了. (一) 前言 开发人员使用JavaScript 警告或者模态对话框来提示校验错误信息.报警信息.执行操作后的返回信息,甚至用来接收输入值等. (二) Alert类 Selenium WebDriver 通过Alert 类来操控 JavaScript 警告. (三) Alert功能及方法 功能/属性 简单

Python+Selenium笔记(十八):持续集成jenkins

(一)安装xmlrunner 使用Jenkins执行测试时,测试代码中会用到这个模块. pip install xmlrunner (二)安装jenkins (1)   下载jekins https://jenkins.io/download/ 下载适合自己的,我是下载长期稳定版的. (2)   解压后运行jenkins.msi这个文件,然后一直下一步就是了. (3)   http://localhost:8080 登录 (4)   根据提示输入密码后,下一步. (6)   这里第一个应该是默认

用python+selenium进行一次cnblog的登录测试

用python+selenium自动化进行一次cnblog的登录测试,可供参考!下面包括测试代码和每种测试情况的截图: ''' cnblog的登录测试,分下面几种情况: (1)用户名.密码正确 (2)用户名正确.密码不正确 (3)用户名正确.密码为空 (4)用户名错误.密码正确 (5)用户名为空.密码正确(还有用户名和密码均为空时与此情况是一样的,这里就不单独测试了) ''' import unittest from selenium import webdriver from time imp

unittest单元测试框架之测试套件(三)

1.测试套件(注意:测试用例先添加先执行,后添加后执行,由此组织与设定测试用例的执行顺序) addTests:添加多个测试用例 addTest:添加单个测试用例 import unittest from UnittestDemo.test_mathfunc import TestMathFunc if __name__ == "__main__": suite = unittest.TestSuite() # 执行加法.减法.除法 tests =[TestMathFunc("

Python+Selenium笔记(十一):配置selenium Grid

(一) 前言 Selenium Grid可以将测试分布在若干个物理或虚拟机器上,从而实现分布方式或并行方式执行测试. 这个链接是官方的相关说明. https://github.com/SeleniumHQ/selenium/wiki/Grid2 (二) Selenium Grid 大概就是这个意思(一个中心节点(HUB),N个子节点(NODE,操作系统+浏览器)) (三) 环境配置 1. 前提:已经配置相应的 JDK环境(LINUX自带JDK环境(我装的LINUX自带的是1.8),WINDOWS

Python&Selenium 数据驱动【unittest+ddt+Excel】

一.摘要 一般情况下我们为了更好的管理测试数据会选择将测试数据存储在Excel文件当中去,本节内容将展示给读者将测试数据存储在Excel文档中的案例. 二.创建存储测试数据的Excel 创建一个Excel文件TestData.xlsx,并将如下表格数据写入到Excel文件中,作为测试数据. 序号 搜索词 期望结果 1 北京 北京 2 上海 上海 3 广州 广州 三.封装解析Excel文件模块 要解析Excel文件,需要先给Python环境安装openpyxl模块,启动命令行,输入命令pip in

Python+Selenium笔记(十):元素等待机制

 (一) 前言 突然的资源受限或网络延迟,可能导致找不到目标元素,这时测试报告会显示测试失败.这时需要一种延时机制,来使脚本的运行速度与程序的响应速度相匹配,WebDriver为这种情况提供了隐式等待和显式等待两种机制. (二) 隐式等待 一旦设置隐式等待时间,就会作用于这个WebDriver实例的整个生命周期(对所有的元素查找都生效),设置隐式等待时间后,Webdriver会在一定时间内持续检测和搜寻DOM,以便于查找一个或多个不是立即加载成功并可用的元素.隐式等待的默认时间是0. WebDr

Python+Selenium笔记(十二):数据驱动测试

(一)   前言 通过使用数据驱动测试,实现对输入值和预期结果的参数化.(例如:输入数据和预期结果可以直接读取Excel文档的数据) (二)   ddt 使用ddt执行数据驱动测试,ddt库可以将测试中的变量参数化.使用ddt的时候,在测试类上使用@ddt装饰符,在测试方法上使用@data装饰符.@data装饰符将参数当作测试数据,参数可以是单个值.列表.元组.字典.对于列表和元组,需要用@unpack装饰符把列表和元组解析成多个参数. 使用下面的命令安装ddt库 pip install ddt