Commit e000b0d4 authored by liguangyu06's avatar liguangyu06
Browse files

用例新增:需求单导出新增下单人字段验证

parent ecce0c38
# -*- encoding=utf8 -*-
__author__ = "liguangyu"
"""
case_tag:cmdc_api,cmdc需求单导出新增下单人字段验证,33,33-27,sit,be
主数据平台:后台运营系统需求单导出接口
"""
from common.common_func import commonFuc
from air_case.cmdc_login.后台管理系统登录.后台管理系统登录 import CmdcDoLogin
from common.handle_excel import HandleExcel
import requests
import json
import os
module = "cmdc_33st"
# 第一步登录后台运营系统获取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, "url25")
request_body = commonFuc().get_business_data(module, "payload25")
# 发送请求
result = requests.post(url, json=request_body, headers=headers)
result = json.loads(result.content)
# 获取需求单信息
demandParentCode = result["data"]["list"][0]["demandParentCode"]
# 第三步获取需求单导出操作
url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url27")
request_body = commonFuc().get_business_data(module, "payload27", demandParentCode)
# 发送请求
result = requests.post(url, json=request_body, headers=headers)
# 获取接口响应时间
api_time = float(result.elapsed.total_seconds())
# 第四步获取导出文件
url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url28")
request_body = commonFuc().get_business_data(module, "payload28")
"""
场景: 需求单导出新增下单人字段验证
用例名称:需求单导出新增下单人字段验证
输出:{"operationUserName":"admin2"}
"""
# 发送请求
result = requests.get(url, params=request_body, headers=headers)
# 获取需求单导出记录
result = json.loads(result.content)
demand_url = result["data"][0]
# 获取导出文件
result = requests.get(demand_url, headers=headers)
# 获取文件
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 = {"operationUserName": excel.read_data()[0].get("制单人")}
# 将接口响应时间添加至result
result["api_time"] = api_time
# 获取预期结果
check_dict = commonFuc().get_business_data(module, "checkDict27")
# print(check_dict)
# 断言实际结果中是否包含预期结果的内容
commonFuc().check_result(check_dict, result)
...@@ -198,7 +198,11 @@ checkDict26: {"operationUserName":"admin2"} ...@@ -198,7 +198,11 @@ checkDict26: {"operationUserName":"admin2"}
checkDict28: {"success":true,"code":"200","message":"OK"} checkDict28: {"success":true,"code":"200","message":"OK"}
#测试场景27:需求单导出新增下单人字段验证
"url27": "/order/back/exportDemandAllInOne"
"payload27": {"times":[null],"firstAuditTimes":null,"firstAuditTimeStart":"","firstAuditTimeEnd":"","listOrderStatus":[],"productName":null,"demandCode":null,"demandParentCode":"%s","customerName":null,"manufacturer":null,"materialCode":null,"sellerCompanyName":null,"produceRegisterNum":null,"productLineName":null,"auditByName":null,"orderSource":null,"changeTypeList":null,"isRebateEdit":null,"jdeType":null,"pageSize":10,"pageStart":1,"orderChangeType":null,"snSgin":null,"changeSign":null,"customerCode":null,"distributionType":null,"busCustomerCode":null,"loginName":null,"cancelSign":0,"shipmentType":null,"siteType":null,"siteCompanyCode":null,"groupQuery":0,"promotionTypeList":[],"isGroup":[],"storageRoomNo":null,"isReplace":null,"stayStatus":null,"closeState":null,"startTime":null}
#预期结果
checkDict27: {"operationUserName":"admin2"}
......
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