大发五分快3规律_《一头扎进》系列之Python+Selenium自动化测试框架实战篇6

  • 时间:
  • 浏览:1
  • 来源:小飞娱乐网_提供小欧娱乐网技术_小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 运行结果:

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

      今天来学习下,肯能加载這個 二个多 多测试类文件顶端的八个测试脚本。在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__) 实现。

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

您的肯定以后进步的动力。肯能你感觉还不错,就请鼓励一下吧!记得随手点波  推荐  从不忘记哦!!!

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