zoukankan      html  css  js  c++  java
  • 使用python实现测试工具(二)

    本系列教程使用的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)}个元素
    ")
        for element in elements:
          print(element.html)
          print(element.attrs)
          print()
    
    
    if len(elements) != int(length):
      print(f"失败! 预期{length}个元素,实际存在{len(elements)}个元素
    ")
      debug()
      exit(1)
    else:
      print(f"成功!
    ")
      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">更多</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">更多</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">更多</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">更多</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">更多</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">更多</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">更多</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">更多</a></div>
    {'class': ('thumbnail-img',)}
    

    动手时间

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

    扩展阅读

    源码地址

    github地址

  • 相关阅读:
    java解析XML【转载】
    呼叫中心功能、呼叫中心硬件设备、系统性能、运行环境介绍
    动态语言、静态语言 比较
    zk 常用资料整理(转)
    zk 的Fileupload 一直返回NULL 解决办法
    16个不错的Visual Studio插件(转)
    Mysql 去除 特定字符后面的所有字符串
    MVC4学习笔记(二) MVC设计实例,5分钟内完成你的Mvc项目
    Robotium 框架学习之Class By
    Intrumentation类:ActivityInstrumentationTestCase2学习(1)
  • 原文地址:https://www.cnblogs.com/nbkhic/p/12340264.html
Copyright © 2011-2022 走看看