引言
我们使用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)
执行结果:
感谢每一个认真阅读我文章的人!!!
作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。
文档获取方式:
加入我的软件测试交流群:632880530免费获取~(同行大佬一起学术交流,每晚都有大佬直播分享技术知识点)
这份文档,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!
以上均可以分享,只需要你搜索vx公众号:程序员雨果,即可免费领取
【软件测试行业现状】2023年了你还敢学软件测试?未来已寄..测试人该何去何从?【自动化测试、测试开发、性能测试】