接口自动化测试思路和实战之手把手【编写线性测试脚本实战 】

接口自动化测试框架目的

测试工程师应用自动化测试框架的目的: 增强测试脚本的可维护性、易用性(降低公司自动化培训成本,让公司的测试工程师都可以开展自动化测试)。

以下框架以微信公众平台开放文档实战

地址:https://developers.weixin.qq.com/doc/offiaccount/Getting_Started/Overview.html

自动化测试框架根据思想理念和深度不同,渐进式的分为以下几种:

线性脚本框架

模块化思想==>模块化测试脚本框架

库思想==>测试库框架。

数据驱动思想==>数据驱动测试框架

关键字驱动思想==>关键字驱动或表驱动的测试框架

上述思想融合完成企业实际自动化==>混合测试自动化框架

编写线性测试脚本实战

接口用例excel;

步骤1、新建项目名API_TEST_FRAME,在项目的下面新建不同层级;如下图

步骤2、根据接口文档的层级,在项目中的testcase层下新建层级;如下图

步骤3、在begin_dev下新建test_get_access_token_api.py文件,并编写代码

 编写代码:

 
  1. # encoding: utf-8

  2. # @author: Jeffrey

  3. # @file: test_get_access_token_api.py

  4. # @time: 2022/7/24 18:08

  5. # @desc: 导入模块顺序:内置模块、第三方模块、自定义模块

  6. import unittest

  7. import requests

  8. import jsonpath

  9. class TestGetAccessTokenApi(unittest.TestCase):

  10. def setUp(self) -> None:

  11. self.session = requests.session()

  12. def tearDown(self) -> None:

  13. self.session.close()

  14. def test_case_01(self):

  15. '''[api_case_01] 测试获取access_token能否正常调用'''

  16. url_params = {"grant_type":"client_credential",

  17. "appid":"wxf14419077f707856",

  18. "secret":"92a113bd4b5ffdc72144740dc7123c99"}

  19. response = self.session.get(url="https://api.weixin.qq.com/cgi-bin/token",

  20. params = url_params)

  21. # 获取响应json中的access_token的值

  22. actual_result = jsonpath.jsonpath(response.json(), "$.access_token")

  23. print(actual_result)

  24. self.assertTrue(actual_result, "api_case_01 执行失败") #非空,非0 都返回True为真

  25. def test_case_02(self):

  26. '''[api_case_02] 测试获取access_token接口在appid错误时,能否正常处理错误'''

  27. url_params = {"grant_type":"client_credential",

  28. "appid":"wxf14419077f707",

  29. "secret":"92a113bd4b5ffdc72144740dc7123c99"}

  30. response = self.session.get(url="https://api.weixin.qq.com/cgi-bin/token",

  31. params = url_params)

  32. # 获取响应json中的errcode的值,因为jsonpath返回的是列表,故加上下标0

  33. actual_result = jsonpath.jsonpath(response.json(), "$.errcode")[0]

  34. print(actual_result)

  35. self.assertEqual(actual_result,40013, "api_case_02 执行失败")

  36. if __name__ == '__main__':

  37. unittest.main(verbosity=2)

执行查看结果:

步骤4、按照开发文档中的用户标签管理,新建test_create_user_tag_api.py文件

 编写代码:

 
  1. # encoding: utf-8

  2. # @author: Jeffrey

  3. # @file: test_create_user_tag_api.py

  4. # @time: 2022/7/24 19:02

  5. # @desc:

  6. import unittest

  7. import requests

  8. import jsonpath

  9. import json

  10. class TestCreateUserTagApi(unittest.TestCase):

  11. def setUp(self) -> None:

  12. self.session = requests.session()

  13. def tearDown(self) -> None:

  14. self.session.close()

  15. def test_case_01(self):

  16. '''[api_case_03] 测试正常进行创建标签接口调用'''

  17. url_params = {"grant_type":"client_credential",

  18. "appid":"wxf14419077f707856",

  19. "secret":"92a113bd4b5ffdc72144740dc7123c99"}

  20. response = self.session.get(url="https://api.weixin.qq.com/cgi-bin/token",

  21. params = url_params)

  22. # 获取响应json中的access_token的值

  23. token_value = jsonpath.jsonpath(response.json(), "$.access_token")[0]

  24. tag_url_params = {"access_token":token_value}

  25. tag_boby = { "tag": { "name":"深圳人2" } }

  26. # 解决中文乱码问题;模拟post请求时,携带json 数据包含中文发送给服务器会转码

  27. # 方式一:json.dumps()

  28. tag_str = json.dumps(tag_boby, ensure_ascii=False)

  29. response = self.session.post(url="https://api.weixin.qq.com/cgi-bin/tags/create",

  30. params = tag_url_params,

  31. data=tag_str.encode('utf-8'))

  32. print(response.json())

  33. # # 方式二:修改requests中的models.py中的源码,修改完后

  34. # response = self.session.post(url="https://api.weixin.qq.com/cgi-bin/tags/create",

  35. # params=tag_url_params,

  36. # json=tag_boby)

  37. # print(response.json())

  38. # 获取响应json的tag的name值,因为jsonpath返回的是列表,故加上下标0

  39. actual_result = jsonpath.jsonpath(response.json(), "$.tag.name")[0]

  40. self.assertEqual(actual_result,"深圳人2", "api_case_03 执行失败")

  41. if __name__ == '__main__':

  42. unittest.main(verbosity=2)

Requests模拟post请求时,如何处理携带json 数据包含中文发送给服务器会转码的问题?

方式一:如下图

方式二:如下图

执行结果

继续新建test_update_user_tag_api.py文件和test_delete_user_tag_api.py文件;自己拓展

步骤5、把用例整合一起执行,在runner文件下的run_api_tests.py中编写代码:

 编写代码:

 
  1. # encoding: utf-8

  2. # @author: Jeffrey

  3. # @file: run_api_tests.py

  4. # @time: 2022/7/24 17:52

  5. # @desc:

  6. import os

  7. import unittest

  8. # 获取当前路径

  9. current_path = os.path.dirname(os.path.abspath(__file__))

  10. # 测试用例路径

  11. case_path = os.path.join(current_path, '../testcases')

  12. discover_obj = unittest.defaultTestLoader.discover(start_dir=case_path,

  13. pattern='test*.py')

  14. all_case_suite = unittest.TestSuite()

  15. # 把discover对象发现的用例加载到测试套件中

  16. all_case_suite.addTest(discover_obj)

  17. unittest.main(defaultTest="all_case_suite", verbosity=2)

查看执行结果:

步骤6、生成测试报告,把HTMLTestReportCN.py文件放到common文件夹中并在run_api_tests.py文件中调整代码;

 编写代码:

 
  1. # encoding: utf-8

  2. # @author: Jeffrey

  3. # @file: run_api_tests.py

  4. # @time: 2022/7/24 17:52

  5. # @desc:

  6. import os

  7. import unittest

  8. from common import HTMLTestReportCN

  9. # 获取当前路径

  10. current_path = os.path.dirname(os.path.abspath(__file__))

  11. # 测试用例路径

  12. case_path = os.path.join(current_path, '../testcases')

  13. discover_obj = unittest.defaultTestLoader.discover(start_dir=case_path,

  14. pattern='test*.py')

  15. all_case_suite = unittest.TestSuite()

  16. # 把discover对象发现的用例加载到测试套件中

  17. all_case_suite.addTest(discover_obj)

  18. # unittest.main(defaultTest="all_case_suite", verbosity=2)

  19. report_path = os.path.join(current_path, '../reports/result.html')

  20. html_file_obj = open(report_path, 'wb')

  21. html_runner = HTMLTestReportCN.HTMLTestRunner(stream=html_file_obj,

  22. title='接口接口自动化测试',

  23. tester='YOU',

  24. description='学习接口框架')

  25. html_runner.run(all_case_suite)

执行后查看报告:

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

 

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取   

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值