python+appium自动化测试-pytest+allure测试报告(一)

来自APP Android端自动化测试初学者的笔记,写的不对的地方大家多多指教哦 之前发布的python+appium自动化测试-pytest+allure测试报告(一)这篇文章由于部分内容有误,修改并补充后现在重新发布

目录

        一、Allure安装

        二、生成json格式的测试报告

方法一:在终端(terminal),生成json格式测试报告

方法二:在测试用例配置Additional Arguments,生成json格式测试报告

三、测试报告由json格式转换为html格式

四、Allure相关注解


一、Allure安装

1、pytest和allure插件安装

pip install allure-pytest
pip install pytest

2、Allure帮助文档

https://docs.qameta.io/allure/#_about

3、Allure安装
a.scoop install allure b.使用安装包安装

  • allure2下载下来是一个zip的压缩包,我们要解压至自己的文件目录下(可解压放至项目的测试用例下或python安装目录下),自己可找到文件即可。
  • 打开allure2目录,找到bin目录,复制bin文件目录, 然后进行环境变量的配置,设置环境变量的目的就是让系统无论在哪个目录下都可以运行allure2。
  • 环境变量设置:(桌面——我的电脑——右键属性——高级系统配置——环境变量——系统变量——Path——编辑环境变量——把我们上面复制的目录路径新增至环境变量中即可)

  • 配置好后,打开cmd终端,输入allure,出现以下帮助文档,就说明配置成功了。

若后续有新版本,建议使用最新的版本

二、生成json格式的测试报告

运行环境:

  • 设备:U4AIUKFAL7W4MJLR
  • 测试app:微博APP(V10.12.0)Andriod版
  • 测试功能:账号密码登录

方法一:在终端(terminal),生成json格式测试报告

终端(terminal)输入以下内容,运行

pytest 运行的py文件 --alluredir=测试报告存放地址
例如:
pytest add_weibo_test.py --alluredir=../report/json

运行测试用例,在测试报告存放位置会生成一份或多份json或xml格式的测试报告

方法二:在测试用例配置Additional Arguments,生成json格式测试报告

1.选择需要运行的测试用例,右键点击Create Run Configuration:"测试用例文件名“

2.进入后在Additional Arguments输入:- -alluredir=生成的json格式测试报告存放的位置

3.设置完后,点击APPLY→OK,在测试函数中运行测试文件

运行后在测试报告存放位置会生成一份或多份json或xml格式的测试报告

三、测试报告由json格式转换为html格式

在终端(terminal)转换
1.测试用例运行完成生成json格式的测试报告后,打开terminal,输入命令:

allure generate ./report/ -o ./report/html --clean

./report/:表示执行需要转换的文件所在的位置,需要转换的文件在report文件夹中
./report/html:表示转换成功的html文件存放的位置,即存放在report下的html文件夹中
--clean:表示清除之前的测试报告,因为重复生成相同的测试报告会报错

注意:在terminal可以通过cd返回上一级或进入其它文件
2.执行完成后,在report文件夹下会生成一个html文件,在html目录下会生成index.html文件,即为可视化报告,如下图所示

3.打开html文件,右键点击index.html文件,选择open in Broswer,选择Chrome浏览器,如下图

4.谷歌浏览器打开后的测试报告图片呈现为下图:

四、Allure相关注解

1. @allure.feature:用于描述被测试产品需求
2. @allure.story:用于描述feature的用户场景,即测试需求,与feature是父子关系
3. @allure.title:用户描述测试用例的标题,不设置默认为用例名称
4. @allure.description:用于对测试用例的一些附加描述
5. @allure.step:用于将一些通用的函数作为测试步骤输出到报告,调用此函数的地方会向报告中输出步骤

  • with allure.step:用于描述测试步骤,将会输出到报告中
  • allure.attach:用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等

代码如下:

# 手机账号密码登录测试用例
import allure
import pytest
from common.init import AppStart

@allure.feature("这是测试feature")
class TestAccountPwd:
    def setup_class(self):
        self.account_login_page = AppStart.start().enter_account_login()

    @allure.story("story_one")
    @allure.title("title_one")
    def test_one(self):
        with allure.step("step--输入账号"):
            allure.attach("123123231321313", "账号")
            account = "123123231321313"
        with allure.step("step--输入密码"):
            pwd = "asdfgh"
            self.account_login_page.input_account_pwd(account, pwd)
        with allure.step("step--断言"):
            allure.attach("手机格式有问题,若非中国大陆手机号码请点击国际手机登录", "期望结果")
            assert self.account_login_page.get_bounced_context() == "手机格式有问题,若非中国大陆手机号码请点击国际手机登录"
            print("\naccount的值:", account, "\npwd的值:", pwd)

    @allure.story("story_two")
    @allure.title("title_two")
    @allure.step("这是测试step")
    def test_two(self):
        account = "w124hhh77"
        pwd = "asdfg"
        self.account_login_page.input_account_pwd(account, pwd)
        assert self.account_login_page.get_bounced_context() == "你尚未注册微博,是否立即注册"
        print("\naccount的值:", account, "\npwd的值:", pwd)

    @allure.story("story_three")
    @allure.title("title_three")
    def test_three(self):
        account = "hhhhhhhhh"
        pwd = "asdfg"
        self.account_login_page.input_account_pwd(account, pwd)
        assert self.account_login_page.get_bounced_context() == "你尚未注册微博,是否立即注册"
        print("\naccount的值:", account, "\npwd的值:", pwd)

    @allure.story("story_four")
    @allure.title("title_four")
    @allure.description("description")
    def test_four(self):
        account = "15059941156"
        pwd = "123123"
        self.account_login_page.input_account_pwd(account, pwd)
        assert self.account_login_page.get_account_pwd_tips() == "帐号或密码错误"
        print("\naccount的值:", account, "\npwd的值:", pwd)

    def teardown_class(self):
        AppStart.quit()

if __name__ == '__main__':
    pytest.main(["account_pwd_test.py"])

1.@allure.feature、@allure.story、@allure.title结果如下:

2.@allure.description结果如下

3.@allure.step结果如下:

4.with allure.step和allure.attach结果如下:

感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以点击下方链接直接免费拿走:

 如果有需要点击链接直接拿走icon-default.png?t=M4ADhttp://47.107.116.139/zhuoran/mf.php

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值