前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python 接口测试之接口关键字封装

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

作者头像
全栈测试开发日记
发布2023-02-18 12:21:17
6680
发布2023-02-18 12:21:17
举报

  引言

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

  接口关键字封装

  众所周知,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)

执行结果:

  总结

  以上就是针对接口测试用例关键字的封装实操,常量封装十分简单,关键在测试方法与思想。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-04-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  •   引言
  •   接口关键字封装
  •   实例演示
  •   总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档