《一头扎进》系列之Python+Selenium框架设计篇6 - 价值好几K的框架,呦!这个框架还真牛叉哦!!!

1. 简介

  本文开始介绍如何通过unittest来管理和执行测试用例,这一篇主要是介绍unittest下addTest()方法来加载测试用例到测试套件中去、用addTest()方法来加载我们测试用例到suite中去和利用discover()方法去加载一个路径下所有的测试用例。

2. addTest()方法

  这里首先介绍unittest下addTest()方法来加载测试用例到测试套件中去。为了演示效果,我在前面文章的脚本基础上,新建了一个测试脚本,这个测试脚本有一个测试用例,加上前面的测试脚本,一共就是三个测试用例,前面那个测试类里面包括两个测试用例。

新建的测试脚本,test_get_page_title.py代码如下:

2.1 代码实现:

2.2 参考代码:

# -*- coding:utf-8 -*-

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
‘‘‘
Created on 2019-12-24
@author: 北京-宏哥   QQ交流群:705269076
Project: 《《一头扎进》系列之Python+Selenium框架设计篇5- 价值好几K的框架,呦!这个框架还真牛叉哦!!!
‘‘‘
# 3.导入模块
import unittest

from automation_framework_demo.framework.browser_engine import BrowserEngine
from automation_framework_demo.pageobjects.baidu_homepage import HomePage

class GetPageTitle(unittest.TestCase):

    @classmethod
    def setUpClass(cls):
        browser = BrowserEngine(cls)
        cls.driver = browser.open_browser(cls)

    @classmethod
    def tearDownClass(cls):
        cls.driver.quit()

    def test_get_title(self):
        homepage = HomePage(self.driver)
        print(homepage.get_page_title())

2.3 运行结果:

运行代码后,控制台打印如下图的结果

今天来学习下,如果加载这两个测试类文件里面的3个测试脚本。在unittest下有一个管理测试套件的叫TestSuit(),我们要使用这个测试套件,需要先初始化一个suite实例,然后这个实例有一个addTest()的方法,可以加载不同类里面的不同测试函数,格式这样的 addTest(测试类的类名(‘测试函数名称,就是test开头的函数’)),我们在testsuites这个包下新建一个TestRunner.py文件用来管理我们的用例启动方式。
来看看这个TestRunner.py的内容

2.4 代码实现:

2.5 参考代码:

# -*- coding:utf-8 -*-

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
‘‘‘
Created on 2019-12-24
@author: 北京-宏哥   QQ交流群:705269076
Project: 《《一头扎进》系列之Python+Selenium框架设计篇5- 价值好几K的框架,呦!这个框架还真牛叉哦!!!
‘‘‘
# 3.导入模块
import unittest
#from automation_framework_demo.testsuits import testsuits
from automation_framework_demo.testsuits.baidu_search2 import BaiduSearch
from automation_framework_demo.testsuits.test_get_page_title import GetPageTitle

suite = unittest.TestSuite()
suite.addTest(BaiduSearch(‘test_baidu_search‘))
suite.addTest(BaiduSearch(‘test_search2‘))
suite.addTest(GetPageTitle(‘test_get_title‘))

if __name__ == ‘__main__‘:
    # 执行用例
    runner = unittest.TextTestRunner()
    runner.run(suite)

2.6 运行结果:

运行代码后,控制台打印如下图的结果

这个方法有没有局限性呢?当然有,加入你有几百个测试类,你是不是也一直这样手动去添加?有没有其他更好的方法去加载我们的测试脚本,关于这个问题,请紧跟宏哥的脚步继续往下看、往下走。

3. makeSuite()方法

前面文章介绍了如何用addTest()方法来加载我们测试用例到suite中去,本文介绍利用makeSuite()方法,一次性加载一个类文件下所有测试用例到suite中去。还是利用前面一篇文章中的测试脚本,来看看TestRunner.py如何写。

3.1 代码实现:

3.2 参考代码:

# -*- coding:utf-8 -*-

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
‘‘‘
Created on 2019-12-24
@author: 北京-宏哥   QQ交流群:705269076
Project: 《《一头扎进》系列之Python+Selenium框架设计篇5- 价值好几K的框架,呦!这个框架还真牛叉哦!!!
‘‘‘
# 3.导入模块
import unittest
#from automation_framework_demo.testsuits import testsuits
from automation_framework_demo.testsuits.baidu_search2 import BaiduSearch
from automation_framework_demo.testsuits.test_get_page_title import GetPageTitle

‘‘‘
suite = unittest.TestSuite()
suite.addTest(BaiduSearch(‘test_baidu_search‘))
suite.addTest(BaiduSearch(‘test_search2‘))
suite.addTest(GetPageTitle(‘test_get_title‘))
‘‘‘
suite =unittest.TestSuite(unittest.makeSuite(BaiduSearch))

if __name__ == ‘__main__‘:
    # 执行用例
    runner = unittest.TextTestRunner()
    runner.run(suite)

3.3 运行结果:

运行代码后,控制台打印如下图的结果

缺陷: makeSuite()方法虽然比前面文章的addTest()方法有了一定的效率提升,在添加测试用例到测试套件过程。但是这个方法也有很多缺点,我不可能把所有项目脚本都放一个测试类文件吧。在unittest中还是有很多方法可以用来添加测试用例到suite中,makeSuite(类名称),只是一种,你可以多看看unittest的文档介绍。接下来我们介绍如何一次性加载一个文件目录下所有测试用例。

4. discover()方法

  继续接着介绍,如何利用unittest管理和执行测试用例的问题,这里我们还是利用之前已经有的三条测试用例,如果你跳过了前面文章,请回到框架设计篇的第八篇和第七篇,里面有相关测试类的文件。本文来介绍,如果利用discover()方法去加载一个路径下所有的测试用例。这个方法是不是太适合我们现在的需求,例如我只需要跑testsuite包下所有测试用例,不管在里面有多少个包和多少个测试类,只需要用discover()搞定,来看看这个场景下TestRunner.py如何写。

4.1 代码实现:

4.2 参考代码:

# -*- coding:utf-8 -*-

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
‘‘‘
Created on 2019-12-24
@author: 北京-宏哥   QQ交流群:705269076
Project: 《《一头扎进》系列之Python+Selenium框架设计篇5- 价值好几K的框架,呦!这个框架还真牛叉哦!!!
‘‘‘
# 3.导入模块
import unittest

suite = unittest.TestLoader().discover("testsuits")

if __name__ == ‘__main__‘:
    # 执行用例
    runner = unittest.TextTestRunner()
    runner.run(suite)

4.3 运行结果:

运行代码后,控制台打印如下图的结果

上面的testsuits是可以包名,也可以是一个文件夹名称,在实际脚本开发过程中,最后都采用这个方法来批量管理和执行几百上千的测试用例。下一篇内容,大概会介绍如何利用HTMLTestRunner.py这个开源的插件,生成测试报告,这个测试报告是一个HTML的格式。介绍完了生成报告文章,框架设计系列教程就会结束,不打算过多介绍其他技能点。

5. 小结

5.1 报错提示:ImportError: Start directory is not importable: ‘D:\\PyCharm-Workspace\\testcases‘

以下两种路径实现代码存放在path.py中,查看区别:

base_dir = os.path.dirname(os.getcwd())       # 第一种,当前目录# os.getcwd()  定位路径为common# os.path.dirname(os.getcwd())   定位路径为API_work
base_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))    # 第二种,该代码存放的根目录# os.path.abspath(__file__)   定位路径为path.py# os.path.dirname(os.path.abspath(__file__))    定位路径为common# os.path.dirname(os.path.dirname(os.path.abspath(__file__)))  定位路径为API_work

以上两种方式,在path.py中执行,print输出均为:

但第一种方式,在run.py中调用path.py中的base_dir属性,查找 "test_*.py" 的根目录就会出现下以报错:

 原因:

1、在run.py中调用path.py 中的 os.getcwd() 代码 ,就是定位 run.py 的根目录;

即:

os.getcwd()   定位路径为API_work

os.path.dirname(os.getcwd())   定位路径为API_work的上一层目录,因找不到上一层目录,所以报错;

2、在run.py中调用第二种方式,是查找path.py的根目录,所以可执行正常;

总结:

  其他模块会调用固定路径时,不要使用 os.getcwd() 当前定位方式来实现;使用 os.path.abspath(__file__) 实现。

好了,今天的分享就到这里吧!!!谢谢各位的耐心阅读。有问题加群交流讨论

您的肯定就是我进步的动力。如果你感觉还不错,就请鼓励一下吧!记得随手点波  推荐  不要忘记哦!!!

别忘了点 推荐 留下您来过的痕迹

原文地址:https://www.cnblogs.com/du-hong/p/12089570.html

时间: 2024-10-22 18:48:00

《一头扎进》系列之Python+Selenium框架设计篇6 - 价值好几K的框架,呦!这个框架还真牛叉哦!!!的相关文章

《一头扎进》系列之Python+Selenium框架设计篇3- 价值好几K的框架,狼来了,狼来了....,狼没来,框架真的来了

1. 简介 前边宏哥一边一边的喊框架,就如同一边一边的喊狼来了!狼来了!.....这回是狼没有来,框架真的来了.从本文开始宏哥将会一步一步介绍,如何从无到有地创建自己的第一个自动化测试框架.这一篇,我们介绍,如何封装自己的日志类和浏览器引擎类. 2. 创建项目层级结构 如何创建,怎么创建.这个就需要我们前边介绍的框架概要设计以及框架的详细设计的思维导图,宏哥就是根据那个图,轻松地.清楚的.思路清晰地一步一步创建项目层级结构. 相关步骤: 1. 打开PyCharm,创建如下格式的项目层级结构,为了

《一头扎进》系列之Python+Selenium框架实战篇4- 价值好几K的框架,呵!这个框架有点意思啊!!!

1.简介 前面文章,我们实现了框架的一部分功能,包括日志类和浏览器引擎类的封装,今天我们继续封装一个基类和介绍如何实现POM.关于基类,是这样定义的:把一些常见的页面操作的selenium封装到base_page.py这个类文件,以后每个POM中的页面类,都继承这个基类,这样每个页面类都有基类的方法,这个我们会在这篇文章由宏哥实现. 2.项目层级结构 1. 上一篇中我们已经创建好了项目层级结构,具体项目层级结构如下图.这里不再赘述,相关文件也如下: 3. 定位和截图类封装 1. 在实现封装基类里

一头扎进Node系列 - 目录

一.前言 本系列是属于初级教程.博主我也还只是一个node的新兵蛋子,想通过学习官网的API文档,慢慢的打好Node基础.当然后期这系列文档会慢慢完善,并且会添加一些项目实战中遇到的一些问题以及解决方案!如果你也是初学者,欢迎你一起加入我们的 NODE API 学习之路吧! Node官网   :https://nodejs.org/api/ Node中文网:http://nodejs.cn/doc/node/index.html 二.目录 一头扎进Node系列 - URL 一头扎进Node系列

一头扎进Spring之---------Spring七大核心模块

Spring七大核心模块 核心容器(Spring Core) 核心容器提供Spring框架的基本功能.Spring以bean的方式组织和管理Java应用中的各个组件及其关系.Spring使用BeanFactory来产生和管理Bean,它是工厂模式的实现.BeanFactory使用控制反转(IoC)模式将应用的配置和依赖性规范与实际的应用程序代码分开 应用上下文(Spring Context) Spring上下文是一个配置文件,向Spring框架提供上下文信息.Spring上下文包括企业服务,如J

《一头扎进Spring4》学习笔记(二)Spring ioc 之详解

第一节 Spring ioc 简介 IOC(控制反转:Inverse of Control),又称作 依赖注入,是一种重要的面向对象编程的法则来削减计算机程序的耦合问题,也是轻量级的Spring框架的核心. 第二节 Spring ico 实例 1.接口类 1 public interface Tester { 2 public void test(); 3 } 2.实体类继承接口类 1 public class Lisi implements Tester{ 2 public void test

《一头扎进Spring4》学习笔记(一)简介与helloworld实现

第一讲 问候Spring4 第一节 简介 Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson创建.简单来说,Spring是一个分层的JavaSE/EEfull-stack(一站式) 轻量级开源框架. 1.框架特征 轻量--从大小与开销两方面而言Spring都是轻量的.完整的Spring框架可以在一个大小只有1MB多的JAR文件里发布.并且Spring所需的处理开销也是微不足道的.此外,Spring是非侵入式的:典型地,Sprin

一头扎进Spring之---------Spring核心容器

[回顾] 在上篇博客中,我们清楚了Spring的核心IOC,博客的结尾,提出了关于容器的问题.在Spring框架中,容器扮演者重要的角色.容器是什么?Java容器?Spring容器?这几个词,大家都很熟悉,但真正知道么?本篇博客的重点分析Spring中的核心容器.容器和Java容器不做详细介绍. [容器] 容器,从字面角度很容易理解,就是用来贮藏东西的.从计算机的角度,可粗略地分为Web容器和编程容器. Web容器是应用服务器中位于组件和平台之间的接口集合.如WebLogic.Tomcat等.

一头扎进Node(一) - URL

一.前言 我们以官网的Demo为例,URL如下: http://user:[email protected]:8080/p/a/t/h?query=string#hash 我们可以将这个url拆分成以下组成部分: 属性名 值 含义 href http://user:[email protected]:8080/p/a/t/h?query=string#hash URL的完整链接 protocol http: URL协议 slashes true/false 协议“:”后面是否有斜线 host h

一头扎进JavaScript设计模式(一)- 构造器模式(Constructor)

一.前言 1.对象是什么?怎么创建?怎么赋值? 在这边就不展开讲了,请参考另外一篇博文JavaScript 对象详解. 2.Contructor是什么? 在这边我们先运用书上的一段话:在经典的面向对象变成语言中,constructor是一种在内存已分配给该对象的情况下,用于初始化新创建对象的特殊方法. 3.Constructor有什么用? 当我们实例化一个对象的时候,对象的构造器会根据你实例化时的参数进行初始化,设置成员属性和方法的值. 二.基本 Constructor 我们创建一个Person