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()
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)
def tearDownClass(cls) -> None: """ 后置处理操作: :return: """ do_log.info("{}".format("登录功能用例执行结束")) cls.do_request.close()
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()
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)
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)
def tearDownClass(cls) -> None: do_log.info("{}".format("充值功能用例执行结束")) cls.do_mysql.close() cls.do_request.close()