Пример #1
0
 def setUpClass(cls) -> None:
     cls.filename = os.path.join(LOGS_DIR,
                                 do_config("file_path", "log_path"))
     cls.file = open(cls.filename, mode="a", encoding="utf-8")
     do_log.info("{}".format("开始执行投资功能用例"))
     cls.do_request = HttpRequest()
     cls.do_mysql = HandleMysql()
Пример #2
0
    def test_add(self, data_namedtuple):
        case_id = data_namedtuple.case_id + 1
        title = data_namedtuple.title
        new_data = HandleParameter.add_parameter(data_namedtuple.data)

        response = TestAdd.do_request(method=data_namedtuple.method,
                                      url=do_config("api", "prefix_url") +
                                      data_namedtuple.url,
                                      data=new_data)

        run_success_msg = do_config("msg", "success_result")
        run_fail_msg = do_config("msg", "fail_result")

        try:
            self.assertEqual(data_namedtuple.expected,
                             response.text,
                             msg="测试【{}】失败".format(title))
        except AssertionError as e:
            do_log.error("{},测试结果为:{}\n,具体异常信息为{}".format(
                title, run_fail_msg, e))
            self.parser_excel.write_result_to_excel(row=case_id,
                                                    actual=response.text,
                                                    result=run_fail_msg)
            raise e
        else:
            do_log.info("{},测试结果为:{}".format(title, run_success_msg))
            self.parser_excel.write_result_to_excel(row=case_id,
                                                    actual=response.text,
                                                    result=run_success_msg)
Пример #3
0
 def tearDownClass(cls) -> None:
     """
     后置处理操作:
     :return:
     """
     do_log.info("{}".format("登录功能用例执行结束"))
     cls.do_request.close()
Пример #4
0
 def setUpClass(cls) -> None:
     """
     前置处理操作
     :return:
     """
     cls.filename = LOGS_DIR + r"\\" + do_config("file_path", "log_path")
     cls.file = open(cls.filename, mode="a", encoding="utf-8")
     do_log.info("{}".format("开始执行登录功能用例"))
     cls.do_request = HttpRequest()
Пример #5
0
    def test_recharge(self, data_namedtuple):
        run_success_msg = do_config("msg", "success_result")
        run_fail_msg = do_config("msg", "fail_result")
        case_id = data_namedtuple.case_id+1
        title = data_namedtuple.title
        new_data = json.loads(HandleParameter.recharge_parameter(data_namedtuple.data))
        check_sql = data_namedtuple.check_sql
        if check_sql:
            leaveAmount_before_recharge = TestRecharge.do_mysql(check_sql, args=(new_data["mobilephone"], ))

        response = TestRecharge.do_request(method=data_namedtuple.method,
                                           url=do_config("api", "prefix_url")+data_namedtuple.url,
                                           data=new_data)
        actual = json.loads(response.text)
        actual["data"] = None

        try:
            self.assertEqual(200, response.status_code, msg="测试【{}】时,请求失败,状态码为【{}】".
                             format(title, response.status_code))
        except AssertionError as e:
            do_log.error("具体异常信息为:".format(e))
            raise e

        try:
            self.assertEqual(json.loads(data_namedtuple.expected),
                             actual,
                             msg="测试【{}】失败".format(title))
            if check_sql:
                leaveAmount_after_recharge = TestRecharge.do_mysql(check_sql, args=(new_data["mobilephone"],))
                actual_amount = leaveAmount_after_recharge["LeaveAmount"] - leaveAmount_before_recharge["LeaveAmount"]
                self.assertEqual(float(new_data["amount"]),
                                 round(float(actual_amount)),
                                 msg="充值金额有误")

        except AssertionError as e:
            do_log.error("{},测试结果为:{}\n,具体异常信息为{}".format(title, run_fail_msg, e))
            self.parser_excel.write_result_to_excel(row=case_id, actual=response.text, result=run_fail_msg)
            raise e
        else:
            do_log.info("{},测试结果为:{}".format(title, run_success_msg))
            self.parser_excel.write_result_to_excel(row=case_id, actual=response.text, result=run_success_msg)
Пример #6
0
    def test_invest(self, data_namedtuple):
        case_id = data_namedtuple.case_id + 1
        title = data_namedtuple.title
        new_data = HandleParameter.invest_parameter(data_namedtuple.data)

        response = TestInvest.do_request(method=data_namedtuple.method,
                                         url=do_config("api", "prefix_url") +
                                         data_namedtuple.url,
                                         data=new_data)

        run_success_msg = do_config("msg", "success_result")
        run_fail_msg = do_config("msg", "fail_result")
        """反射"""
        if response.json().get("msg") == "加标成功":
            check_sql = data_namedtuple.check_sql
            if check_sql:
                check_sql = HandleParameter.invest_parameter(check_sql)
                sql_data = TestInvest.do_mysql(sql=check_sql)
                HandleParameter.loan_id = sql_data.get("Id")
                # setattr(HandleParameter, "loan_id", loan_id)

        try:
            self.assertEqual(data_namedtuple.expected,
                             response.text,
                             msg="测试【{}】失败".format(title))
        except AssertionError as e:
            do_log.error("{},测试结果为:{}\n,具体异常信息为{}".format(
                title, run_fail_msg, e))
            self.parser_excel.write_result_to_excel(row=case_id,
                                                    actual=response.text,
                                                    result=run_fail_msg)
            raise e
        else:
            do_log.info("{},测试结果为:{}".format(title, run_success_msg))
            print("{}: {}".format(type(response.text), response.text))
            self.parser_excel.write_result_to_excel(row=case_id,
                                                    actual=response.text,
                                                    result=run_success_msg)
Пример #7
0
 def tearDownClass(cls) -> None:
     do_log.info("{}".format("充值功能用例执行结束"))
     cls.do_mysql.close()
     cls.do_request.close()