Python 接口测试之接口关键字封装

引言

我们使用RF做UI自动化测试的时候,使用的是关键字驱动。同样,Python做接口自动化测试的时候,也可以使用关键字驱动。但是这里并不是叫关键字驱动,而是叫数据驱动。而接口测试的关键字是什么呢? 我们数据驱动的载体是Excel,那么excel里存放的数据是接口测试用例数据,一个接口数据里有常量和变量。变量就是一些参数对应的值,而常量就是接口的:host、path、method和data等等。而这些常量是固定不变的,我们可以将接口测试用例这些常量封装到一个类中,每次执行测试的时候,调用类中某个方法来读取excel中接口关键字对应的值。这些就称之为——关键字数据。

如果你想学习自动化测试,我这边给你推荐一套视频,这个视频可以说是B站播放全网第一的接口测试教程,同时在线人数到达1000人,并且还有笔记可以领取及各路大神技术交流:798478386 

B站讲的最详细的Python接口自动化测试实战教程全集(实战最新版)_哔哩哔哩_bilibiliB站讲的最详细的Python接口自动化测试实战教程全集(实战最新版)共计200条视频,包括:1、接口自动化之为什么要做接口自动化、2、接口自动化之request全局观、3、接口自动化之接口实战等,UP主更多精彩视频,请关注UP账号。https://www.bilibili.com/video/BV17p4y1B77x/?spm_id_from=333.337.search-card.all.click

接口关键字封装

众所周知,Excel中第一行字段的值都为固定的值,即常量。可以用这些常量来定位每一个测试用例不同字段的坐标值,将获取到的值传递给接口。

首先我们看看接口测试用例有哪些最主要的关键字常量:

上图基本上是接口测试用例关键的字段,当然可以根据自己项目需要自行添加。

我们在读取每条测试用例的时候,实际上是读取每行的数据,然后可以通过固定的关键字(列)来获取对应的值,最后传递给接口方法来执行接口测试。

封装如下:

class TestCaseKeyWord(object):
    """
    定义测试用例关键字类
    """
    CASE_ID = '0'
    CASE_NAME = '1'
    IS_EXECUTE = '2'
    INTERFACE_URL = '3'
    METHOD = '4'
    HEADER = '5'
    REQUEST_DATA  = '6'
    EXPECTED_RESULT = '7'
    ACTUAL_RESULT = '8'
    RESULT = '9'
 
# 获取用例id
def get_case_id():
    return TestCaseKeyWord.CASE_ID
 
# 获取用例名称
def get_case_name():
    return TestCaseKeyWord.CASE_NAME
 
# 用例是否执行
def get_case_is_execute():
    return TestCaseKeyWord.IS_EXECUTE
 
# 接口url
def get_case_interface_url():
    return TestCaseKeyWord.INTERFACE_URL
 
# 用例方法
def get_case_method():
    return TestCaseKeyWord.METHOD
 
# 请求头
def get_case_header():
    return TestCaseKeyWord.HEADER
 
# 请求参数
def get_case_payload():
    return TestCaseKeyWord.REQUEST_DATA
 
# 预期结果
def get_case_expected_result():
    return TestCaseKeyWord.EXPECTED_RESULT
 
# 实际结果
def get_case_actual_result():
    return TestCaseKeyWord.ACTUAL_RESULT
 
# 用例执行结果
def get_case_result():
    return TestCaseKeyWord.RESULT
 
 
if __name__ == '__main__':
    print(get_case_id())
    print(get_case_is_execute())

实例演示

在excel中添加一条测试用例:

新建testcase_test.py文件,获取接口测试用例名称:

from basic_method import testcases_keyword
from public.operate_excel import Operate_Excel
get_excel = Operate_Excel()
# 获取用例数
print(get_excel.get_sheet_nrows()-1)
# 返回用例名称关键字的列值
case_name_col = int(testcases_keyword.get_case_name())
print(case_name_col)
# 获取第一条用例的名称
get_name = get_excel.get_sheet_cell(1,case_name_col)
print(get_name)

执行结果:

总结

以上就是针对接口测试用例关键字的封装实操,常量封装十分简单,关键在测试方法与思想,更多自动化测试设计与想法,可以加入QQ测试开发交流群:798478386 ,一起讨论讨论,不积跬步无以至千里~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值