软件测试/测试开发丨接口自动化测试学习笔记,数据库操作与断言

一、接口测试响应验证

如何在测试过程中验证接口没有 Bug?

  1. 通过接口响应值
  2. 通过查询数据库信息辅助验证

二、接口测试数据清理

自动化测试中会产生大量的脏数据,该如何清理?

  • 通过调用delete接口删除
  • 自动化测试使用干净的测试环境,每次自动化测试完成后,还原数据。

三、数据库操作注意事项

  • 直接对数据库操作是非常危险的行为
  • 权限管理严格的公司对数据库权限给的很低
  • 表结构复杂,随便删除数据会影响功能异常,甚至会出现系统异常。

四、接口自动化测试常用的数据库操作

  • 连接与配置
  • 查询数据与断言

4.1、数据库封装(Python)

  • 封装数据库配置
  • 封装 sql 查询操作
  • 调用方法执行 sql 语句
python 复制代码
class Mysql:
    @classmethod
    def connect(cls):
        mysql_info = {
            "host": "litemall.hogwarts.ceshiren.com",
            "port": 13306,
            "user": "test",
            "password": "test123456",
            "database": "litemall",
            "charset": "utf8mb4"
        }
        conn = pymysql.Connect(**mysql_info)
        return conn

    @classmethod
    def execute(cls, sql):
        cnn = cls.connect()
        sor = cnn.cursor()
        sor.execute(sql)
        res = sor.fetchall()
        sor.close()
        cnn.close()
        return res

4.2、数据库断言

python 复制代码
    def test_cart_add(self, good_sn='CC102101'):
        """测试添加购物车功能"""
        with allure.step("获取商品的id"):
            ids = self.good.id(good_sn)
        with allure.step("获取商品的good_id和product_id"):
            good_id = ids[0]
            product_id = ids[1]
        sql = f"""                 
        SELECT number FROM litemall_cart where goods_sn='{good_sn}' and goods_id='{good_id}'
        """
        good_num1 = Mysql.execute(sql)[0][0]
        print(good_num1)
        with allure.step("添加商品到购物车"):
            print(self.cart.add(good_id, product_id))
        good_num2 = Mysql.execute(sql)[0][0]
        print(good_num2)
        assert good_num2 - good_num1 == 1

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
玄米乌龙茶12312 小时前
项目开发学习笔记
笔记·学习
zhishijike12 小时前
全国行政区划sql(省市区)
数据库·sql·mysql
KaMeidebaby12 小时前
卡梅德生物技术快报|单 B 细胞抗体技术:全犬源单抗制备流程、关键参数与性能验证
前端·数据库·其他·百度·新浪微博
KG_LLM图谱增强大模型12 小时前
scHilda:大模型与知识图谱分层融合,突破单细胞分型瓶颈
数据库·人工智能·知识图谱
凯瑟琳.奥古斯特12 小时前
力扣3654:二维矩阵连续空位统计
数据结构·数据库·算法·职场和发展
闫记康13 小时前
Linux学习day3
linux·服务器·学习
满昕欢喜13 小时前
SQL Server的概述与安装
数据库·sqlserver
2501_9307077813 小时前
使用C#代码在 Excel 中为数据透视表添加筛选器
数据库·数据挖掘·数据分析
TDengine (老段)13 小时前
TDengine 数据库创建与参数详解
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
测试员周周13 小时前
【AI测试路线图2】功能测试转 AI 测试:4~5 个月,一条最稳的路
开发语言·人工智能·python·功能测试·测试工具·单元测试·pytest