python_selenium自动化测试框架

Posted 软件测试凡哥

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python_selenium自动化测试框架相关的知识,希望对你有一定的参考价值。

目录:导读

引言

设计思路

测试框架分层设计

 测试框架目录结构

 编写用例方法

测试结果展示

写在最后


引言

在如今的软件开发行业中,自动化测试已成为一项必不可少的技能。而Python与Selenium组合的自动化测试框架,正是一款备受开发者欢迎的自动化测试工具。Python语言的易学易用,以及Selenium框架的强大功能,使得Python+Selenium自动化测试框架成为了自动化测试领域的热门工具之一。在这篇文章中,我们将探索Python+Selenium自动化测试框架的设计模式、适用场景以及使用方法,帮助大家更好地了解这一工具,并在实践中获得更高效、准确的自动化测试结果。

设计思路

 本文整理归纳以往的工作中用到的东西,现汇总成基础测试框架提供分享。

框架采用python3 + selenium3 + PO + yaml + ddt + unittest等技术编写成基础测试框架,能适应日常测试工作需要。

1、使用Page Object模式将页面定位和业务操作分开,分离测试对象(元素对象)和测试脚本(用例脚本),一个页面建一个对象类,提高用例的可维护性;

2、使用yaml管理页面控件元素数据和测试用例数据。例如元素ID等发生变化时,不需要去修改测试代码,只需要在对应的页面元素yaml文件中修改即可;

3、分模块管理,互不影响,随时组装,即拿即用。

GitHub项目地址:GitHub - yingoja/DemoUI: selenium UI自动化测试框架

测试框架分层设计

 

  • 把常见的操作和查找封装成基础类,不管是什么产品,可直接拿来复用
  • 业务层主要是封装对象页面类,一个页面建一个类,业务层页面继承基础层
  • 用例层针对产品页面功能进行构造摸拟执行测试
  • 框架层提供基础组件,支撑整个流程执行及功能扩展,给用例层提供各页面的元素数据、用例测试数据,测试报告输出等

 测试框架目录结构

如下思维导图目录结构介绍:

 编写用例方法

 login.yaml

例如,我们要新增登录功能测试用例:

首先,只需在testyaml目录下新增一个页面对象yaml文件,参考login.yaml格式编写即可。这些文件是提供给封装页面对象类调用并执行定位识别操作。

 login_data.yaml

其次,在testdata目录下新增一个login_data.yaml文件提供给登录接口传参的测试数据,编写格式参考login_data.yaml文件。

 loginPage.py

然后,在page_obj目录下新增一个loginPage.py文件,是用来封装登录页面对象类,执行登录测试流程操作。

 login_sta.py

最后,在testcase目录下创建测试用例文件login_sta.py,采用ddt数据驱动读取yaml测试数据文件

综上所述,编写用例方法只需要按以上四个步骤创建->编写即可。

执行如下主程序,可看输出的实际结果。

 1 #!/usr/bin/env python
 2 # _*_ coding:utf-8 _*_
 3 __author__ = 'YinJia'
 4 
 5 import os,sys
 6 sys.path.append(os.path.dirname(__file__))
 7 from config import setting
 8 import unittest,time
 9 from package.htmlTestRunner import HTMLTestRunner
10 from public.models.newReport import new_report
11 from public.models.sendmail import send_mail
12 
13 # 测试报告存放文件夹,如不存在,则自动创建一个report目录
14 if not os.path.exists(setting.TEST_REPORT):os.makedirs(setting.TEST_REPORT + '/' + "screenshot")
15 
16 def add_case(test_path=setting.TEST_DIR):
17     """加载所有的测试用例"""
18     discover = unittest.defaultTestLoader.discover(test_path, pattern='*_sta.py')
19     return discover
20 
21 def run_case(all_case,result_path=setting.TEST_REPORT):
22     """执行所有的测试用例"""
23     now = time.strftime("%Y-%m-%d %H_%M_%S")
24     filename =  result_path + '/' + now + 'result.html'
25     fp = open(filename,'wb')
26     runner = HTMLTestRunner(stream=fp,title='抽屉新热榜UI自动化测试报告',
27                             description='环境:windows 7 浏览器:chrome',
28                             tester='Jason')
29     runner.run(all_case)
30     fp.close()
31     report = new_report(setting.TEST_REPORT) #调用模块生成最新的报告
32     send_mail(report) #调用发送邮件模块
33 
34 if __name__ =="__main__":
35     cases = add_case()
36     run_case(cases)

测试结果展示

  • HTML报告日志

  • HTML报告点击截图,弹出截图

  • 测试报告通过的日志

  • 自动截图存放指定的目录

  • 邮件测试报告

 

更多软件测试资料等学习教程请留言【软件测试学习】免费获取!

写在最后

如果你觉得文章还不错,请大家 点赞、分享、留言 下,因为这将是我持续输出更多优质文章的最强动力!

看到这篇文章的人有觉得我的理解有误的地方,也欢迎评论和探讨~

你也可以加入下方的的群聊去和同行大神交流切磋

 

Python_Selenium的等待操作

在跑自动化脚本时,有时候因为网络或者其他因素的影响会导致元素还没加载出来然后报not find element错误,所以这时候就需要注意添加等待 selenium的等待分为3种: 1、固定等待 2、智能等待 3、显示等待 1、固定等待:线程停止 time.sleep(2) 2、隐式等待(智能等待):

以上是关于python_selenium自动化测试框架的主要内容,如果未能解决你的问题,请参考以下文章

Python_Selenium的等待操作

python_selenium元素定位

python_selenium元素定位_xpath

Python_Selenium之浏览器封装_去掉浏览器受到自动化控制横条显示及去掉是否记住密码弹窗

性能测试利器-Locust框架解析

自动化测试开展自动化测试的过程