IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> pytest中接口自动化测试用例,参数化的前后差别 -> 正文阅读

[开发测试]pytest中接口自动化测试用例,参数化的前后差别

在进行自动化测试用例设计的时候,随着测试用例的条数越来越多,如何能快速维护测试数据,是个必须要考虑的问题。

以用户登录login接口自动化测试为例,我设计了6个测试用例,其中2条是有效等价类,另外4个是无效等价类(这里仅是示例,真正的用例必然要比这个复杂的多)

一、未参数化时

未使用参数化时,用例可能是长这样的,看上去代码还算是清晰,但是呢,有如下2个大的弊端
1、6条测试用例,我要写6个测试函数才可以,代码有点长啊
2、若用户登录的接口有调整,6个测试函数都需要修改才行,效率很低

"""
对login接口进行测试,当用户数据在测试用例中时
"""

import pytest
from api.login import UserLogin


class TestLogin1 :

    @pytest.mark.level_1
    def test_1_usertype_88code(self) :
        actual_result = UserLogin.userLogin("annie", "123456")
        expert_result = "success"
        assert actual_result == expert_result

    @pytest.mark.level_1
    def test_1_usertype_mobile(self) :
        actual_result = UserLogin.userLogin("13356548888", "456789")
        expert_result = "success"
        assert actual_result == expert_result

    @pytest.mark.level_2
    def test_2_wrongPassword(self) :
        actual_result = UserLogin.userLogin("annie", "abcdef")
        expert_result = "error"
        assert actual_result == expert_result

    @pytest.mark.level_2
    def test_2_wrongUser(self) :
        actual_result = UserLogin.userLogin("sfsf54455545545445", "abcdef")
        expert_result = "error"
        assert actual_result == expert_result

    @pytest.mark.level_2
    def test_2_emptyUser(self) :
        actual_result = UserLogin.userLogin("", "abcdef")
        expert_result = "error"
        assert actual_result == expert_result

    @pytest.mark.level_2
    def test_2_emptyPassword(self) :
        actual_result = UserLogin.userLogin("annie", "")
        expert_result = "error"
        assert actual_result == expert_result

二、使用了参数化功能,但测试数据与测试代码未分离时

现在我用如下方法进行简单的参数化功能,由于其中2条是有效等价类,另外4个是无效等价类,所以我设计了两个测试函数,并使用mark进行标记,这样方便后续分组执行测试用例

"""
测试数据,使用参数化,但测试数据与测试代码未分离
"""

from api.login import UserLogin
import pytest

class TestLogin2 :

    @pytest.mark.level_1
    @pytest.mark.parametrize('username, password, expert_result',
                             [("annie", "123456", "success"),
                              ("13366288788", "456789", "success")
                              ])
    def test_1(self, username, password, expert_result) :
        actual_result = UserLogin.userLogin(username, password)
        assert actual_result == expert_result

    @pytest.mark.level_2
    @pytest.mark.parametrize('username, password, expert_result',
                             [("annie", "aaaaa", "error"),
                              ("sdfsfsdf", "123456", "error"),
                              ("", "123456", "error"),
                              ("annie", "", "error")
                              ])
    def test_2(self, username, password, expert_result) :
        actual_result = UserLogin.userLogin(username, password)
        assert actual_result == expert_result

如上所示,代码条数短了写,少了冗余的代码,但是呢,还有一个缺点,如果测试数据有变化,我还需要打开python文件,手动修改测试数据才可以,可能还涉及到了git发版的问题(如果公司是统一维护的代码),总之,不是很理想

三、使用了参数化功能,测试用例存储在mysql中

如下所示,我将测试数据存储在了mysql数据库中。
从当前看,是需要设计表,以及写mysql语句的,但是从长远看,就比较方便了。
如果这个用户不能用了,我只需连上mysql数据库,修改一下表里的用户记录就行了。如果需要新增其他用例,也可以在mysql直接操作,非常简单。

1、SQL语句,其中包含了测试用例的入参,以及期望测试结果

create table users(
id int auto_increment primary key, 
username varchar(100) not null, 
password varchar(100) not null,
expert_result varchar(100) not null,
level tinyint comment '1为有效等价类,2为无效等价类'
);

insert into users(username,password,expert_result,level) values
('annie','123456','success',1),
('13365588888','456789','success',1),
('annie','aaaa','error',2),
('sdfdsfsdfsfs','123456','error',2),
('annie','','error',2),
('','123456','error',2)

2、将从mysql中读取测试数据,写一个通用的方法,供所有其他测试class调用

import pymysql

class DbMysql:
    def __init__(self):
        self.connection = pymysql.connect(host="127.0.0.1",
                                  user="root",
                                  password="123456",
                                  database="test_login")

    def select(self,sql):
        with self.connection.cursor() as cursor:
            cursor.execute(sql)
            results = cursor.fetchall()
            return results

3、在测试login的文件中,从数据库中查询测试数据,进行参数化

"""
测试数据在mysql数据库中,进行参数化
"""

from api.login import UserLogin
from db_mysql.db_select import DbMysql
import pytest


def get_data(level) :
    sql = r"select username,password,expert_result from users where level = {0}".format(level)
    data = DbMysql().select(sql)
    return data

class TestLogin3 :

    @pytest.mark.level_1
    @pytest.mark.parametrize('username, password, expert_result', get_data(level=1))
    def test_1(self, username, password, expert_result) :
        actual_result = UserLogin.userLogin(username, password)
        assert actual_result == expert_result


    @pytest.mark.level_2
    @pytest.mark.parametrize('username, password, expert_result', get_data(level=2))
    def test_2(self, username, password, expert_result) :
        actual_result = UserLogin.userLogin(username, password)
        assert actual_result == expert_result
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-04-15 00:30:46  更:2022-04-15 00:33:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/18 0:21:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码