前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python+Selenium笔记(四):unittest的Test Suite(测试套件)

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

作者头像
free赖权华
发布2018-04-27 18:07:32
2.1K0
发布2018-04-27 18:07:32
举报
文章被收录于专栏:赖权华的笔记赖权华的笔记

(一) 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

代码语言:javascript
复制
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)
代码语言:javascript
复制
(四) homepagetest.py
代码语言:javascript
复制
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)
代码语言:javascript
复制
(五) smoketests.py (测试套件)
代码语言:javascript
复制
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,输入以下数据:

代码语言:javascript
复制
园子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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-02-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档