Commit 5560ffae authored by liguangyu06's avatar liguangyu06
Browse files

用例新增:列表查询条件验证_上报植入列表

parent da5079b0
# -*- encoding=utf8 -*-
__author__ = "liguangyu"
"""
case_tag:cmdc_api,cmdc列表查询条件验证_上报植入列表,00,00-33,sit,be
主数据平台:后台运营系统获取上报植入列表接口
"""
from common.common_func import commonFuc
from air_case.cmdc_login.后台管理系统登录.后台管理系统登录 import CmdcDoLogin
from common.db.db import mySql
import datetime
import random
import requests
import json
module = "cmdc_special_version"
# 第一步登录后台运营系统获取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)
# 数据库操作
mysql_handle = mySql()
# 获取conf.ini文件中配置的数据库信息
host, port, user, pwd = mysql_handle.getConf(db="cmdc_db_be")
# 在数据库中已存在的植入上报数据对应的产品线信息
sql = "SELECT t.productLineCode, t.companyCode FROM `cmdc-order`.tc_report t where deleteSign = 0"
productLineCode = mysql_handle.selectSql(host, port, user, pwd, "cmdc-order", sql)[0][0]
companyCode = mysql_handle.selectSql(host, port, user, pwd, "cmdc-order", sql)[0][1]
# 第二步获取上报植入列表
url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url33")
request_body = commonFuc().get_business_data(module, "payload33_1", companyCode, productLineCode)
# 发送请求
result = requests.post(url, json=request_body, headers=headers)
result = json.loads(result.content)
# print(result)
# 生成随机数
report_random = random.randint(0, len(result["data"]["list"]) - 1)
# 获取上报植入信息
customerInfo = result["data"]["list"][report_random]["customerCode"]
optionStr = result["data"]["list"][report_random]["optionStr"]
reportAuditStatus = result["data"]["list"][report_random]["reportAuditStatus"]
companyCode = companyCode
productLineCode = productLineCode
reportHospitalCodeList = result["data"]["list"][report_random]["reportHospitalCode"]
deleteSign = result["data"]["list"][report_random]["deleteSign"]
invoiceStatus = (result["data"]["list"][report_random]["invoiceStatus"] if result["data"]["list"][report_random][
"invoiceStatus"] else "")
reportStatus = result["data"]["list"][report_random]["reportStatus"]
batchNumber = result["data"]["list"][report_random]["batchNumber"]
reportDateStart = (
result["data"]["list"][report_random]["reportDateStr"][:10] + " 00:00:00" if result["data"]["list"][report_random][
"reportDateStr"] else "2000-01-1 00:00:00")
reportDateEnd = datetime.datetime.now().strftime("%Y-%m-%d") + " 23:59:59"
reportAuditTimeStart = (
result["data"]["list"][report_random]["reportAuditTimeStr"][:10] + " 00:00:00" if result["data"]["list"][report_random][
"reportAuditTimeStr"] else "2000-01-1 00:00:00")
reportAuditTimeEnd = datetime.datetime.now().strftime("%Y-%m-%d") + " 23:59:59"
reportManufacturerTimeStart = (
result["data"]["list"][report_random]["reportManufacturerTime"][:10] + " 00:00:00" if result["data"]["list"][report_random][
"reportManufacturerTime"] else "2000-01-01 00:00:00")
reportManufacturerTimeEnd = datetime.datetime.now().strftime("%Y-%m-%d") + " 23:59:59"
# 第三步进行列表查询条件验证
url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url33")
request_body = commonFuc().get_business_data(module, "payload33", customerInfo, optionStr, reportAuditStatus,
companyCode,
productLineCode, reportHospitalCodeList, deleteSign, invoiceStatus,
reportStatus, batchNumber, reportDateStart, reportDateEnd,
reportAuditTimeStart,
reportAuditTimeEnd, reportManufacturerTimeStart, reportManufacturerTimeEnd)
"""
场景: 列表查询条件验证_上报植入列表
用例名称:列表查询条件验证_上报植入列表
输出:{"batchNumber":"%s"}
"""
# 发送请求
result = requests.post(url, json=request_body, headers=headers)
# 获取接口响应时间
api_time = float(result.elapsed.total_seconds())
# 获取上报植入信息
result = json.loads(result.content)
result = {"batchNumber": result["data"]["list"][0]["batchNumber"]}
# 将接口响应时间添加至result
result["api_time"] = api_time
# 获取预期结果
check_dict = commonFuc().get_business_data(module, "checkDict33", batchNumber)
# print(check_dict)
# 断言实际结果中是否包含预期结果的内容
commonFuc().check_result(check_dict, result)
......@@ -251,7 +251,13 @@ checkDict32: {"success":true,"code":"200","message":"OK"}
#预期结果
checkDict42: {"success":false,"code":"ERROR","message":"产品线编码不能为空","data":null}
#测试场景33:列表查询条件验证_上报植入列表
"url33": "/order/public/getReportList"
"payload33": {"customerInfo":"%s","optionStr":"%s","reportAuditStatus":"%s","status":null,"companyCode":"%s","productLineCode":"%s","reportHospitalCode":"","reportHospitalCodeList":["%s"],"deleteSign":"%s","numberSource":"","invoiceStatus":"%s","reportStatus":"%s","reportQueryType":0,"batchNumber":"%s","pageNum":1,"pageSize":10,"pageStart":1,"reportDateStart":"%s","reportDateEnd":"%s","reportAuditTimeStart":"%s","reportAuditTimeEnd":"%s","reportManufacturerTimeStart":"%s","reportManufacturerTimeEnd":"%s"}
#预期结果
checkDict33: {"batchNumber":"%s"}
#获取植入上报信息
"payload33_1": {"customerInfo":"","optionStr":"","reportAuditStatus":null,"status":null,"companyCode":"%s","productLineCode":"%s","reportHospitalCode":"","reportHospitalCodeList":[],"deleteSign":"","numberSource":"","invoiceStatus":null,"reportStatus":null,"reportQueryType":0,"pageNum":1,"pageSize":10,"pageStart":1,"reportDateStart":null,"reportDateEnd":null,"reportAuditTimeStart":null,"reportAuditTimeEnd":null,"reportManufacturerTimeStart":null,"reportManufacturerTimeEnd":null}
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment