diff --git "a/air_case/cmdc_ls/\346\211\271\351\207\217\345\257\274\345\207\272\345\212\237\350\203\275\351\252\214\350\257\201_\345\214\273\351\231\242\346\244\215\345\205\245\344\270\212\346\212\245\345\210\227\350\241\250.air/\346\211\271\351\207\217\345\257\274\345\207\272\345\212\237\350\203\275\351\252\214\350\257\201_\345\214\273\351\231\242\346\244\215\345\205\245\344\270\212\346\212\245\345\210\227\350\241\250.py" "b/air_case/cmdc_ls/\346\211\271\351\207\217\345\257\274\345\207\272\345\212\237\350\203\275\351\252\214\350\257\201_\345\214\273\351\231\242\346\244\215\345\205\245\344\270\212\346\212\245\345\210\227\350\241\250.air/\346\211\271\351\207\217\345\257\274\345\207\272\345\212\237\350\203\275\351\252\214\350\257\201_\345\214\273\351\231\242\346\244\215\345\205\245\344\270\212\346\212\245\345\210\227\350\241\250.py" new file mode 100644 index 0000000000000000000000000000000000000000..4142026d2e88dd75bbf60651a6dd20576b958729 --- /dev/null +++ "b/air_case/cmdc_ls/\346\211\271\351\207\217\345\257\274\345\207\272\345\212\237\350\203\275\351\252\214\350\257\201_\345\214\273\351\231\242\346\244\215\345\205\245\344\270\212\346\212\245\345\210\227\350\241\250.air/\346\211\271\351\207\217\345\257\274\345\207\272\345\212\237\350\203\275\351\252\214\350\257\201_\345\214\273\351\231\242\346\244\215\345\205\245\344\270\212\346\212\245\345\210\227\350\241\250.py" @@ -0,0 +1,74 @@ +# -*- encoding=utf8 -*- +__author__ = "liguangyu" + +""" +case_tag:cmdc_api,cmdc批量导出功能验证_医院植入上报列表,2300,2300-3,sit,be +主数据平台:后台运营系统批量导出接口 +""" + +from common.common_func import commonFuc +from air_case.cmdc_login.后台管理系统登录.后台管理系统登录 import CmdcDoLogin +from common.handle_excel import HandleExcel +import requests +import random +import json +import os + +module = "cmdc_ls" + +# 第一步登录后台运营系统获取token +username = commonFuc().get_business_data(module, "username_do_be") +password = commonFuc().get_business_data(module, "password_do_be") +# 获取登录后Cmdc_access_token +cmdc_access_token = CmdcDoLogin(username, password).get_token() +headers = commonFuc().get_business_data(module, "json_headers", cmdc_access_token) + +# 第二步获取医院植入上报列表 +url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url1") +request_body = commonFuc().get_business_data(module, "payload1") +# 发送请求 +result = requests.post(url, json=request_body, headers=headers) +result = json.loads(result.content) + +# 生成随机数 +hosp_random = random.randint(0, len(result["data"]["list"]) - 1) + +# 获取医院植入上报信息 +invoiceCode = result["data"]["list"][hosp_random]["invoiceCode"] + +# 第三步进行数据导出 +url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url3") +request_body = commonFuc().get_business_data(module, "payload3", invoiceCode) +# print(request_body) +""" + + 场景: 批量导出功能验证_医院植入上报列表 + 用例名称:批量导出功能验证_医院植入上报列表 + 输出:{"invoiceCode":"%s"} +""" + +# 发送请求 +result = requests.post(url, json=request_body, headers=headers) +# 获取接口响应时间 +api_time = float(result.elapsed.total_seconds()) + +# 获取文件 +BASE_DIR = os.path.dirname(os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))) +file_path = BASE_DIR + "/data/cmdc_files/医院植入明细.xlsx" + +# 获取到导出文件存入cmdc_files文件中 +with open(file_path, 'wb') as f: + f.write(result.content) + +# 获取导出文件中医院植入上报信息 +excel = HandleExcel(file_path, "Sheet1") +result = {"invoiceCode": excel.read_data()[0].get("发票号码")} + +# 将接口响应时间添加至result +result["api_time"] = api_time + +# 获取预期结果 +check_dict = commonFuc().get_business_data(module, "checkDict3", invoiceCode) +# print(check_dict) +# 断言实际结果中是否包含预期结果的内容 +commonFuc().check_result(check_dict, result) diff --git a/data/cmdc_ls/data b/data/cmdc_ls/data index 0ae1677feb94cf46c6a5ccc3d1864956fb8725ca..0a7cc7cfe5392fb0afe69e318b296f16dd45fcb4 100644 --- a/data/cmdc_ls/data +++ b/data/cmdc_ls/data @@ -40,3 +40,8 @@ checkDict1: {"success":true,"code":"200","message":"OK"} checkDict2: {"invoiceCode":"%s"} +#测试场景3:批量导出功能验证_医院植入上报列表 +"url3": "/cms/public/ls/exportExcel" +"payload3": {"distributor":"","source":"","statisticYear":"","statisticMonth":"","invoiceCode":"%s","hospInfo":"","pageStart":1,"pageSize":10,"type":"1"} +#预期结果 +checkDict3: {"invoiceCode":"%s"} \ No newline at end of file