{ "uid" : "dcbfa7f9bbdf6161", "name" : "正向用例", "fullName" : "test_case.test_lao_zhang.test_bpm.TestBPM#test_bpm", "historyId" : "e6ac3c13b8b565a578345a2c5e68a403", "time" : { "start" : 1725517442507, "stop" : 1725517442539, "duration" : 32 }, "status" : "failed", "statusMessage" : "AssertionError: 断言失败", "statusTrace" : "self = <apiAutoTest_v3.test_case.test_lao_zhang.test_bpm.TestBPM object at 0x0000023F24EF27C0>\nfix_db = <apiAutoTest_v3.common.db.DB object at 0x0000023F25094040>\nfix_req = <apiAutoTest_v3.request_method.request_method.RequestMethod object at 0x0000023F250940A0>, module_name = '认证接口', api_name = '刷新token'\nlevel = '高', title = '正向用例', url = 'http://36.139.193.99:8088/refresh', method = 'GET', mime = None, case_data = None\nexpect_data = {'message': '刷新token成功'}, sql_type = None, sql_data = None, update_key = None\n\n @allure.epic(\"BPM项目-老张\")\n # @allure.feature(\"模块名称\")\n # @allure.story(\"接口名称\")\n # @allure.title(\"用例标题\")\n # @allure.severity(\"用例等级\")\n @pytest.mark.parametrize(\"module_name, api_name, level, title, url, method, mime, case_data, expect_data, sql_type, sql_data, update_key\", excel.get_data())\n def test_bpm(self, fix_db, fix_req, module_name, api_name, level, title, url, method, mime, case_data, expect_data, sql_type, sql_data, update_key):\n allure.dynamic.feature(module_name)\n allure.dynamic.story(api_name)\n allure.dynamic.title(title)\n allure.dynamic.severity(level)\n \n # 判断sql语句的类型是否为delete\n if sql_type == \"delete\":\n # 使用DB类对象调用delete方法执行删除的sql语句,DB类对象===fix_db自定义固件\n fix_db.delete(sql_data['delete'])\n \n # 判断sql语句类型是否为select\n elif sql_type == \"select\":\n # 使用DB类对象调用select方法执行查询的sql语句, 并获取查询结果,DB类对象===fix_db自定义固件\n select_result = fix_db.select(sql_data['select'])\n # 将查询结果更新到用例数据中\n case_data[update_key] = select_result\n \n # 判断sql语句的类型是否为select|delete 或者为 delete|select\n elif sql_type == \"select|delete\" or sql_type == \"delete|select\":\n # 使用DB类对象调用delete方法执行删除的sql语句,DB类对象===fix_db自定义固件\n fix_db.delete(sql_data['delete'])\n \n # 使用DB类对象调用select方法执行查询的sql语句, 并获取查询结果,DB类对象===fix_db自定义固件\n select_result = fix_db.select(sql_data['select'])\n # 将查询结果更新到用例数据中\n case_data[update_key] = select_result\n \n # 使用RequestMethod类对象发送请求\n res = fix_req.request_all(req_method=method, req_url=url, req_mime=mime, case_data=case_data)\n \n # 断言\n try:\n for key in expect_data.keys():\n> assert expect_data[key] == res.json().get(key)\nE AssertionError: assert '刷新token成功' == None\nE + where None = <built-in method get of dict object at 0x0000023F2524DB40>('message')\nE + where <built-in method get of dict object at 0x0000023F2524DB40> = {'account': 'admin', 'expiration': 86400, 'loginStatus': True, 'token': 'eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbiIsInRl...MsImlhdCI6MTcyNTUxNzMzM30.XmDKHG2JrMZ9qdPIp0abifDYfjJk2Xwqyw2o3GaTKRXzfpc--kJRfS0BF47e17S-l--7Fz83Fiews8Z_LnQ6dA', ...}.get\nE + where {'account': 'admin', 'expiration': 86400, 'loginStatus': True, 'token': 'eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbiIsInRl...MsImlhdCI6MTcyNTUxNzMzM30.XmDKHG2JrMZ9qdPIp0abifDYfjJk2Xwqyw2o3GaTKRXzfpc--kJRfS0BF47e17S-l--7Fz83Fiews8Z_LnQ6dA', ...} = json()\nE + where json = <Response [200]>.json\n\ntest_case\\test_lao_zhang\\test_bpm.py:61: AssertionError\n\nDuring handling of the above exception, another exception occurred:\n\nself = <apiAutoTest_v3.test_case.test_lao_zhang.test_bpm.TestBPM object at 0x0000023F24EF27C0>\nfix_db = <apiAutoTest_v3.common.db.DB object at 0x0000023F25094040>\nfix_req = <apiAutoTest_v3.request_method.request_method.RequestMethod object at 0x0000023F250940A0>, module_name = '认证接口', api_name = '刷新token'\nlevel = '高', title = '正向用例', url = 'http://36.139.193.99:8088/refresh', method = 'GET', mime = None, case_data = None\nexpect_data = {'message': '刷新token成功'}, sql_type = None, sql_data = None, update_key = None\n\n @allure.epic(\"BPM项目-老张\")\n # @allure.feature(\"模块名称\")\n # @allure.story(\"接口名称\")\n # @allure.title(\"用例标题\")\n # @allure.severity(\"用例等级\")\n @pytest.mark.parametrize(\"module_name, api_name, level, title, url, method, mime, case_data, expect_data, sql_type, sql_data, update_key\", excel.get_data())\n def test_bpm(self, fix_db, fix_req, module_name, api_name, level, title, url, method, mime, case_data, expect_data, sql_type, sql_data, update_key):\n allure.dynamic.feature(module_name)\n allure.dynamic.story(api_name)\n allure.dynamic.title(title)\n allure.dynamic.severity(level)\n \n # 判断sql语句的类型是否为delete\n if sql_type == \"delete\":\n # 使用DB类对象调用delete方法执行删除的sql语句,DB类对象===fix_db自定义固件\n fix_db.delete(sql_data['delete'])\n \n # 判断sql语句类型是否为select\n elif sql_type == \"select\":\n # 使用DB类对象调用select方法执行查询的sql语句, 并获取查询结果,DB类对象===fix_db自定义固件\n select_result = fix_db.select(sql_data['select'])\n # 将查询结果更新到用例数据中\n case_data[update_key] = select_result\n \n # 判断sql语句的类型是否为select|delete 或者为 delete|select\n elif sql_type == \"select|delete\" or sql_type == \"delete|select\":\n # 使用DB类对象调用delete方法执行删除的sql语句,DB类对象===fix_db自定义固件\n fix_db.delete(sql_data['delete'])\n \n # 使用DB类对象调用select方法执行查询的sql语句, 并获取查询结果,DB类对象===fix_db自定义固件\n select_result = fix_db.select(sql_data['select'])\n # 将查询结果更新到用例数据中\n case_data[update_key] = select_result\n \n # 使用RequestMethod类对象发送请求\n res = fix_req.request_all(req_method=method, req_url=url, req_mime=mime, case_data=case_data)\n \n # 断言\n try:\n for key in expect_data.keys():\n assert expect_data[key] == res.json().get(key)\n except AssertionError:\n log.error(f\"断言失败,接口url为:{url}, 用例数据:{case_data}, 期望数据:{expect_data}, 服务器返回数据:{res.text}\")\n> raise AssertionError(\"断言失败\")\nE AssertionError: 断言失败\n\ntest_case\\test_lao_zhang\\test_bpm.py:64: AssertionError", "flaky" : false, "newFailed" : false, "beforeStages" : [ ], "testStage" : { "status" : "failed", "statusMessage" : "AssertionError: 断言失败", "statusTrace" : "self = <apiAutoTest_v3.test_case.test_lao_zhang.test_bpm.TestBPM object at 0x0000023F24EF27C0>\nfix_db = <apiAutoTest_v3.common.db.DB object at 0x0000023F25094040>\nfix_req = <apiAutoTest_v3.request_method.request_method.RequestMethod object at 0x0000023F250940A0>, module_name = '认证接口', api_name = '刷新token'\nlevel = '高', title = '正向用例', url = 'http://36.139.193.99:8088/refresh', method = 'GET', mime = None, case_data = None\nexpect_data = {'message': '刷新token成功'}, sql_type = None, sql_data = None, update_key = None\n\n @allure.epic(\"BPM项目-老张\")\n # @allure.feature(\"模块名称\")\n # @allure.story(\"接口名称\")\n # @allure.title(\"用例标题\")\n # @allure.severity(\"用例等级\")\n @pytest.mark.parametrize(\"module_name, api_name, level, title, url, method, mime, case_data, expect_data, sql_type, sql_data, update_key\", excel.get_data())\n def test_bpm(self, fix_db, fix_req, module_name, api_name, level, title, url, method, mime, case_data, expect_data, sql_type, sql_data, update_key):\n allure.dynamic.feature(module_name)\n allure.dynamic.story(api_name)\n allure.dynamic.title(title)\n allure.dynamic.severity(level)\n \n # 判断sql语句的类型是否为delete\n if sql_type == \"delete\":\n # 使用DB类对象调用delete方法执行删除的sql语句,DB类对象===fix_db自定义固件\n fix_db.delete(sql_data['delete'])\n \n # 判断sql语句类型是否为select\n elif sql_type == \"select\":\n # 使用DB类对象调用select方法执行查询的sql语句, 并获取查询结果,DB类对象===fix_db自定义固件\n select_result = fix_db.select(sql_data['select'])\n # 将查询结果更新到用例数据中\n case_data[update_key] = select_result\n \n # 判断sql语句的类型是否为select|delete 或者为 delete|select\n elif sql_type == \"select|delete\" or sql_type == \"delete|select\":\n # 使用DB类对象调用delete方法执行删除的sql语句,DB类对象===fix_db自定义固件\n fix_db.delete(sql_data['delete'])\n \n # 使用DB类对象调用select方法执行查询的sql语句, 并获取查询结果,DB类对象===fix_db自定义固件\n select_result = fix_db.select(sql_data['select'])\n # 将查询结果更新到用例数据中\n case_data[update_key] = select_result\n \n # 使用RequestMethod类对象发送请求\n res = fix_req.request_all(req_method=method, req_url=url, req_mime=mime, case_data=case_data)\n \n # 断言\n try:\n for key in expect_data.keys():\n> assert expect_data[key] == res.json().get(key)\nE AssertionError: assert '刷新token成功' == None\nE + where None = <built-in method get of dict object at 0x0000023F2524DB40>('message')\nE + where <built-in method get of dict object at 0x0000023F2524DB40> = {'account': 'admin', 'expiration': 86400, 'loginStatus': True, 'token': 'eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbiIsInRl...MsImlhdCI6MTcyNTUxNzMzM30.XmDKHG2JrMZ9qdPIp0abifDYfjJk2Xwqyw2o3GaTKRXzfpc--kJRfS0BF47e17S-l--7Fz83Fiews8Z_LnQ6dA', ...}.get\nE + where {'account': 'admin', 'expiration': 86400, 'loginStatus': True, 'token': 'eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJhZG1pbiIsInRl...MsImlhdCI6MTcyNTUxNzMzM30.XmDKHG2JrMZ9qdPIp0abifDYfjJk2Xwqyw2o3GaTKRXzfpc--kJRfS0BF47e17S-l--7Fz83Fiews8Z_LnQ6dA', ...} = json()\nE + where json = <Response [200]>.json\n\ntest_case\\test_lao_zhang\\test_bpm.py:61: AssertionError\n\nDuring handling of the above exception, another exception occurred:\n\nself = <apiAutoTest_v3.test_case.test_lao_zhang.test_bpm.TestBPM object at 0x0000023F24EF27C0>\nfix_db = <apiAutoTest_v3.common.db.DB object at 0x0000023F25094040>\nfix_req = <apiAutoTest_v3.request_method.request_method.RequestMethod object at 0x0000023F250940A0>, module_name = '认证接口', api_name = '刷新token'\nlevel = '高', title = '正向用例', url = 'http://36.139.193.99:8088/refresh', method = 'GET', mime = None, case_data = None\nexpect_data = {'message': '刷新token成功'}, sql_type = None, sql_data = None, update_key = None\n\n @allure.epic(\"BPM项目-老张\")\n # @allure.feature(\"模块名称\")\n # @allure.story(\"接口名称\")\n # @allure.title(\"用例标题\")\n # @allure.severity(\"用例等级\")\n @pytest.mark.parametrize(\"module_name, api_name, level, title, url, method, mime, case_data, expect_data, sql_type, sql_data, update_key\", excel.get_data())\n def test_bpm(self, fix_db, fix_req, module_name, api_name, level, title, url, method, mime, case_data, expect_data, sql_type, sql_data, update_key):\n allure.dynamic.feature(module_name)\n allure.dynamic.story(api_name)\n allure.dynamic.title(title)\n allure.dynamic.severity(level)\n \n # 判断sql语句的类型是否为delete\n if sql_type == \"delete\":\n # 使用DB类对象调用delete方法执行删除的sql语句,DB类对象===fix_db自定义固件\n fix_db.delete(sql_data['delete'])\n \n # 判断sql语句类型是否为select\n elif sql_type == \"select\":\n # 使用DB类对象调用select方法执行查询的sql语句, 并获取查询结果,DB类对象===fix_db自定义固件\n select_result = fix_db.select(sql_data['select'])\n # 将查询结果更新到用例数据中\n case_data[update_key] = select_result\n \n # 判断sql语句的类型是否为select|delete 或者为 delete|select\n elif sql_type == \"select|delete\" or sql_type == \"delete|select\":\n # 使用DB类对象调用delete方法执行删除的sql语句,DB类对象===fix_db自定义固件\n fix_db.delete(sql_data['delete'])\n \n # 使用DB类对象调用select方法执行查询的sql语句, 并获取查询结果,DB类对象===fix_db自定义固件\n select_result = fix_db.select(sql_data['select'])\n # 将查询结果更新到用例数据中\n case_data[update_key] = select_result\n \n # 使用RequestMethod类对象发送请求\n res = fix_req.request_all(req_method=method, req_url=url, req_mime=mime, case_data=case_data)\n \n # 断言\n try:\n for key in expect_data.keys():\n assert expect_data[key] == res.json().get(key)\n except AssertionError:\n log.error(f\"断言失败,接口url为:{url}, 用例数据:{case_data}, 期望数据:{expect_data}, 服务器返回数据:{res.text}\")\n> raise AssertionError(\"断言失败\")\nE AssertionError: 断言失败\n\ntest_case\\test_lao_zhang\\test_bpm.py:64: AssertionError", "steps" : [ ], "attachments" : [ { "uid" : "7b407d6d68f0ca84", "name" : "log", "source" : "7b407d6d68f0ca84.txt", "type" : "text/plain", "size" : 1469 } ], "parameters" : [ ], "stepsCount" : 0, "hasContent" : true, "shouldDisplayMessage" : true, "attachmentsCount" : 1 }, "afterStages" : [ ], "labels" : [ { "name" : "feature", "value" : "认证接口" }, { "name" : "story", "value" : "刷新token" }, { "name" : "severity", "value" : "高" }, { "name" : "epic", "value" : "BPM项目-老张" }, { "name" : "parentSuite", "value" : "test_case.test_lao_zhang" }, { "name" : "suite", "value" : "test_bpm" }, { "name" : "subSuite", "value" : "TestBPM" }, { "name" : "host", "value" : "LAPTOP-O09782E1" }, { "name" : "thread", "value" : "21668-MainThread" }, { "name" : "framework", "value" : "pytest" }, { "name" : "language", "value" : "cpython3" }, { "name" : "package", "value" : "test_case.test_lao_zhang.test_bpm" }, { "name" : "resultFormat", "value" : "allure2" } ], "parameters" : [ { "name" : "api_name", "value" : "'刷新token'" }, { "name" : "case_data", "value" : "None" }, { "name" : "expect_data", "value" : "{'message': '刷新token成功'}" }, { "name" : "level", "value" : "'高'" }, { "name" : "method", "value" : "'GET'" }, { "name" : "mime", "value" : "None" }, { "name" : "module_name", "value" : "'认证接口'" }, { "name" : "sql_data", "value" : "None" }, { "name" : "sql_type", "value" : "None" }, { "name" : "title", "value" : "'正向用例'" }, { "name" : "update_key", "value" : "None" }, { "name" : "url", "value" : "'http://36.139.193.99:8088/refresh'" } ], "links" : [ ], "hidden" : true, "retry" : true, "extra" : { "categories" : [ ], "tags" : [ ] }, "source" : "dcbfa7f9bbdf6161.json", "parameterValues" : [ "'刷新token'", "None", "{'message': '刷新token成功'}", "'高'", "'GET'", "None", "'认证接口'", "None", "None", "'正向用例'", "None", "'http://36.139.193.99:8088/refresh'" ] }