Commit cef2c94a authored by liguangyu06's avatar liguangyu06
Browse files

用例新增:获取业务人员信息

parent 73611bbe
# -*- encoding=utf8 -*-
__author__ = "liguangyu"
"""
case_tag:cmdc_api,cmdc获取业务人员信息,2295,2295-113,sit,bs
主数据平台:后台运营系统获取业务人员信息接口
"""
from common.common_func import commonFuc
from air_case.cmdc_login.后台管理系统登录.后台管理系统登录 import CmdcDoLogin
from common.db.db import mySql
import random
import requests
import json
module = "cmdc_order_list"
# 第一步登录后台运营系统获取token
username = commonFuc().get_business_data(module, "username2")
password = commonFuc().get_business_data(module, "password2")
# 获取登录后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, "url_list")
request_body = commonFuc().get_business_data(module, "payload_list")
# 发送请求
result = requests.post(url, json=request_body, headers=headers)
result = json.loads(result.content)
# 生成随机数
demand_random = random.randint(0, len(result["data"]["list"]) - 1)
# 获取需求单信息
customerCode = result["data"]["list"][demand_random]["customerCode"]
productLineCode = result["data"]["list"][demand_random]["productLineCode"]
# 第三步根据客户code获取采购协议信息
url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url107")
request_body = commonFuc().get_business_data(module, "payload107", customerCode, productLineCode)
# 发送请求
result = requests.get(url, params=request_body, headers=headers)
result = json.loads(result.content)
# 生成随机数
vp_random = random.randint(0, len(result["data"]) - 1)
# 获取采购协议信息
alesDepartmentName = result["data"][vp_random]["alesDepartmentName"]
sourceSign = result["data"][vp_random]["sourceSign"]
# 第四步获取部门信息
url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url112")
request_body = commonFuc().get_business_data(module, "payload112", alesDepartmentName, sourceSign)
# 发送请求
result = requests.get(url, params=request_body, headers=headers)
result = json.loads(result.content)
# 生成随机数
department_random = random.randint(0, len(result["data"]) - 1)
# 获取部门信息
alesDepartmentNo = result["data"][department_random]["alesDepartmentNo"]
alesDepartmentName = result["data"][department_random]["alesDepartmentName"]
# 第五步获取业务人员信息
url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url113")
request_body = commonFuc().get_business_data(module, "payload113", alesDepartmentNo)
"""
场景: 获取业务人员信息
用例名称:获取业务人员信息
输出:{"total":"%s"}
"""
# 发送请求
result = requests.get(url, params=request_body, headers=headers)
# 获取接口响应时间
api_time = float(result.elapsed.total_seconds())
# 获取业务人员信息
result = json.loads(result.content)
result = {"total": len(result["data"])}
# 将接口响应时间添加至result
result["api_time"] = api_time
# 数据库操作
mysql_handle = mySql()
# 获取conf.ini文件中配置的数据库信息
host, port, user, pwd = mysql_handle.getConf(db="cmdc_db")
# 查询数据库中对应部门的业务人员数量
sql = "SELECT count(t.personId) FROM `cmdc-user`.cmdc_person t " \
"WHERE belong = 00102 and BussinessUnitDesc = '{}' and useFlag = 1".format(alesDepartmentName)
total = mysql_handle.selectSql(host, port, user, pwd, "cmdc-user", sql)[0][0]
# 获取预期结果
check_dict = commonFuc().get_business_data(module, "checkDict112", total)
# print(check_dict)
# 断言实际结果中是否包含预期结果的内容
commonFuc().check_result(check_dict, result)
...@@ -52,9 +52,7 @@ sourceSign = result["data"][vp_random]["sourceSign"] ...@@ -52,9 +52,7 @@ sourceSign = result["data"][vp_random]["sourceSign"]
url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url112") url = commonFuc().get_api_url() + commonFuc().get_business_data(module, "url112")
request_body = commonFuc().get_business_data(module, "payload112", alesDepartmentName, sourceSign) request_body = commonFuc().get_business_data(module, "payload112", alesDepartmentName, sourceSign)
""" """
场景: 获取部门信息 场景: 获取部门信息
用例名称:获取部门信息 用例名称:获取部门信息
输出:{"total":"%s"} 输出:{"total":"%s"}
...@@ -77,7 +75,7 @@ mysql_handle = mySql() ...@@ -77,7 +75,7 @@ mysql_handle = mySql()
# 获取conf.ini文件中配置的数据库信息 # 获取conf.ini文件中配置的数据库信息
host, port, user, pwd = mysql_handle.getConf(db="cmdc_db") host, port, user, pwd = mysql_handle.getConf(db="cmdc_db")
# 查询数据库中采购单数量 # 查询数据库中部门数量
sql = "SELECT count(t.MCMCU) FROM `cmdc-user`.cmdc_vapimcu_jde t WHERE MCCO = 00102" sql = "SELECT count(t.MCMCU) FROM `cmdc-user`.cmdc_vapimcu_jde t WHERE MCCO = 00102"
total = mysql_handle.selectSql(host, port, user, pwd, "cmdc-user", sql)[0][0] total = mysql_handle.selectSql(host, port, user, pwd, "cmdc-user", sql)[0][0]
......
...@@ -725,7 +725,11 @@ checkDict114: {"projectCode":"%s"} ...@@ -725,7 +725,11 @@ checkDict114: {"projectCode":"%s"}
#预期结果 #预期结果
checkDict112: {"total":"%s"} checkDict112: {"total":"%s"}
#测试场景一百一十三:获取业务人员信息
"url113": "/user/public/vapimcuJde/getSalesPerson"
"payload113": {"alesDepartmentNo":"%s"}
#预期结果
checkDict113: {"total":"%s"}
......
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