• 【第九章】引入HTMLTestReportCN测试报告模块,添加日志模块


    • 引入测试报告

    # -*- coding: utf-8 -*-
    # @Time : 2021/12/22 14:13
    # @Author : Limusen
    # @File : main
    
    """
    
    测试用例的运行入口
    
    """
    
    import os
    import unittest
    from common.config_utils import local_config
    from common import HTMLTestReportCN
    
    current = os.path.dirname(os.path.abspath(__file__))
    case_path = os.path.join(current, local_config.CASE_PATH)  # 在ini文件写入测试用例地址
    report_path = os.path.join(current, local_config.REPORT_PATH)  # 在ini文件写入测试报告地址
    
    
    def load_api_case():
        discover_obj = unittest.defaultTestLoader.discover(start_dir=case_path,
                                                           pattern='test_api_case.py')
        all_case_suite = unittest.TestSuite()
        all_case_suite.addTest(discover_obj)
        return discover_obj
    
    
    # 创建网页版报告路径的对象
    report_path_obj = HTMLTestReportCN.ReportDirectory(report_path)
    # 创建报告
    report_path_obj.create_dir("接口测试报告")
    # 获取网页版报告的路径
    html_report_obj = HTMLTestReportCN.GlobalMsg.get_value("report_path")
    # print(html_report_obj)
    html_report_file_obj = open(html_report_obj, 'wb')
    runner = HTMLTestReportCN.HTMLTestRunner(stream=html_report_file_obj,
                                             tester="me",
                                             description="接口测试框架报告")
    runner.run(load_api_case())



    • 优化代码添加日志信息

    check_utils.py 模块增加日志

    # -*- coding: utf-8 -*-
    # @Time : 2021/12/13 14:07
    # @Author : Limusen
    # @File : check_utils
    
    import json
    import re
    from common.logs_utils import logger
    
    
    class CheckUtils:
    
        def __init__(self, response_data):
            """
            :param response_data: 响应结果
            """
            self.response_data = response_data
            self.function = {
                "none": self.none_check,
                "json_key": self.key_check,
                "json_key_value": self.key_value_check,
                "body_regexp": self.body_regexp_check,
                "header_key_check": self.header_key_check,
                "header_key_value_check": self.header_key_value_check,
                "response_code_check": self.response_code_check
            }
            self.pass_result = {  # 通过结果
                "code": 0,
                "response_code": self.response_data.status_code,
                "response_reason": self.response_data.reason,
                "response_headers": self.response_data.headers,
                "response_body": self.response_data.text,
                "message": "测试用例执行通过",
                "check_result": True
            }
            self.fail_result = {  # 失败结果 2 表示断言失败
                "code": 2,
                "response_code": self.response_data.status_code,
                "response_reason": self.response_data.reason,
                "response_headers": self.response_data.headers,
                "response_body": self.response_data.text,
                "message": "测试用例断言失败,测试用例执行不通过",
                "check_result": False
            }
    
        def none_check(self):
            """
            断言类型为空的情况
            :return:
            """
            logger.info("断言类型 [none],不进行断言,本次断言通过")
            return self.pass_result
    
        def key_check(self, check_data):
            """
            检查键是否相同
            :param check_data: 需要检查的字段,注意得是字符串才行,因为要分割
            :return: True说明断言成功,False说明断言失败
            """
            # 字符串逗号分割
            key_list = check_data.split(",")
            tmp_result = []
            # 取出需要断言的字段
            for check_key in key_list:
                # 如果 check_key 在json串的键当中,则添加True,不是则添加False
                if check_key in self.response_data.json().keys():
                    tmp_result.append(True)
                else:
                    tmp_result.append(False)
            if False in tmp_result:
                logger.error('断言类型 [key_check] ==》实际结果:{}, 期望结果:{} 不相符,断言失败'.format(self.response_data.text, check_data))
                # 只要有一个不符合 用例全部失败
                return self.fail_result
            else:
                logger.info("断言类型 [key_check],检查键值,实际结果:{}, 期望结果:{} 相符,断言成功".format(self.response_data.text, check_data))
                return self.pass_result
    
        def key_value_check(self, check_data):
            """
            检查键值对是否一致
            :param check_data:
            :return:
            """
            key_dict = json.loads(check_data)
            tmp_result = []
    
            for check_key in key_dict.items():
                if check_key in self.response_data.json().items():
                    tmp_result.append(True)
                else:
                    tmp_result.append(False)
            if False in tmp_result:
                logger.error(
                    '断言类型 [key_value_check] ==》实际结果:{}, 期望结果:{} 不相符,断言失败'.format(self.response_data.text, check_data
                                                                                 ))
                return self.fail_result
            else:
                logger.info('断言类型 [key_value_check] ==》实际结果:{}, 期望结果:{} 相符,断言成功'.format(self.response_data.text, check_data))
    
                return self.pass_result
    
        def body_regexp_check(self, check_data):
            """
            根据正则表达式断言
            :param check_data:
            :return:
            """
            if re.findall(check_data, self.response_data.text):
                # 能找到check_data的值则算通过
                logger.info(
                    '断言类型 [body_regexp_check] ==》实际结果:{}, 期望结果:{} 相符,断言成功'.format(self.response_data.text, check_data
                                                                                  ))
                return self.pass_result
            else:
                logger.error(
                    '断言类型 [body_regexp_check] ==》实际结果:{}, 期望结果:{} 不相符,断言失败'.format(self.response_data.text, check_data
                                                                                   ))
                return self.fail_result
    
        def header_key_check(self, check_data):
            """
            检查头部信息是否包含某个值  可以参照key_check()
            :param check_data:
            :return:
            """
            # 字符串逗号分割
            key_list = check_data.split(",")
            tmp_result = []
            # 取出需要断言的字段
            for check_key in key_list:
                # 如果 check_key 在json串的键当中,则添加True,不是则添加False
                if check_key in self.response_data.headers.keys():
                    tmp_result.append(True)
                else:
                    tmp_result.append(False)
            if False in tmp_result:
                logger.error(
                    '断言类型 [header_key_check] ==》实际结果:{}, 期望结果:{} 不相符,断言失败'.format(self.response_data.text, check_data
                                                                                  ))
                # 只要有一个不符合 用例全部失败
                return self.fail_result
            else:
                logger.info(
                    '断言类型 [header_key_check] ==》实际结果:{}, 期望结果:{} 相符,断言成功'.format(self.response_data.text, check_data
                                                                                 ))
                return self.pass_result
    
        def header_key_value_check(self, check_data):
            """
            检查头部键值对是否一致 参照key_value_check()
            :param check_data:
            :return:
            """
            key_dict = json.loads(check_data)
            tmp_result = []
    
            for check_key in key_dict.items():
                if check_key in self.response_data.headers.items():
                    tmp_result.append(True)
                else:
                    tmp_result.append(False)
            if False in tmp_result:
                logger.error(
                    '断言类型 [header_key_value_check] ==》实际结果:{}, 期望结果:{} 不相符,断言失败'.format(self.response_data.text, check_data
                                                                                        ))
                # 只要有一个不符合 用例全部失败
                return self.fail_result
            else:
                logger.info(
                    '断言类型 [header_key_value_check] ==》实际结果:{}, 期望结果:{} 相符,断言成功'.format(self.response_data.text, check_data
                                                                                       ))
                return self.pass_result
    
        def response_code_check(self, check_data):
            """
            检查返回状态码
            :param check_data:
            :return:
            """
            if self.response_data.status_code == int(check_data):
                logger.info(
                    '断言类型 [__response_code_check] ==》实际结果:{}, 期望结果:{} 相符,断言成功'.format(self.response_data.text, check_data
                                                                                      ))
                return self.pass_result
            else:
                logger.error(
                    '断言类型 [__response_code_check] ==》实际结果:{}, 期望结果:{} 不相符,断言失败'.format(self.response_data.text, check_data
                                                                                       ))
                return self.fail_result
    
        def run_check(self, check_type, except_result):
            """
            :param check_type: 检查的类型
            :param except_result: 检查的字段
            :return:
            """
            if check_type == "none" or except_result == "":
                return self.function["none"]()
            else:
                return self.function[check_type](except_result)
    
    
    if __name__ == '__main__':
        import requests
    
        url = "https://api.weixin.qq.com/cgi-bin/token"
        get_params = {"grant_type": "client_credential", "appid": "wxb637f897f0bf1f0d",
                      "secret": "501123d2d367b109a5cb9a9011d0f084"}
    
        response = requests.get(url=url, params=get_params)
        # print(response.headers)
    
        ck = CheckUtils(response)
        print(ck.none_check())
        print(ck.run_check('json_key', "access_token,expires_in"))
        print(ck.run_check('json_key_value', '{"expires_in": 7200}'))
        print(ck.run_check("body_regexp", '"access_token":"(.+?)"'))
        print(ck.run_check("header_key_check", "Connection"))
        print(ck.run_check("header_key_value_check", '{"Connection": "keep-alive"}'))
        print(ck.run_check("response_code_check", "200"))

    自此所有的代码编写完毕,只需要修改excel就可以完成接口测试

  • 相关阅读:
    【Qt】splitter
    android 使用AsyncHttpClient框架上传文件以及使用HttpURLConnection下载文件
    poj 1879 Truck History
    在LinuxMint中对firefox进行手动安装flash插件
    王立平--include在Android中的应用
    【IPC进程间通讯之二】管道Pipe
    我组织类时无意间遵守了依赖倒置原则
    百度2016笔试(算法春招实习)
    制作翻转效果动画
    vim常用命令行备忘总结
  • 原文地址:https://www.cnblogs.com/yushengaqingzhijiao/p/15719476.html
Copyright © 2020-2023  润新知