• AirtestIDE创建.py脚本并运行、生成报告


    文章来源于AirtestProject


    前言

    有很多新手同学在刚开始使用AirtestIDE的时候,就特别喜欢新建纯 .py 脚本,我想这可能是出于对纯 .py 脚本莫名的熟悉感吧~

    而认真看过我们官方教程的同学都知道,对于刚接触Airtest和Poco这两个自动化测试框架的新手来说,我们还是非常推荐大家从 .air 脚本开始学起的。

    但鉴于在普通的 .py 脚本里面调用Airtest或者Poco的接口,也是同学们的一个刚需,我们今天就先来看看如何借助AirtestIDE来帮助我们新建纯 .py 脚本,并了解下这其中有什么特别的注意事项吧~本期目录:

    • 1.新建.py脚本
    • 2.详解auto_setup()里面的logdir和devices
    • 3.生成纯.py脚本的报告

    (注:下文内容均使用IDE自带的python环境)


    1.新建.py脚本

    ① 打开你的AirtestIDE,依次选择 文件 - 新建脚本 - .py 纯Python(高级用户

    ② 在弹出的设置窗口,依次设置好各个初始化参数:

    ③ 按上述设置新建的纯 .py 脚本,初始化内容会如图所示:

    我们重点来看下这段初始化代码

    if not cli_setup():
    auto_setup(__file__, logdir=True, devices=[
    "Android://127.0.0.1:5037/ZPFABE5DI7WWZLAM",
    ])

    这段初始化代码的意思是说,当使用 python xxx.py 来运行本文件,且不带任何命令行参数时,则自动使用 auto_setup 这个接口来对 Airtest 相关的参数进行初始化。这样只需要在写 .py 脚本时,填写好期望的参数就能直接用 python xxx.py 指令来运行脚本。

    如果是 python xxx.py --device xx --log xx 这种带命令行参数的,只要脚本检测到传入了命令行参数,就依然优先使用命令行参数来初始化 Airtest 相关的参数。


    2.详解auto_setup()里面的logdir和devices

    ① 设置脚本运行时的log保存路径--logdir

    logdir 的值必须为 True 或者是指定的具体保存路径。如果 logdir 的值为 None 的话,则默认在运行脚本时不保存log内容,也就是最终不能生成报告。

    如果将 logdir 的值设置为 True ,则表示将log内容保存在默认为 .py 文件所在目录下的 log/ 目录

    如果填写具体的保存路径,比如 E:/test/log,此时log内容就会被保存在指定目录下:

    ② 连接设备参数--devices

    在新建 .py 脚本时,这个 devices 参数一定要加上,你可以使用当前IDE已连接的设备进行初始化,也可以建完脚本之后,自己再手动添加上。

    如果没有在 .py 脚本中添加这个连接设备的参数,那么脚本内关于Airtest或者Poco的脚本将无法正常执行(敲黑板!最常见的就是下图这种情况):

    扩展阅读:Airtest API精讲之设备连接管理API集合


    3.生成纯.py脚本的报告

    生成纯 .py 脚本的报告有俩种方法,一种是借助IDE的 查看报告 按钮来生成;另一种是使用 simple_report() 方法生成报告。

    ① 借助IDE的 查看报告 按钮

    运行完 .py 脚本以后,点击IDE的 查看报告 按钮之后,会弹出一个提示框,让你选择log目录所在位置:

    此时你只需要选择初始化参数 logdir 所填写的路径,再点击OK即可。之后会在默认浏览器打开刚才的脚本运行报告。

    ② 使用 simple_report() 方法

    因 simple_report() 方法在 airtest.report.report 模块中,所以使用之前,我们需要把这个方法引入进来:

    # -*- encoding=utf8 -*-
    __author__ = "AirtestProject"

    from airtest.core.api import *
    from airtest.cli.parser import cli_setup

    if not cli_setup():
    auto_setup(__file__, logdir=True, devices=[
    "Android://127.0.0.1:5037/ZPFABE5DI7WWZLAM",
    ])

    snapshot(msg="请填写测试点.")

    # generate html report
    from airtest.report.report import simple_report
    simple_report(__file__)

    如果初始化的时候,logdir 的值为 True ,即log内容被保存在 .py 文件的log/目录下,则我们可以直接使用 simple_report(__file__) ,无需其它参数,即可帮助我们在 .py 文件所在目录生成脚本运行的报告 log.html:

    如果初始化的时候,logdir 的值为指定目录,则在 simple_report(__file__) 里面我们还需要加上以下参数:

    # -*- encoding=utf8 -*-
    __author__ = "AirtestProject"

    from airtest.core.api import *
    from airtest.cli.parser import cli_setup

    if not cli_setup():
    auto_setup(__file__, logdir="E:/test/log", devices=[
    "Android://127.0.0.1:5037/ZPFABE5DI7WWZLAM",
    ])

    snapshot(msg="请填写测试点.")

    # generate html report
    from airtest.report.report import simple_report
    simple_report(__file__,logpath="E:/test/log",output="E:/test/log/log.html")

    因为初始化的时候,我们把脚本保存目录用 logdir 参数指定为"E:/test/log",则在生成报告的时候,我们也要去找这个地址的log.txt,所以需要将 logpath 指定为"E:/test/log"。

    另外我们希望log.html,即网页版的报告也保存在此路径,所以我们将output也指定为 "E:/test/log/log.html"。

    那么我们可不可以不指定 output 地址呢?当然是可以的,如果我们没有指定 output 地址的话,将默认在 .py 脚本所在的目录下生成log.html:


    扩展阅读:Airtest通过代码生成报告——simple_report、LogToHtml详解

  • 相关阅读:
    iOS 键盘类型定制归纳
    CocoaPods安装第三方出错:XCode7.3
    NSIntger CGFloat NSNumber
    iOS 关于使用xib创建cell的两种初始化方式
    自定义导航栏--用法一
    CocoaPods的安装[转载]
    pch和info.plist初探
    iOS_XCode7_Launch Image 的初使用
    nginx四层负载及动静分离
    Nginx负载均衡
  • 原文地址:https://www.cnblogs.com/songzhenhua/p/16436180.html
Copyright © 2020-2023  润新知