{
  "uid" : "72761ac453ae24f7",
  "name" : "正向用例",
  "fullName" : "test_case.test_basic.test_case.TestBPM#test_bpm",
  "historyId" : "5abfadd4bc6f48931308e01525d1aa96",
  "time" : {
    "start" : 1721015509625,
    "stop" : 1721015509658,
    "duration" : 33
  },
  "status" : "failed",
  "statusMessage" : "AssertionError: 断言失败,描述失败的原因",
  "statusTrace" : "self = <APIAutoTest_v3_1.test_case.test_basic.test_case.TestBPM object at 0x0000018E4AB7A0A0>\nreq_fix = <APIAutoTest_v3_1.request_method.request_method.RequestMethod object at 0x0000018E4AB84220>\ndb_fix = <APIAutoTest_v3_1.common.db.DB object at 0x0000018E4AB84C70>, module_name = '维度管理', api_name = '根据维度编码删除维度', level = '中'\ncase_title = '正向用例', case_method = 'DELETE', case_url = 'http://36.139.193.99:8088/api/demension/v1/dem/deleteDemByIds', case_mime = 'query'\ncase_data = {'ids': '1812696302778687488'}, expect_data = {'message': '删除维度成功'}, sql_type = 'select'\nsql_data = 'SELECT ID_ FROM uc_demension WHERE `CODE_`=\"test_dem_xyz_123\";', update_key = 'ids'\n\n    @log_decorator\n    @allure.epic(\"BPM-Basic\")\n    # @allure.feature(\"模块名称\")\n    # @allure.story(\"接口名称\")\n    # @allure.title(\"接口标题\")\n    # @allure.severity(\"用例级别\")\n    @pytest.mark.parametrize(\"module_name, api_name, level, case_title, case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key\", ReadExcel(USERNAME).get_data())\n    def test_bpm(self, req_fix, db_fix, module_name, api_name, level, case_title, case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key):\n        # 影响allure报告的输出\n        allure.dynamic.feature(module_name)\n        allure.dynamic.story(api_name)\n        allure.dynamic.title(case_title)\n        allure.dynamic.severity(level)\n    \n        print(case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key)\n    \n        # 判断sql语句类型是否为delete,如果是,使用DB类对象调用delete方法执行删除的sql语句\n        if sql_type == \"delete\":\n            # 使用DB类对象调用delete方法执行删除的sql语句, DB类对象就是自定义固件db_fix\n            db_fix.delete(sql_data)\n    \n        # 判断sql语句的类型是否为select,如果是,使用DB类对象调用select方法执行查询语句,并接收查询的结果\n        elif sql_type == \"select\":\n            # 使用DB类对象调用select方法执行查询语句,并接收查询的结果\n            select_result = db_fix.select(sql_data)\n            # 将查询结果更新到用例数据中\n            case_data[update_key] = select_result\n    \n        # 判断sql语句的类型是否为select|delete 或者 delete|select ,如果是,使用DB类对象执行sql语句\n        elif sql_type == \"select|delete\" or sql_type == \"delete|select\":\n            # 使用DB类对象调用delete方法执行删除的sql语句。\n            db_fix.delete(sql_data[\"delete\"])\n    \n            # 使用DB类对象调用select方法执行查询的sql语句, 并接收查询的结果\n            select_result = db_fix.select(sql_data[\"select\"])\n            # 将查询结果更新到用例数据中\n            case_data[update_key] = select_result\n    \n        result = req_fix.request_all(req_method=case_method, req_url=case_url, req_mime=case_mime, case_data=case_data)\n        print(result.text)\n    \n        try:\n            for key in expect_data:\n>               assert expect_data[key] == result.json().get(key)\nE               AssertionError: assert '删除维度成功' == '删除维度成功!'\nE                 \nE                 - 删除维度成功!\nE                 ?       -\nE                 + 删除维度成功\n\ntest_case\\test_basic\\test_case.py:61: AssertionError\n\nDuring handling of the above exception, another exception occurred:\n\nself = <APIAutoTest_v3_1.test_case.test_basic.test_case.TestBPM object at 0x0000018E4AB7A0A0>\nreq_fix = <APIAutoTest_v3_1.request_method.request_method.RequestMethod object at 0x0000018E4AB84220>\ndb_fix = <APIAutoTest_v3_1.common.db.DB object at 0x0000018E4AB84C70>, module_name = '维度管理', api_name = '根据维度编码删除维度', level = '中'\ncase_title = '正向用例', case_method = 'DELETE', case_url = 'http://36.139.193.99:8088/api/demension/v1/dem/deleteDemByIds', case_mime = 'query'\ncase_data = {'ids': '1812696302778687488'}, expect_data = {'message': '删除维度成功'}, sql_type = 'select'\nsql_data = 'SELECT ID_ FROM uc_demension WHERE `CODE_`=\"test_dem_xyz_123\";', update_key = 'ids'\n\n    @log_decorator\n    @allure.epic(\"BPM-Basic\")\n    # @allure.feature(\"模块名称\")\n    # @allure.story(\"接口名称\")\n    # @allure.title(\"接口标题\")\n    # @allure.severity(\"用例级别\")\n    @pytest.mark.parametrize(\"module_name, api_name, level, case_title, case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key\", ReadExcel(USERNAME).get_data())\n    def test_bpm(self, req_fix, db_fix, module_name, api_name, level, case_title, case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key):\n        # 影响allure报告的输出\n        allure.dynamic.feature(module_name)\n        allure.dynamic.story(api_name)\n        allure.dynamic.title(case_title)\n        allure.dynamic.severity(level)\n    \n        print(case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key)\n    \n        # 判断sql语句类型是否为delete,如果是,使用DB类对象调用delete方法执行删除的sql语句\n        if sql_type == \"delete\":\n            # 使用DB类对象调用delete方法执行删除的sql语句, DB类对象就是自定义固件db_fix\n            db_fix.delete(sql_data)\n    \n        # 判断sql语句的类型是否为select,如果是,使用DB类对象调用select方法执行查询语句,并接收查询的结果\n        elif sql_type == \"select\":\n            # 使用DB类对象调用select方法执行查询语句,并接收查询的结果\n            select_result = db_fix.select(sql_data)\n            # 将查询结果更新到用例数据中\n            case_data[update_key] = select_result\n    \n        # 判断sql语句的类型是否为select|delete 或者 delete|select ,如果是,使用DB类对象执行sql语句\n        elif sql_type == \"select|delete\" or sql_type == \"delete|select\":\n            # 使用DB类对象调用delete方法执行删除的sql语句。\n            db_fix.delete(sql_data[\"delete\"])\n    \n            # 使用DB类对象调用select方法执行查询的sql语句, 并接收查询的结果\n            select_result = db_fix.select(sql_data[\"select\"])\n            # 将查询结果更新到用例数据中\n            case_data[update_key] = select_result\n    \n        result = req_fix.request_all(req_method=case_method, req_url=case_url, req_mime=case_mime, case_data=case_data)\n        print(result.text)\n    \n        try:\n            for key in expect_data:\n                assert expect_data[key] == result.json().get(key)\n        except AssertionError:\n>           raise AssertionError(\"断言失败,描述失败的原因\")\nE           AssertionError: 断言失败,描述失败的原因\n\ntest_case\\test_basic\\test_case.py:63: AssertionError",
  "flaky" : false,
  "newFailed" : false,
  "beforeStages" : [ {
    "name" : "db_fix",
    "time" : {
      "start" : 1721015508791,
      "stop" : 1721015508821,
      "duration" : 30
    },
    "status" : "passed",
    "steps" : [ ],
    "attachments" : [ ],
    "parameters" : [ ],
    "hasContent" : false,
    "stepsCount" : 0,
    "attachmentsCount" : 0,
    "shouldDisplayMessage" : false
  }, {
    "name" : "req_fix",
    "time" : {
      "start" : 1721015508741,
      "stop" : 1721015508791,
      "duration" : 50
    },
    "status" : "passed",
    "steps" : [ ],
    "attachments" : [ ],
    "parameters" : [ ],
    "hasContent" : false,
    "stepsCount" : 0,
    "attachmentsCount" : 0,
    "shouldDisplayMessage" : false
  } ],
  "testStage" : {
    "status" : "failed",
    "statusMessage" : "AssertionError: 断言失败,描述失败的原因",
    "statusTrace" : "self = <APIAutoTest_v3_1.test_case.test_basic.test_case.TestBPM object at 0x0000018E4AB7A0A0>\nreq_fix = <APIAutoTest_v3_1.request_method.request_method.RequestMethod object at 0x0000018E4AB84220>\ndb_fix = <APIAutoTest_v3_1.common.db.DB object at 0x0000018E4AB84C70>, module_name = '维度管理', api_name = '根据维度编码删除维度', level = '中'\ncase_title = '正向用例', case_method = 'DELETE', case_url = 'http://36.139.193.99:8088/api/demension/v1/dem/deleteDemByIds', case_mime = 'query'\ncase_data = {'ids': '1812696302778687488'}, expect_data = {'message': '删除维度成功'}, sql_type = 'select'\nsql_data = 'SELECT ID_ FROM uc_demension WHERE `CODE_`=\"test_dem_xyz_123\";', update_key = 'ids'\n\n    @log_decorator\n    @allure.epic(\"BPM-Basic\")\n    # @allure.feature(\"模块名称\")\n    # @allure.story(\"接口名称\")\n    # @allure.title(\"接口标题\")\n    # @allure.severity(\"用例级别\")\n    @pytest.mark.parametrize(\"module_name, api_name, level, case_title, case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key\", ReadExcel(USERNAME).get_data())\n    def test_bpm(self, req_fix, db_fix, module_name, api_name, level, case_title, case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key):\n        # 影响allure报告的输出\n        allure.dynamic.feature(module_name)\n        allure.dynamic.story(api_name)\n        allure.dynamic.title(case_title)\n        allure.dynamic.severity(level)\n    \n        print(case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key)\n    \n        # 判断sql语句类型是否为delete,如果是,使用DB类对象调用delete方法执行删除的sql语句\n        if sql_type == \"delete\":\n            # 使用DB类对象调用delete方法执行删除的sql语句, DB类对象就是自定义固件db_fix\n            db_fix.delete(sql_data)\n    \n        # 判断sql语句的类型是否为select,如果是,使用DB类对象调用select方法执行查询语句,并接收查询的结果\n        elif sql_type == \"select\":\n            # 使用DB类对象调用select方法执行查询语句,并接收查询的结果\n            select_result = db_fix.select(sql_data)\n            # 将查询结果更新到用例数据中\n            case_data[update_key] = select_result\n    \n        # 判断sql语句的类型是否为select|delete 或者 delete|select ,如果是,使用DB类对象执行sql语句\n        elif sql_type == \"select|delete\" or sql_type == \"delete|select\":\n            # 使用DB类对象调用delete方法执行删除的sql语句。\n            db_fix.delete(sql_data[\"delete\"])\n    \n            # 使用DB类对象调用select方法执行查询的sql语句, 并接收查询的结果\n            select_result = db_fix.select(sql_data[\"select\"])\n            # 将查询结果更新到用例数据中\n            case_data[update_key] = select_result\n    \n        result = req_fix.request_all(req_method=case_method, req_url=case_url, req_mime=case_mime, case_data=case_data)\n        print(result.text)\n    \n        try:\n            for key in expect_data:\n>               assert expect_data[key] == result.json().get(key)\nE               AssertionError: assert '删除维度成功' == '删除维度成功!'\nE                 \nE                 - 删除维度成功!\nE                 ?       -\nE                 + 删除维度成功\n\ntest_case\\test_basic\\test_case.py:61: AssertionError\n\nDuring handling of the above exception, another exception occurred:\n\nself = <APIAutoTest_v3_1.test_case.test_basic.test_case.TestBPM object at 0x0000018E4AB7A0A0>\nreq_fix = <APIAutoTest_v3_1.request_method.request_method.RequestMethod object at 0x0000018E4AB84220>\ndb_fix = <APIAutoTest_v3_1.common.db.DB object at 0x0000018E4AB84C70>, module_name = '维度管理', api_name = '根据维度编码删除维度', level = '中'\ncase_title = '正向用例', case_method = 'DELETE', case_url = 'http://36.139.193.99:8088/api/demension/v1/dem/deleteDemByIds', case_mime = 'query'\ncase_data = {'ids': '1812696302778687488'}, expect_data = {'message': '删除维度成功'}, sql_type = 'select'\nsql_data = 'SELECT ID_ FROM uc_demension WHERE `CODE_`=\"test_dem_xyz_123\";', update_key = 'ids'\n\n    @log_decorator\n    @allure.epic(\"BPM-Basic\")\n    # @allure.feature(\"模块名称\")\n    # @allure.story(\"接口名称\")\n    # @allure.title(\"接口标题\")\n    # @allure.severity(\"用例级别\")\n    @pytest.mark.parametrize(\"module_name, api_name, level, case_title, case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key\", ReadExcel(USERNAME).get_data())\n    def test_bpm(self, req_fix, db_fix, module_name, api_name, level, case_title, case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key):\n        # 影响allure报告的输出\n        allure.dynamic.feature(module_name)\n        allure.dynamic.story(api_name)\n        allure.dynamic.title(case_title)\n        allure.dynamic.severity(level)\n    \n        print(case_method, case_url, case_mime, case_data, expect_data, sql_type, sql_data, update_key)\n    \n        # 判断sql语句类型是否为delete,如果是,使用DB类对象调用delete方法执行删除的sql语句\n        if sql_type == \"delete\":\n            # 使用DB类对象调用delete方法执行删除的sql语句, DB类对象就是自定义固件db_fix\n            db_fix.delete(sql_data)\n    \n        # 判断sql语句的类型是否为select,如果是,使用DB类对象调用select方法执行查询语句,并接收查询的结果\n        elif sql_type == \"select\":\n            # 使用DB类对象调用select方法执行查询语句,并接收查询的结果\n            select_result = db_fix.select(sql_data)\n            # 将查询结果更新到用例数据中\n            case_data[update_key] = select_result\n    \n        # 判断sql语句的类型是否为select|delete 或者 delete|select ,如果是,使用DB类对象执行sql语句\n        elif sql_type == \"select|delete\" or sql_type == \"delete|select\":\n            # 使用DB类对象调用delete方法执行删除的sql语句。\n            db_fix.delete(sql_data[\"delete\"])\n    \n            # 使用DB类对象调用select方法执行查询的sql语句, 并接收查询的结果\n            select_result = db_fix.select(sql_data[\"select\"])\n            # 将查询结果更新到用例数据中\n            case_data[update_key] = select_result\n    \n        result = req_fix.request_all(req_method=case_method, req_url=case_url, req_mime=case_mime, case_data=case_data)\n        print(result.text)\n    \n        try:\n            for key in expect_data:\n                assert expect_data[key] == result.json().get(key)\n        except AssertionError:\n>           raise AssertionError(\"断言失败,描述失败的原因\")\nE           AssertionError: 断言失败,描述失败的原因\n\ntest_case\\test_basic\\test_case.py:63: AssertionError",
    "steps" : [ ],
    "attachments" : [ {
      "uid" : "21fed71ea3954314",
      "name" : "log",
      "source" : "21fed71ea3954314.txt",
      "type" : "text/plain",
      "size" : 656
    }, {
      "uid" : "d63e19da329e7efd",
      "name" : "stdout",
      "source" : "d63e19da329e7efd.txt",
      "type" : "text/plain",
      "size" : 278
    } ],
    "parameters" : [ ],
    "hasContent" : true,
    "stepsCount" : 0,
    "attachmentsCount" : 2,
    "shouldDisplayMessage" : true
  },
  "afterStages" : [ {
    "name" : "db_fix::0",
    "time" : {
      "start" : 1721015510221,
      "stop" : 1721015510221,
      "duration" : 0
    },
    "status" : "passed",
    "steps" : [ ],
    "attachments" : [ ],
    "parameters" : [ ],
    "hasContent" : false,
    "stepsCount" : 0,
    "attachmentsCount" : 0,
    "shouldDisplayMessage" : false
  }, {
    "name" : "req_fix::0",
    "time" : {
      "start" : 1721015510221,
      "stop" : 1721015510221,
      "duration" : 0
    },
    "status" : "passed",
    "steps" : [ ],
    "attachments" : [ ],
    "parameters" : [ ],
    "hasContent" : false,
    "stepsCount" : 0,
    "attachmentsCount" : 0,
    "shouldDisplayMessage" : false
  } ],
  "labels" : [ {
    "name" : "feature",
    "value" : "维度管理"
  }, {
    "name" : "story",
    "value" : "根据维度编码删除维度"
  }, {
    "name" : "severity",
    "value" : "中"
  }, {
    "name" : "epic",
    "value" : "BPM-Basic"
  }, {
    "name" : "parentSuite",
    "value" : "test_case.test_basic"
  }, {
    "name" : "suite",
    "value" : "test_case"
  }, {
    "name" : "subSuite",
    "value" : "TestBPM"
  }, {
    "name" : "host",
    "value" : "LAPTOP-O09782E1"
  }, {
    "name" : "thread",
    "value" : "18996-MainThread"
  }, {
    "name" : "framework",
    "value" : "pytest"
  }, {
    "name" : "language",
    "value" : "cpython3"
  }, {
    "name" : "package",
    "value" : "test_case.test_basic.test_case"
  }, {
    "name" : "resultFormat",
    "value" : "allure2"
  } ],
  "parameters" : [ {
    "name" : "api_name",
    "value" : "'根据维度编码删除维度'"
  }, {
    "name" : "case_data",
    "value" : "{'ids': '需要更新'}"
  }, {
    "name" : "case_method",
    "value" : "'DELETE'"
  }, {
    "name" : "case_mime",
    "value" : "'query'"
  }, {
    "name" : "case_title",
    "value" : "'正向用例'"
  }, {
    "name" : "case_url",
    "value" : "'http://36.139.193.99:8088/api/demension/v1/dem/deleteDemByIds'"
  }, {
    "name" : "expect_data",
    "value" : "{'message': '删除维度成功'}"
  }, {
    "name" : "level",
    "value" : "'中'"
  }, {
    "name" : "module_name",
    "value" : "'维度管理'"
  }, {
    "name" : "sql_data",
    "value" : "'SELECT ID_ FROM uc_demension WHERE `CODE_`=\"test_dem_xyz_123\";'"
  }, {
    "name" : "sql_type",
    "value" : "'select'"
  }, {
    "name" : "update_key",
    "value" : "'ids'"
  } ],
  "links" : [ ],
  "hidden" : false,
  "retry" : false,
  "extra" : {
    "severity" : "normal",
    "retries" : [ ],
    "categories" : [ {
      "name" : "Product defects",
      "matchedStatuses" : [ ],
      "flaky" : false
    } ],
    "tags" : [ ]
  },
  "source" : "72761ac453ae24f7.json",
  "parameterValues" : [ "'根据维度编码删除维度'", "{'ids': '需要更新'}", "'DELETE'", "'query'", "'正向用例'", "'http://36.139.193.99:8088/api/demension/v1/dem/deleteDemByIds'", "{'message': '删除维度成功'}", "'中'", "'维度管理'", "'SELECT ID_ FROM uc_demension WHERE `CODE_`=\"test_dem_xyz_123\";'", "'select'", "'ids'" ]
}