暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

pytest系列——assert断言

迅捷小莫 2021-09-02
1538

Pytest

自动化测试中 ,有一个很重要的概念——断言。那什么是断言呢?用大白话来讲 ,断言无非就是给你的测试下一个结论:PASS OR FAIL。这样我们才能在执行结果中判断出用例的执行成功或失败。

在我们使用pytest的过程中,之前也提到过 用例的几种状态,分别是passed,failed,skipped,xpassed,xfailed。我们通常需要给每个用例添加断言,以保证我们用例执行的正确性。在pytest中,我们通常直接使用python自带的assert关键字。

01

为什么需要断言?

在此前经常碰到有些同学对断言的概念并不清晰,我们来看看下面的代码:

    import pytest  # 导入pytest




    def test_001():
       print("test_001 done")
       assert False  # 添加断言,使其失败




    def test_002():
       print("test_002 done")
       print("test failed")  # 打印失败
       return False  # 返回错误




    if __name__ == '__main__':  # 定义主函数
       pytest.main()  # 调用pytest

    我们分别给两个测试函数,一个使用了断言(assert False,一定会失败),一个使用了return False。那这两个执行结果有什么区别呢?往下看:

    test_001报错,而test_002没有报错,这是为什么呢?可能某些初学者会有这样的疑惑,pytest是根据什么来判断你的用例是失败的呢?

    1. 用例执行过程有错误产生,这种错误通常是代码错误导致的问题,pytest会记录状态为FAILED

    2. 发生了断言失败,记录为 FAILED

    但是,实际上这两种是属于一种情况,因为我们如果发生断言错误,系统会抛出AssertionError:

    所以总的来说,即如果运行过程中,发生了代码异常,pytest认为那就是用例执行失败

    02

    怎么合理使用断言?

    首先,我们要明确自己的测试目标是什么,比如是跑接口自动化,或者ui自动化,或者一些单元测试。第二,我们要明确什么可以代表测试用例“真正成功”。什么叫真正成功,难道还有假的成功不成?小提莫想说,确实有。

    举个例子,我们现在想测试一个登入接口,login,接口文档如下:

    登入接口文档

    接口地址:/apis/login

    请求方式:POST

    请求格式:application/json

    请求参数:

    字段

    说明

    类型

    是否必填

    username

    账号

    String

    password

    密码

    String

    响应参数:

    字段

    说明

    类型

    备注

    success

    是否成功 

    Boolean

    true

    false

    code

    响应码

    Integer

        0 登入成功

        101 密码错误

        102 账号不存在

       103 账号密码为空

    msg

    提示信息

    String

    1. 登入成功

    2. 密码错误

    3. 账号不存在

    4. 账号密码为空

    可以看到上面的文档,我们在写接口测试用例的时候,需要对它怎么进行断言呢?

    首先,断言和我的输入肯定是匹配的,断言其实就是我的预期结果,也就是我们黑盒测试中描述的那样:

    我们向我们的测试对象(此时是login接口)输入x, y参数,那我们就会得到一个z的响应。比如我x, y分别代表账号和密码,那我此刻可以改变我的x, y的参数,得到不同的响应。所以在测试之前,我已经知道我想要的是什么了 (指的是断言)。比如x, y是正确的账号密码,那我的断言即为“登入成功”。输入密码错误,则为“密码错误”。如下图:

    所以我们理清思路,转化成代码:

      import pytest
      import requests


      user, pwd = ('admin', 123456)




      def test_login_success():
         """
         登入成功
         :return:
         """
         json = {
             "username": "admin",
             "password": 123456
         }
         response = requests.post(url='apis/login', json=json).json()
         assert response['msg'] == "登入成功"




      def test_login_pwd_error():
         """
         密码错误
         :return:
         """
         json = {
             "username": "admin",
             "password": 12345
         }
         response = requests.post(url='apis/login', json=json).json()
         assert response['msg'] == "密码错误"




      def test_login_usr_not_exist():
         """
         账号不存在
         :return:
         """
         json = {
             "username": "admin",
             "password": 12345
         }
         response = requests.post(url='apis/login', json=json).json()
         assert response['msg'] == "账号不存在"

      我们只需要拿到msg来做断言即可,当然也可以用code也是可以的。

      不过在断言的时候,我发现有的朋友会使用HTTP STATUS CODE来做断言,这个也就是我们常说的HTTP状态码,可能有的小伙伴会判断CODE=200, 那这种是非常不正确的做法,也就是小提莫前面提到的“真正成功”,它显然是不符合的。因为状态码200仅仅是代表接口通畅,而并非业务成功!我们一定要使用接口的业务字段 进行断言,才算达到要求的断言。

      那本期内容介绍了如何使用断言,也终于把很多人的疑惑解开,到底怎么使用断言现在终于懂了呐。

      see you later.

      扫码关注哦~


      文章转载自迅捷小莫,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

      评论