Skip to content
GitLab
Projects
Groups
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
test
autotest-airtest-web-cmdc
Commits
ba4740d6
Commit
ba4740d6
authored
Mar 29, 2024
by
liguangyu06
Browse files
用例新增:批量导出功能验证_商品信息列表
parent
d95ae5c3
Changes
2
Hide whitespace changes
Inline
Side-by-side
air_case/cmdc_ls/批量导出功能验证_商品信息列表.air/批量导出功能验证_商品信息列表.py
0 → 100644
View file @
ba4740d6
# -*- encoding=utf8 -*-
__author__
=
"liguangyu"
"""
case_tag:cmdc_api,cmdc批量导出功能验证_商品信息列表,2300,2300-22,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
,
"url20"
)
request_body
=
commonFuc
().
get_business_data
(
module
,
"payload20"
)
# 发送请求
result
=
requests
.
post
(
url
,
json
=
request_body
,
headers
=
headers
)
result
=
json
.
loads
(
result
.
content
)
# 生成随机数
good_random
=
random
.
randint
(
0
,
len
(
result
[
"data"
][
"list"
])
-
1
)
# 获取商品信息
goodsInfo
=
result
[
"data"
][
"list"
][
good_random
][
"productCode"
]
productLineName
=
result
[
"data"
][
"list"
][
good_random
][
"productLineName"
]
keynoteSpec
=
result
[
"data"
][
"list"
][
good_random
][
"keynoteSpec"
]
# 第三步进行商品信息批量导出
url
=
commonFuc
().
get_api_url
()
+
commonFuc
().
get_business_data
(
module
,
"url22"
)
request_body
=
commonFuc
().
get_business_data
(
module
,
"payload22"
,
goodsInfo
,
productLineName
,
keynoteSpec
)
"""
场景: 批量导出功能验证_商品信息列表
用例名称:批量导出功能验证_商品信息列表
输出:{"goodsInfo":"%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
=
{
"goodsInfo"
:
excel
.
read_data
()[
0
].
get
(
"商品编码"
)}
# 将接口响应时间添加至result
result
[
"api_time"
]
=
api_time
# 获取预期结果
check_dict
=
commonFuc
().
get_business_data
(
module
,
"checkDict22"
,
goodsInfo
)
# print(check_dict)
# 断言实际结果中是否包含预期结果的内容
commonFuc
().
check_result
(
check_dict
,
result
)
data/cmdc_ls/data
View file @
ba4740d6
...
@@ -156,7 +156,11 @@ checkDict20: {"success":true,"code":"200","message":"OK"}
...
@@ -156,7 +156,11 @@ checkDict20: {"success":true,"code":"200","message":"OK"}
#预期结果
#预期结果
checkDict21: {"goodsInfo":"%s"}
checkDict21: {"goodsInfo":"%s"}
#测试场景22:批量导出功能验证_商品信息列表
"url22": "/cms/public/ls/exportExcel"
"payload22": {"goodsInfo":"%s","productLineName":"%s","keynoteSpec":"%s","pageStart":1,"pageSize":10,"type":"4"}
#预期结果
checkDict22: {"goodsInfo":"%s"}
...
...
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment