美文网首页自动化测试
用python版selenium来拯救测试小姐姐

用python版selenium来拯救测试小姐姐

作者: 七玄之主 | 来源:发表于2019-12-11 13:45 被阅读0次

    最近参与的项目进入集中测试阶段了,可怜各位测试小姐姐还要手动输入各种数据,真是不能忍啊。这种时候就需要我们程序猿出场了,使用各种高科技来拯救小姐姐吧。

    python版的selenium来实现一个简单的自动化程序很简单,具体selenium的使用教程也不用赘述了,官网文档描述的很清楚了,附上链接供大家参考Selenium 浏览器自动化项目

    言归正传,该项目名为AutoTest 可配置自动化测试工具使用,python+selenium实现的可配置自动化测试工具,只要稍微了解HTML及相关查询器的知识,就可以通过书写测试流程文件来完成测试流程定制,表单自动填写,按钮点击,流程截图,键盘事件,浏览器缓存操作等功能,目前仅支持Chrome, IE浏览器。

    项目地址AutoTest 可配置自动化测试工具

    启动方法

    • 开发环境运行

      • 本地环境请预先安装好python3.8,下载项目到本地任意文件夹,使用pip安装pipenv包,使用vscode加载项目后,在控制台输入pipenv shell建立独立开发环境,然后输入pipenv install完成项目所需包安装。
      • 本地添加如下lauch.json启动文件
        {
            "version": "0.2.0",
            "configurations": [
                {
                    "name": "Python: Current File",
                    "type": "python",
                    "request": "launch",
                    "program": "${workspaceFolder}/autotest.py",
                    "console": "integratedTerminal"
                }
            ]
        }
        
      • 点击F5即可启动本项目。
    • exe文件运行

      • 在完成开发环境配置后,可以通过项目中提供的run.bat文件来生成exe可执行文件来启动项目。

    使用说明

    • 相关配置文件

      • autotest.yaml 项目全局配置文件,配置诸如默认启动浏览器,是否使用代理等。
      • logger.yaml 日志配置文件,配置日志等级及输出类型
      • const.yaml 常量定义,在自定义测试流程时使用
    • 流程文件定义说明

      • 流程文件是json格式文件,所有文件都必须放到项目根目录下的flowdata文件夹下,文件名取名任意,前缀为cmn_XXXX.json的文件将做为通用流程文件,提供给其他流程文件使用,不会直接加载到项目可执行流程文件中。
      • 如下代码所示,每一个键值对代表一个操作步骤,字典键无具体意义,可作为操作提示备注信息,type指定操作类型,这里的open是指的打开具体网址操作,targeturl表示目标网址,option表示当前操作后的一些额外动作,例如此处的{ "type": "wait", "params": 5}为停顿5秒。
        {
          "打开简书": {
            "type": "open",
            "targeturl": "https://www.jianshu.com/",
            "option": { "type": "wait", "params": 5}
          }
        }
        
      • type包括以下类型
        • open 打开指定网址。
          • 必要属性:targeturl指定目标网站地址;
          • 可选属性:
            • option指定当前操作完成后的一些额外操作,包括refresh刷新页面,wait停顿,close关闭浏览器,switch切换窗口,screenshot截图;
            • doafter指定完成操作后的子操作,语法和父节点一致。
        • read 读取指定mock数据文件。
          • 必要属性:
            • findmethod指定页面元素使用的选择器,包括ID,XPATH,LINK_TEXT,PARTIAL_LINK_TEXT,NAME,TAG_NAME,CLASS_NAME,CSS_SELECTOR
            • targeturl指定读取目标mock文件地址。mock文件作为流程中需要使用的共通数据文件,统一放置在mockdata文件夹中,mock文件格式也为json格式,其中的字典键对应与findmethod相匹配的查询表达式。
          • 可选属性:optiondoafter
        • click 处理页面元素单击操作。
          • 必要属性:findmethodtarget指定与findmethod相匹配的查询表达式;
          • 可选属性:
            • count指定点击次数,默认为1次;
            • index通过指定索引值从匹配元素集中找到对应元素
            • option
            • doafter
        • dbclick 处理页面元素双击操作。
          • 必要属性:findmethodtarget
          • 可选属性:optiondoafter
        • alert 弹出对话框确认操作。系统中有时在点击关键按钮时会出现相关操作确认提示框,通过配置该节点默认确认进入下一节点。
          • 可选属性:optiondoafter
        • copy 将匹配值复制到剪贴板中,以备后续使用。
          • 必要属性:
            • 通过指定findmethodtarget组合,可以复制页面指定元素值到剪贴板中;
            • 通过指定itemval,可以复制其对应值到剪贴板中,itemval支持设置常量值,如copy操作配置在某循环中,也可通过指定format来完成动态值设置。
          • 可选属性:optiondoafter
        • paste 将剪贴板值设置给页面指定元素。
          • 必要属性:findmethodtarget
          • 可选属性:optiondoafter
        • for 循环操作。
          • 必要属性:
            • 通过指定startidxendidx组合,完成指定范围的索引循环,其当前索引值可作为动态值提供给循环体内子节点使用;
            • 通过指定findmethodtarget组合,完成对页面匹配元素集的循环操作,当前元素值可提供给循环体内子节点使用。当循环体内click子节点未指定元素时,会使用循环中的当前元素进行单击操作。
            • flow定义了循环体要处理的子节点集合。
          • 可选属性:optiondoafter
        • cache 设置浏览器缓存。
          • 必要属性:
            • cachekey指定浏览器缓存键;
            • itemval指定缓存键对应的值。
          • 可选属性:optiondoafter
        • setval 区别于read多项目读取,该操作为对页面单项目的值设定,主要用于设置上传文件,动态值设定等。
          • 必要属性:findmethodtarget, itemval
          • 可选属性:optiondoafter
        • flowfile 加载共通流程模板文件。
          • 必要属性:targeturl
          • 可选属性:optiondoafter
        • keyboard 键盘操作。多用于点击键盘PAGE_DOWN事件完成页面滚动等,不支持键盘键组合。
          • 必要属性:
            • 通过指定findmethodtarget组合,在指定页面元素上施加对应键盘操作。
            • itemval指定键盘键值;
          • 可选属性:optiondoafter
      • 其他属性说明
        • option包括无参命令,有参命令,也可以通过数组形式包括多个命令。
          • 无参命令:
            • {"option":"refresh"} 刷新浏览器
            • {"option":"close"} 关闭浏览器
            • {"option":"screenshot"} 当前显示窗口截屏
          • 有参命令
            • {"option": { "type": "wait", "params": 5} } 执行等待,等待时间由params参数指定。多用于解决页面加载缓慢问题。
            • {"option": { "type": "switch", "params": "new"} } 切换到新开窗口;{"option": { "type": "switch", "params": "origin"} } 关闭新窗口后,切换回原始窗口
            • 截取页面全屏,params指定参数数组,第一个参数为页面中需要处理的漂浮元素,xpath指定查询元素方式,当前支持id=xxxclass=yyy, tag=zzz等3种方式,display_page表示漂浮元素要显示的位置,一般情况下漂浮元素如简书的头需要显示在截屏的首页则设置为first,如简书的返回顶部按钮需要显示在截屏的尾页则设置为last,截取全屏功能仅通过Chrome测试;第二个参数为指定是否需要预先加载完页面,例如简书首页文章列表随着滚动加载,如需要截取全屏则需要设置为True,反之对于一次性加载的页面则设置为False
              {
                "type": "screenshot",
                "params": [
                  [
                    { "xpath":"tag=nav", "display_page":"first"},
                    { "xpath":"class=side-tool", "display_page":"last"}
                  ],
                  "True"
                ]
              }
              
      • bat文件说明
        • run.bat 执行后会在项目根目录生成dist文件夹,里面包含了项目可执行程序exe等相关文件。执行打包前,请先进入pipenv所创建的独立环境后,再请执行命令pip install pyinstaller安装对应包。
        • zip.bat 使用windows自带压缩软件,压缩浏览器代理插件用的压缩文件,使用前请先修改proxy文件下的代理配置文件background.js,直接cmd中进入项目目录输入zip命令执行。

    简书点赞流程文件解析

    {
      "打开简书": {
        "type": "open",
        "targeturl": "https://www.jianshu.com/",
        "option": { "type": "wait", "params": 5}
      },
      "添加cookie": {
        "type": "cache",
        "cachekey": "remember_user_token",
        "itemval": "输入账户登陆后的token值",
        "option": ["refresh", {
          "type": "wait",
          "params": 5
        }, {
          "type": "screenshot",
          "params": [
            [
              { "xpath":"tag=nav", "display_page":"first"},
              { "xpath":"class=side-tool", "display_page":"last"}
            ],
            "True"
          ]
        }]
      },
      "循环点击文章列表": {
        "type": "for",
        "findmethod": "CSS_SELECTOR",
        "target": "#list-container>ul.note-list>li>div.content>a.title",
        "flow": {
          "打开文章": {
            "type": "click",
            "option": {
              "type": "switch",
              "params": "new"
            }
          },
          "文章点赞": {
            "type": "click",
            "findmethod": "CLASS_NAME",
            "target": "_2VdqdF",
            "index": 0,
            "option": {
              "type": "switch",
              "params": "origin"
            }
          }
        }
      }
    }
    

    该流程文件包含了3个节点,第一个节点表示打开简书网站;第二个节点操作缓存,简书网站在你登陆以后会在浏览器缓存的remember_user_token中记录你的token值,通过手动添加该缓存即可自动登陆,同时在添加完缓存后,需要按序执行额外的一些操作,刷新浏览器让登陆状态生效,截取文章列表全屏(此处另一个目的是为了加载完全部文章以备后续点赞用);第三个节点通过CSS_SELECTOR选择器,查找所有文章列表,并循环该列表完成后续点赞操作。子节点打开文章,由于没有指定查找匹配元素方式,则默认会点击循环当前元素即当前文章,额外操作中完成切换到新窗口,子节点文章点赞则完成单击点赞按钮后,在额外操作中关掉当前窗口并切换回主窗口。

    下面是程序运行后的启动界面,选中流程文件,点击启动即可。


    被拯救的小姐姐很满意,奖励了一根鸡腿。

    相关文章

      网友评论

        本文标题:用python版selenium来拯救测试小姐姐

        本文链接:https://www.haomeiwen.com/subject/ppdvgctx.html