python实现测试工具(二)——简单的ui测试工具


Posted in Python onOctober 19, 2020

本系列教程使用的python版本是3.6.3。

背景

这一节我们实现一个简单的ui测试工具。

该工具的作用是访问某个页面,然后根据css选择器去定位页面上的元素,最后判断页面上元素的个数与我们的预期是否相符。

举一个具体的例子,比如我们去访问www.itest.info这个页面,我们需要判断页面上class = thumbnail-img的元素存在,并且有4个。因为每一个元素代表一门课程,所以这个断言的意思是重定向科技主页上应该有4门主要课程。

视频讲解在这里。

工具设计

我们设计一个命令行工具,给工具传3个参数。

  • 被访问页面的url
  • 页面上元素的css选择器
  • 预期的元素数量,页面上可以存在n个元素,如果传入0,则表示元素不存在,做反向断言

所以工具大概是这样用的: python script_name.py url css_selector length

代码实现

简单起见,我们会用到requests-html库。安装文档在这里。

from requests_html import HTMLSession
from sys import argv
DEBUG = True

USAGE = '''
USAGE:
python html_assertion.py www.itest.info .thumbnail-img 4
'''

if len(argv) != 4:
 print(USAGE)
 exit(1)

script_name, url, css_selector, length = argv

if url[:4] != 'http':
 url = 'http://' + url

session = HTMLSession()
r = session.get(url)

elements = r.html.find(css_selector)


def debug():
 if DEBUG:
  print('*' * 100)
  print(f"css选择器: {css_selector}, 共找到{len(elements)}个元素\n")
  for element in elements:
   print(element.html)
   print(element.attrs)
   print()


if len(elements) != int(length):
 print(f"失败! 预期{length}个元素,实际存在{len(elements)}个元素\n")
 debug()
 exit(1)
else:
 print(f"成功!\n")
 debug()

精讲

用例失败之后使用exit(1)表示异常退出,这样在使用jenkins运行的时候,用例失败jenkins的job结果也会相应失败
requests-html库的基本使用参考这里

运行示例

# 失败情况
python html_assertion.py www.itest.info .thumbnail-img 1
失败! 预期1个元素,实际存在4个元素

****************************************************************************************************
css选择器: .thumbnail-img, 共找到4个元素

<div class="thumbnail-img"><div class="overflow-hidden"><img class="img-responsive" src="/uploads/course/image/7/mission_impossible_cut.jpg"/></div><a class="btn-more hover-effect" href="/courses/7" rel="external nofollow" rel="external nofollow" >更多</a></div>
{'class': ('thumbnail-img',)}

<div class="thumbnail-img"><div class="overflow-hidden"><img class="img-responsive" src="/uploads/course/image/6/120606ineam4nspdc6qdaw.jpg"/></div><a class="btn-more hover-effect" href="/courses/6" rel="external nofollow" rel="external nofollow" >更多</a></div>
{'class': ('thumbnail-img',)}

<div class="thumbnail-img"><div class="overflow-hidden"><img class="img-responsive" src="/uploads/course/image/3/12.jpg"/></div><a class="btn-more hover-effect" href="/courses/3" rel="external nofollow" rel="external nofollow" >更多</a></div>
{'class': ('thumbnail-img',)}

<div class="thumbnail-img"><div class="overflow-hidden"><img class="img-responsive" src="/uploads/course/image/2/13.jpg"/></div><a class="btn-more hover-effect" href="/courses/2" rel="external nofollow" rel="external nofollow" >更多</a></div>
{'class': ('thumbnail-img',)}

# 成功情况
python html_assertion.py www.itest.info .thumbnail-img 4
成功!

****************************************************************************************************
css选择器: .thumbnail-img, 共找到4个元素

<div class="thumbnail-img"><div class="overflow-hidden"><img class="img-responsive" src="/uploads/course/image/7/mission_impossible_cut.jpg"/></div><a class="btn-more hover-effect" href="/courses/7" rel="external nofollow" rel="external nofollow" >更多</a></div>
{'class': ('thumbnail-img',)}

<div class="thumbnail-img"><div class="overflow-hidden"><img class="img-responsive" src="/uploads/course/image/6/120606ineam4nspdc6qdaw.jpg"/></div><a class="btn-more hover-effect" href="/courses/6" rel="external nofollow" rel="external nofollow" >更多</a></div>
{'class': ('thumbnail-img',)}

<div class="thumbnail-img"><div class="overflow-hidden"><img class="img-responsive" src="/uploads/course/image/3/12.jpg"/></div><a class="btn-more hover-effect" href="/courses/3" rel="external nofollow" rel="external nofollow" >更多</a></div>
{'class': ('thumbnail-img',)}

<div class="thumbnail-img"><div class="overflow-hidden"><img class="img-responsive" src="/uploads/course/image/2/13.jpg"/></div><a class="btn-more hover-effect" href="/courses/2" rel="external nofollow" rel="external nofollow" >更多</a></div>
{'class': ('thumbnail-img',)}

动手时间

  • 抄一遍代码,看自己能不能运行起来
  • 给这段代码每一行都加上注释,理解代码做了些什么

扩展阅读

https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors

源码地址

github地址

以上就是python实现测试工具(二)——简单的ui测试工具的详细内容,更多关于python ui测试的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
详解python异步编程之asyncio(百万并发)
Jul 07 Python
详解将Django部署到Centos7全攻略
Sep 26 Python
Python多线程处理实例详解【单进程/多进程】
Jan 30 Python
ZABBIX3.2使用python脚本实现监控报表的方法
Jul 02 Python
django自带serializers序列化返回指定字段的方法
Aug 21 Python
tensorflow ckpt模型和pb模型获取节点名称,及ckpt转pb模型实例
Jan 21 Python
python线程join方法原理解析
Feb 11 Python
Python判断字符串是否为空和null方法实例
Apr 26 Python
pandas.DataFrame.drop_duplicates 用法介绍
Jul 06 Python
Python字典取键、值对的方法步骤
Sep 30 Python
使用pandas实现筛选出指定列值所对应的行
Dec 13 Python
selenium+python实现基本自动化测试的示例代码
Jan 27 Python
python实现测试工具(一)——命令行发送get请求
Oct 19 #Python
基于Python制作一副扑克牌过程详解
Oct 19 #Python
Python实现壁纸下载与轮换
Oct 19 #Python
Python调用REST API接口的几种方式汇总
Oct 19 #Python
Python爬虫抓取论坛关键字过程解析
Oct 19 #Python
python MD5加密的示例
Oct 19 #Python
python Yaml、Json、Dict之间的转化
Oct 19 #Python
You might like
提高PHP编程效率的53个要点(经验小结)
2010/09/04 PHP
php版淘宝网查询商品接口代码示例
2014/06/17 PHP
Zend Framework教程之资源(Resources)用法实例详解
2016/03/14 PHP
为你的 Laravel 验证器加上多验证场景的实现
2020/04/07 PHP
一句话JavaScript表单验证代码
2009/08/02 Javascript
Javascript 面向对象 命名空间
2010/05/13 Javascript
jquery 日期控件datepicker属性详细解析
2013/11/08 Javascript
JavaScript中for-in遍历方式示例介绍
2014/02/11 Javascript
javascript匿名函数应用示例介绍
2014/03/07 Javascript
js事件处理程序跨浏览器解决方案
2016/03/27 Javascript
vue2.0数据双向绑定与表单bootstrap+vue组件
2017/02/27 Javascript
vue.js 实现评价五角星组件的实例代码
2018/08/13 Javascript
Vue项目打包压缩的实现(让页面更快响应)
2020/03/10 Javascript
JS canvas实现画板和签字板功能
2021/02/23 Javascript
python中字典dict常用操作方法实例总结
2015/04/04 Python
python的多重继承的理解
2017/08/06 Python
Python语言实现将图片转化为html页面
2017/12/06 Python
python实现数据写入excel表格
2018/03/25 Python
windows下添加Python环境变量的方法汇总
2018/05/14 Python
Python安装lz4-0.10.1遇到的坑
2018/05/20 Python
使用Python将Mysql的查询数据导出到文件的方法
2019/02/25 Python
python发送多人邮件没有展示收件人问题的解决方法
2019/06/21 Python
button在IE6/7下的黑边去除方案
2012/12/24 HTML / CSS
Html5移动端div固定到底部实现底部导航条的几种方式
2021/03/09 HTML / CSS
比利时的在线灯具店:Lampen24.be
2019/07/01 全球购物
Java的五个基础面试题
2016/02/26 面试题
天网面试题
2013/04/07 面试题
汽车专业人才自我鉴定范文
2013/12/29 职场文书
护理专业毕业生自荐信范文
2014/01/05 职场文书
小学生期末自我鉴定
2014/01/19 职场文书
同事打架检讨书
2014/02/04 职场文书
2014年三八妇女节活动方案
2014/02/28 职场文书
大学生社团活动总结
2014/04/26 职场文书
学校志愿者活动总结
2014/06/27 职场文书
2015年医生个人工作总结
2015/04/25 职场文书
python通过函数名调用函数的几种方法总结
2021/06/07 Python