Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
oto
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
龚小红
oto
Commits
6c519b7b
Commit
6c519b7b
authored
Sep 01, 2021
by
xiamengchen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
秒杀互动支付成功前流程
parent
f8da03ea
Changes
9
Show whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
604 additions
and
405 deletions
+604
-405
AnchorGetSKList.java
src/test/java/com/kjj/bean/secondKill/AnchorGetSKList.java
+1
-0
Answer.java
src/test/java/com/kjj/cases/live/answer/Answer.java
+0
-10
RelativeLottery.java
...test/java/com/kjj/cases/live/lottery/RelativeLottery.java
+141
-141
ConfSecondKill.java
...st/java/com/kjj/cases/live/secondKill/ConfSecondKill.java
+27
-6
SecondKill.java
src/test/java/com/kjj/cases/live/secondKill/SecondKill.java
+238
-80
Treasure.java
src/test/java/com/kjj/cases/live/treasure/Treasure.java
+13
-0
BasicConfig.java
src/test/java/com/kjj/config/BasicConfig.java
+2
-0
IdMakeUtil.java
src/test/java/com/kjj/utils/IdMakeUtil.java
+14
-0
liveTestNG.xml
src/test/liveTestNG.xml
+168
-168
No files found.
src/test/java/com/kjj/bean/secondKill/AnchorGetSKList.java
View file @
6c519b7b
...
@@ -7,4 +7,5 @@ public class AnchorGetSKList {
...
@@ -7,4 +7,5 @@ public class AnchorGetSKList {
private
int
interactStatus
;
private
int
interactStatus
;
private
String
id
;
private
String
id
;
private
int
surplusNum
;
private
int
surplusNum
;
private
String
goodsId
;
}
}
src/test/java/com/kjj/cases/live/answer/Answer.java
View file @
6c519b7b
...
@@ -229,16 +229,6 @@ public class Answer implements Authorization {
...
@@ -229,16 +229,6 @@ public class Answer implements Authorization {
//访客端
//访客端
/*查询访客端有奖答题配置详情*/
/*查询访客端有奖答题配置详情*/
@Test
(
description
=
"代理人关系绑定"
,
priority
=
11
)
public
void
代理人关系绑定
()
{
agentAuth
();
Map
<
String
,
Object
>
bindingParam
=
new
HashMap
<>();
bindingParam
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
Response
bindingRes
=
network
.
postResponse
(
bindingParam
,
BasicConfig
.
MOBILE_binding
);
boolean
success
=
bindingRes
.
jsonPath
().
getJsonObject
(
"success"
);
System
.
out
.
println
(
success
);
Assert
.
assertTrue
(
success
,
network
.
message
(
bindingParam
,
BasicConfig
.
MOBILE_binding
,
"绑定失败"
,
bindingRes
.
body
().
asString
()));
}
@Test
(
description
=
"访客A查询答题红包配置"
,
priority
=
12
)
@Test
(
description
=
"访客A查询答题红包配置"
,
priority
=
12
)
public
void
访客
A
查询答题红包配置
()
public
void
访客
A
查询答题红包配置
()
{
{
...
...
src/test/java/com/kjj/cases/live/lottery/RelativeLottery.java
View file @
6c519b7b
...
@@ -65,145 +65,145 @@ public class RelativeLottery implements Authorization {
...
@@ -65,145 +65,145 @@ public class RelativeLottery implements Authorization {
}
}
@Test
(
description
=
"访客H收下抽奖券"
,
priority
=
3
)
//
@Test(description = "访客H收下抽奖券", priority = 3)
public
void
访客
H
收下抽奖券
()
{
//
public void 访客H收下抽奖券() {
visitorAuth9
();
//
visitorAuth9();
Map
<
String
,
Object
>
bindingParam
=
new
HashMap
<>();
//
Map<String, Object> bindingParam = new HashMap<>();
bindingParam
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
bindingParam.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
Response
bindingRes
=
network
.
postResponse
(
bindingParam
,
MOBILE_acceptLottery
);
//
Response bindingRes = network.postResponse(bindingParam, MOBILE_acceptLottery);
boolean
success
=
bindingRes
.
jsonPath
().
getJsonObject
(
"success"
);
//
boolean success = bindingRes.jsonPath().getJsonObject("success");
Assert
.
assertTrue
(
success
,
network
.
message
(
bindingParam
,
MOBILE_acceptLottery
,
"绑定失败"
,
bindingRes
.
body
().
asString
()));
//
Assert.assertTrue(success, network.message(bindingParam, MOBILE_acceptLottery, "绑定失败", bindingRes.body().asString()));
}
//
}
//
@Test
(
description
=
"访客H_分享直播间"
,
priority
=
5
)
//
@Test(description = "访客H_分享直播间", priority = 5)
public
void
访客
H_
分享直播间
()
{
//
public void 访客H_分享直播间() {
sleep
(
1000
);
//
sleep(1000);
Map
<
String
,
Object
>
signParam
=
new
HashMap
<>();
//
Map<String, Object> signParam = new HashMap<>();
signParam
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
signParam.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
signParam
.
put
(
"shareType"
,
10
);
//
signParam.put("shareType", 10);
Response
signRes
=
network
.
getResponse
(
signParam
,
MOBILE_sign
);
//
Response signRes = network.getResponse(signParam, MOBILE_sign);
System
.
out
.
println
(
signRes
.
body
().
asString
());
//
System.out.println(signRes.body().asString());
String
data
=
signRes
.
jsonPath
().
getString
(
"data"
);
//
String data = signRes.jsonPath().getString("data");
this
.
shareSign
=
data
;
//
this.shareSign = data;
Assert
.
assertNotNull
(
shareSign
,
network
.
message
(
signParam
,
MOBILE_sign
,
"分享失败"
,
signRes
.
body
().
asString
()));
//
Assert.assertNotNull(shareSign, network.message(signParam, MOBILE_sign, "分享失败", signRes.body().asString()));
//
}
//
}
//
@Test
(
description
=
"根据分享类型获取分享内容"
,
priority
=
6
)
//
@Test(description = "根据分享类型获取分享内容", priority = 6)
public
void
根据分享类型获取分享内容
()
{
//
public void 根据分享类型获取分享内容() {
Map
<
String
,
Object
>
params
=
new
HashMap
<>();
//
Map<String, Object> params = new HashMap<>();
params
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
params.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
params
.
put
(
"shareType"
,
14
);
//
params.put("shareType",14);
params
.
put
(
"userType"
,
"A"
);
//
params.put("userType","A");
Response
response
=
network
.
getResponse
(
params
,
BasicConfig
.
MOBILE_helpInfo
);
//
Response response = network.getResponse(params, BasicConfig.MOBILE_helpInfo);
System
.
out
.
println
(
response
.
body
().
asString
());
//
System.out.println(response.body().asString());
Object
mpShareTitle
=
response
.
jsonPath
().
getJsonObject
(
"data.mpShareTitle"
);
//
Object mpShareTitle = response.jsonPath().getJsonObject("data.mpShareTitle");
Assert
.
assertEquals
(
mpShareTitle
,
"亲友抽奖券分享文案"
,
network
.
message
(
params
,
BasicConfig
.
MOBILE_helpInfo
,
"根据分享类型获取分享内容"
,
response
.
body
().
asString
()));
//
Assert.assertEquals(mpShareTitle,"亲友抽奖券分享文案", network.message(params, BasicConfig.MOBILE_helpInfo, "根据分享类型获取分享内容", response.body().asString()));
}
//
}
//
@Test
(
description
=
"访客H_获取小程序分享码"
,
priority
=
7
)
//
@Test(description = "访客H_获取小程序分享码", priority = 7)
public
void
访客
H_
获取小程序分享码
()
{
//
public void 访客H_获取小程序分享码() {
sleep
(
1000
);
//
sleep(1000);
Map
<
String
,
Object
>
signParam
=
new
HashMap
<>();
//
Map<String, Object> signParam = new HashMap<>();
signParam
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
signParam.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
Response
response
=
network
.
postResponse
(
signParam
,
MOBILE_codeLottery
);
//
Response response = network.postResponse(signParam, MOBILE_codeLottery);
System
.
out
.
println
(
response
.
body
().
asString
());
//
System.out.println(response.body().asString());
boolean
data
=
response
.
jsonPath
().
getBoolean
(
"data"
);
//
boolean data = response.jsonPath().getBoolean("data");
Assert
.
assertNotNull
(
data
,
network
.
message
(
signParam
,
MOBILE_codeLottery
,
"分享失败"
,
response
.
body
().
asString
()));
//
Assert.assertNotNull(data, network.message(signParam, MOBILE_codeLottery, "分享失败", response.body().asString()));
//
sleep
(
3000
);
//
sleep(3000);
response
=
network
.
getResponse
(
signParam
,
MOBILE_codeDetailLottery
);
//
response = network.getResponse(signParam, MOBILE_codeDetailLottery);
System
.
out
.
println
(
response
.
body
().
asString
());
//
System.out.println(response.body().asString());
boolean
qrCodeUrl
=
response
.
jsonPath
().
getBoolean
(
"data.qrCodeUrl"
);
//
boolean qrCodeUrl = response.jsonPath().getBoolean("data.qrCodeUrl");
Assert
.
assertNotNull
(
qrCodeUrl
,
network
.
message
(
signParam
,
MOBILE_codeDetailLottery
,
"分享失败"
,
response
.
body
().
asString
()));
//
Assert.assertNotNull(qrCodeUrl, network.message(signParam, MOBILE_codeDetailLottery, "分享失败", response.body().asString()));
}
//
}
//
@Test
(
description
=
"访客H获取直播所有的订阅消息模板"
,
priority
=
8
)
//
@Test(description = "访客H获取直播所有的订阅消息模板", priority = 8)
public
void
访客
H
获取直播所有的订阅消息模板
()
{
//
public void 访客H获取直播所有的订阅消息模板() {
visitorAuth9
();
//
visitorAuth9();
Map
<
String
,
Object
>
sycParam
=
new
HashMap
<>();
//
Map<String, Object> sycParam = new HashMap<>();
sycParam
.
put
(
"appid"
,
"wx4d7276f866bd24c8"
);
//
sycParam.put("appid","wx4d7276f866bd24c8");
Response
sycRes
=
network
.
postResponse
(
sycParam
,
BasicConfig
.
USER_wxIdAllList
);
//
Response sycRes = network.postResponse(sycParam, BasicConfig.USER_wxIdAllList);
System
.
out
.
println
(
sycRes
.
body
().
asString
());
//
System.out.println(sycRes.body().asString());
Object
data
=
sycRes
.
jsonPath
().
getJsonObject
(
"data"
);
//
Object data = sycRes.jsonPath().getJsonObject("data");
Assert
.
assertNotNull
(
data
,
network
.
message
(
sycParam
,
BasicConfig
.
USER_wxIdAllList
,
"获取订阅消息失败"
,
sycRes
.
body
().
asString
()));
//
Assert.assertNotNull(data, network.message(sycParam, BasicConfig.USER_wxIdAllList, "获取订阅消息失败", sycRes.body().asString()));
}
//
}
//
@Test
(
description
=
"邀请Xmz关系绑定"
,
priority
=
9
)
//
@Test(description = "邀请Xmz关系绑定", priority = 9)
public
void
邀请
Xmz
关系绑定
()
{
//
public void 邀请Xmz关系绑定() {
visitorAuth26
();
//
visitorAuth26();
Map
<
String
,
Object
>
bindingParam
=
new
HashMap
<>();
//
Map<String, Object> bindingParam = new HashMap<>();
bindingParam
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
bindingParam.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
bindingParam
.
put
(
"shareSign"
,
shareSign
);
//
bindingParam.put("shareSign", shareSign);
Response
bindingRes
=
network
.
postResponse
(
bindingParam
,
MOBILE_binding
);
//
Response bindingRes = network.postResponse(bindingParam, MOBILE_binding);
boolean
success
=
bindingRes
.
jsonPath
().
getJsonObject
(
"success"
);
//
boolean success = bindingRes.jsonPath().getJsonObject("success");
Assert
.
assertTrue
(
success
,
network
.
message
(
bindingParam
,
MOBILE_binding
,
"绑定失败"
,
bindingRes
.
body
().
asString
()));
//
Assert.assertTrue(success, network.message(bindingParam, MOBILE_binding, "绑定失败", bindingRes.body().asString()));
}
//
}
//
//
@Test
(
description
=
"查询访客Xmz绑定结果和绑定凭证"
,
priority
=
10
)
//
@Test(description = "查询访客Xmz绑定结果和绑定凭证", priority = 10)
public
void
查询访客
Xmz
绑定结果和绑定凭证
()
{
//
public void 查询访客Xmz绑定结果和绑定凭证() {
visitorAuth26
();
//
visitorAuth26();
sleep
(
2000
);
//
sleep(2000);
Map
<
String
,
Object
>
tokenParam
=
new
HashMap
<>();
//
Map<String, Object> tokenParam = new HashMap<>();
tokenParam
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
tokenParam.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
Response
tokenRes
=
network
.
getResponse
(
tokenParam
,
BasicConfig
.
MOBILE_Token
);
//
Response tokenRes = network.getResponse(tokenParam, BasicConfig.MOBILE_Token);
boolean
success
=
tokenRes
.
jsonPath
().
getJsonObject
(
"success"
);
//
boolean success = tokenRes.jsonPath().getJsonObject("success");
Integer
type
=
tokenRes
.
jsonPath
().
getInt
(
"data.type"
);
//
Integer type = tokenRes.jsonPath().getInt("data.type");
Assert
.
assertTrue
(
type
==
3
,
network
.
message
(
tokenParam
,
BasicConfig
.
MOBILE_Token
,
"未获取到绑定结果"
,
tokenRes
.
body
().
asString
()));
//
Assert.assertTrue(type==3, network.message(tokenParam, BasicConfig.MOBILE_Token, "未获取到绑定结果", tokenRes.body().asString()));
}
//
}
//
@Test
(
description
=
"访客A预约直播间"
,
priority
=
11
)
//
@Test(description = "访客A预约直播间", priority = 11)
public
void
访客
A
预约直播间
()
{
//
public void 访客A预约直播间() {
visitorAuth26
();
//
visitorAuth26();
Map
<
String
,
Object
>
sycParam
=
new
HashMap
<>();
//
Map<String, Object> sycParam = new HashMap<>();
sycParam
.
put
(
"bizId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
sycParam.put("bizId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
sycParam
.
put
(
"bizType"
,
1
);
//
sycParam.put("bizType", 1);
List
<
Long
>
markIds1
=
new
ArrayList
<>();
//
List<Long> markIds1 = new ArrayList<>();
markIds1
.
add
(
142L
);
//
markIds1.add(142L);
markIds1
.
add
(
143L
);
//
markIds1.add(143L);
markIds1
.
add
(
140L
);
//
markIds1.add(140L);
sycParam
.
put
(
"markIds"
,
markIds1
);
//
sycParam.put("markIds", markIds1);
Response
sycRes
=
network
.
postResponse
(
sycParam
,
BasicConfig
.
USER_SYCAPPOINTMENT
);
//
Response sycRes = network.postResponse(sycParam, BasicConfig.USER_SYCAPPOINTMENT);
Object
data
=
sycRes
.
jsonPath
().
getJsonObject
(
"data"
);
//
Object data = sycRes.jsonPath().getJsonObject("data");
System
.
out
.
println
(
data
);
//
System.out.println(data);
Assert
.
assertNotNull
(
data
,
network
.
message
(
sycParam
,
BasicConfig
.
USER_SYCAPPOINTMENT
,
"预约失败"
,
sycRes
.
body
().
asString
()));
//
Assert.assertNotNull(data, network.message(sycParam, BasicConfig.USER_SYCAPPOINTMENT, "预约失败", sycRes.body().asString()));
}
//
}
//
@Test
(
description
=
"访客Xmz给访客H助力"
,
priority
=
12
)
//
@Test(description = "访客Xmz给访客H助力", priority = 12)
public
void
访客
Xmz
给访客
H
助力
()
{
//
public void 访客Xmz给访客H助力() {
visitorAuth26
();
//
visitorAuth26();
sleep
(
2000
);
//
sleep(2000);
//获取授权配置助力弹窗
//
//获取授权配置助力弹窗
Map
<
String
,
Object
>
Params
=
new
HashMap
<>();
//
Map<String, Object> Params = new HashMap<>();
Params
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
Params.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
Params
.
put
(
"shareType"
,
14
);
//
Params.put("shareType",14);
Response
response
=
network
.
getResponse
(
Params
,
BasicConfig
.
MOBILE_popupDetail
);
//
Response response=network.getResponse(Params,BasicConfig.MOBILE_popupDetail);
System
.
out
.
println
(
response
.
body
().
asString
());
//
System.out.println(response.body().asString());
String
helpImg
=
response
.
jsonPath
().
getString
(
"data.currentPopup.helpImg"
);
//
String helpImg=response.jsonPath().getString("data.currentPopup.helpImg");
Assert
.
assertNotNull
(
helpImg
,
network
.
message
(
Params
,
BasicConfig
.
MOBILE_popupDetail
,
"助力弹窗为null"
,
response
.
body
().
asString
()));
//
Assert.assertNotNull(helpImg,network.message(Params,BasicConfig.MOBILE_popupDetail,"助力弹窗为null",response.body().asString()));
//
Params
.
clear
();
//
Params.clear();
Params
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
Params.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
Params
.
put
(
"shareSign"
,
shareSign
);
//
Params.put("shareSign",shareSign);
Params
.
put
(
"shareType"
,
14
);
//
Params.put("shareType",14);
Params
.
put
(
"confId"
,
confId
);
//
Params.put("confId",confId);
response
=
network
.
postResponse
(
Params
,
BasicConfig
.
MOBILE_assist
);
//
response = network.postResponse(Params, BasicConfig.MOBILE_assist);
System
.
out
.
println
(
response
.
body
().
asString
());
//
System.out.println(response.body().asString());
boolean
data
=
response
.
jsonPath
().
getBoolean
(
"data"
);
//
boolean data = response.jsonPath().getBoolean("data");
Assert
.
assertTrue
(
data
,
network
.
message
(
Params
,
BasicConfig
.
MOBILE_assist
,
"访客Xmz给访客H助力失败"
,
response
.
body
().
asString
()));
//
Assert.assertTrue(data, network.message(Params, BasicConfig.MOBILE_assist, "访客Xmz给访客H助力失败", response.body().asString()));
}
//
}
//
@Test
(
description
=
"查询亲友券被领取1张"
,
priority
=
13
)
//
@Test(description = "查询亲友券被领取1张", priority = 13)
public
void
查询亲友券被领取
1
张
()
{
//
public void 查询亲友券被领取1张() {
visitorAuth9
();
//
visitorAuth9();
Map
<
String
,
Object
>
getLiveAwardListParam
=
new
HashMap
<>();
//
Map<String, Object> getLiveAwardListParam = new HashMap<>();
getLiveAwardListParam
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
//
getLiveAwardListParam.put("liveId", LiveConstants.getValue(LiveConstants.StringKeyEnum.ENCODE_LIVE_ID.getKey()));
Response
response
=
network
.
getResponse
(
getLiveAwardListParam
,
MOBILE_confLottery
);
//
Response response = network.getResponse(getLiveAwardListParam, MOBILE_confLottery);
System
.
out
.
println
(
response
.
body
().
asString
());
//
System.out.println(response.body().asString());
int
receiverInfoList
=
response
.
jsonPath
().
getInt
(
"data.userDetail.receiverInfoList.size()"
);
//
int receiverInfoList = response.jsonPath().getInt("data.userDetail.receiverInfoList.size()");
String
nickname
=
response
.
jsonPath
().
getString
(
"data.userDetail.receiverInfoList.get(0).nickname"
);
//
String nickname = response.jsonPath().getString("data.userDetail.receiverInfoList.get(0).nickname");
Assert
.
assertEquals
(
receiverInfoList
,
1
,
network
.
message
(
getLiveAwardListParam
,
MOBILE_confLottery
,
"亲友配置券已接受人数错误"
,
response
.
body
().
asString
()));
//
Assert.assertEquals(receiverInfoList, 1,network.message(getLiveAwardListParam, MOBILE_confLottery, "亲友配置券已接受人数错误", response.body().asString()));
Assert
.
assertEquals
(
nickname
,
"小米粥"
,
network
.
message
(
getLiveAwardListParam
,
MOBILE_confLottery
,
"亲友配置券领取人错误"
,
response
.
body
().
asString
()));
//
Assert.assertEquals(nickname, "小米粥",network.message(getLiveAwardListParam, MOBILE_confLottery, "亲友配置券领取人错误", response.body().asString()));
}
//
}
}
}
src/test/java/com/kjj/cases/live/secondKill/ConfSecondKill.java
View file @
6c519b7b
...
@@ -24,7 +24,8 @@ public class ConfSecondKill implements Authorization {
...
@@ -24,7 +24,8 @@ public class ConfSecondKill implements Authorization {
private
long
newSecKillId
;
// 会被删除的秒杀id
private
long
newSecKillId
;
// 会被删除的秒杀id
private
static
final
long
secKillGoodsId
=
115
;
// 用来配置轮次的秒杀商品ID
private
static
final
long
secKillGoodsId
=
115
;
// 用来配置轮次的秒杀商品ID
public
static
final
String
secKillGoodsIdEncode
=
IdMakeUtil
.
managerEncodingId
(
secKillGoodsId
);
public
static
final
String
secKillGoodsIdEncode
=
IdMakeUtil
.
managerEncodingId
(
secKillGoodsId
);
private
String
skId
;
// 秒杀id
public
static
String
skIdFirst
;
// 第一轮秒杀id
public
static
String
skIdSecond
;
// 第二轮秒杀ID
public
static
int
killListSize
;
public
static
int
killListSize
;
@BeforeClass
@BeforeClass
...
@@ -194,7 +195,25 @@ public class ConfSecondKill implements Authorization {
...
@@ -194,7 +195,25 @@ public class ConfSecondKill implements Authorization {
}
}
}
}
@Test
(
description
=
"助播端获取秒杀轮次列表"
,
priority
=
8
)
@Test
(
description
=
"新增第二轮秒杀"
,
priority
=
8
)
public
void
新增第二轮秒杀
()
{
Map
<
String
,
Object
>
secKillAddPar
=
new
HashMap
<>();
secKillAddPar
.
put
(
"goodsId"
,
secKillGoodsIdEncode
);
secKillAddPar
.
put
(
"goodsAmount"
,
1
);
// 1 == 0.01
secKillAddPar
.
put
(
"interactNum"
,
1
);
secKillAddPar
.
put
(
"ableAgent"
,
1
);
// 代理人可参与
secKillAddPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
Response
secKillAddRes
=
network
.
postResponse
(
secKillAddPar
,
BasicConfig
.
ANCHOR_secondKillSave
);
try
{
boolean
data
=
secKillAddRes
.
jsonPath
().
getBoolean
(
"data"
);
Assert
.
assertTrue
(
data
,
network
.
message
(
secKillAddPar
,
BasicConfig
.
ANCHOR_secondKillSave
,
"新增轮次失败"
,
secKillAddRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
secKillAddPar
,
BasicConfig
.
ANCHOR_secondKillSave
,
"未获取到数据"
,
secKillAddRes
.
body
().
asString
()));
}
}
@Test
(
description
=
"助播端获取秒杀轮次列表"
,
priority
=
9
)
public
void
助播端获取秒杀轮次列表
()
{
public
void
助播端获取秒杀轮次列表
()
{
Map
<
String
,
Object
>
liveSecKillPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
liveSecKillPar
=
new
HashMap
<>();
liveSecKillPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
liveSecKillPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
...
@@ -203,8 +222,10 @@ public class ConfSecondKill implements Authorization {
...
@@ -203,8 +222,10 @@ public class ConfSecondKill implements Authorization {
try
{
try
{
secKillLists
=
JsonUtil
.
parseResponseToListBean
(
liveSecKillRes
,
AnchorGetSKList
.
class
);
secKillLists
=
JsonUtil
.
parseResponseToListBean
(
liveSecKillRes
,
AnchorGetSKList
.
class
);
killListSize
=
secKillLists
.
size
();
killListSize
=
secKillLists
.
size
();
skId
=
secKillLists
.
get
(
killListSize
-
1
).
getId
();
String
goodsId
=
secKillLists
.
get
(
0
).
getGoodsId
();
System
.
out
.
println
(
skId
);
Assert
.
assertEquals
(
goodsId
,
secKillGoodsIdEncode
,
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"轮次对应商品ID错误"
,
liveSecKillRes
.
body
().
asString
()));
skIdFirst
=
secKillLists
.
get
(
0
).
getId
();
skIdSecond
=
secKillLists
.
get
(
1
).
getId
();
}
catch
(
Exception
e
){
}
catch
(
Exception
e
){
e
.
printStackTrace
();
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"未获取到数据"
,
liveSecKillRes
.
body
().
asString
()));
Assert
.
fail
(
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"未获取到数据"
,
liveSecKillRes
.
body
().
asString
()));
...
@@ -212,13 +233,13 @@ public class ConfSecondKill implements Authorization {
...
@@ -212,13 +233,13 @@ public class ConfSecondKill implements Authorization {
}
}
@Test
(
description
=
"助播端编辑秒杀轮次"
,
priority
=
9
)
@Test
(
description
=
"助播端编辑秒杀轮次"
,
priority
=
10
)
public
void
助播端编辑秒杀轮次
()
{
public
void
助播端编辑秒杀轮次
()
{
Map
<
String
,
Object
>
secKillUpdatePar
=
new
HashMap
<>();
Map
<
String
,
Object
>
secKillUpdatePar
=
new
HashMap
<>();
secKillUpdatePar
.
put
(
"goodsId"
,
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsId"
,
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"interactNum"
,
3
);
secKillUpdatePar
.
put
(
"interactNum"
,
3
);
secKillUpdatePar
.
put
(
"id"
,
skId
);
secKillUpdatePar
.
put
(
"id"
,
skId
First
);
secKillUpdatePar
.
put
(
"ableAgent"
,
0
);
secKillUpdatePar
.
put
(
"ableAgent"
,
0
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
try
{
try
{
...
...
src/test/java/com/kjj/cases/live/secondKill/SecondKill.java
View file @
6c519b7b
...
@@ -2,7 +2,6 @@ package com.kjj.cases.live.secondKill;
...
@@ -2,7 +2,6 @@ package com.kjj.cases.live.secondKill;
import
com.kjj.bean.secondKill.AnchorGetSKList
;
import
com.kjj.bean.secondKill.AnchorGetSKList
;
import
com.kjj.bean.secondKill.KillGoods
;
import
com.kjj.bean.secondKill.KillGoods
;
import
com.kjj.bean.secondKill.SecondKillList
;
import
com.kjj.cases.admin.Authorization
;
import
com.kjj.cases.admin.Authorization
;
import
com.kjj.config.BasicConfig
;
import
com.kjj.config.BasicConfig
;
import
com.kjj.constants.LiveConstants
;
import
com.kjj.constants.LiveConstants
;
...
@@ -15,13 +14,12 @@ import org.testng.Assert;
...
@@ -15,13 +14,12 @@ import org.testng.Assert;
import
org.testng.annotations.BeforeClass
;
import
org.testng.annotations.BeforeClass
;
import
org.testng.annotations.Test
;
import
org.testng.annotations.Test
;
import
java.util.Date
;
import
java.util.HashMap
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Map
;
public
class
SecondKill
implements
Authorization
{
public
class
SecondKill
implements
Authorization
{
private
String
secKillId
;
// 第一轮秒杀id
private
String
confId1
;
// 第一轮秒杀confId
@BeforeClass
@BeforeClass
public
void
setUp
(){
public
void
setUp
(){
...
@@ -31,23 +29,6 @@ public class SecondKill implements Authorization {
...
@@ -31,23 +29,6 @@ public class SecondKill implements Authorization {
/**
/**
* 直播中编辑秒杀轮次
* 直播中编辑秒杀轮次
*/
*/
@Test
(
description
=
"获取第一轮秒杀信息"
,
priority
=
1
)
public
void
获取第一轮秒杀信息
()
{
Map
<
String
,
Object
>
liveSecKillPar
=
new
HashMap
<>();
liveSecKillPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
LIVE_ID
.
getKey
()));
Response
liveSecKillRes
=
network
.
getResponse
(
liveSecKillPar
,
BasicConfig
.
MANAGER_secondKillLists
);
List
<
SecondKillList
>
secondKillLists
;
SecondKillList
secondKillList
=
null
;
try
{
secondKillLists
=
JsonUtil
.
parseResponseToListBean
(
liveSecKillRes
,
SecondKillList
.
class
);
secondKillList
=
secondKillLists
.
get
(
0
);
}
catch
(
Exception
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
liveSecKillPar
,
BasicConfig
.
MANAGER_secondKillLists
,
"未获取到数据"
,
liveSecKillRes
.
body
().
asString
()));
}
secKillId
=
IdMakeUtil
.
managerEncodingId
(
secondKillList
.
getId
());
System
.
out
.
println
(
secKillId
);
}
@Test
(
description
=
"修改秒杀商品"
,
priority
=
2
)
@Test
(
description
=
"修改秒杀商品"
,
priority
=
2
)
public
void
修改秒杀商品
()
{
public
void
修改秒杀商品
()
{
...
@@ -55,8 +36,8 @@ public class SecondKill implements Authorization {
...
@@ -55,8 +36,8 @@ public class SecondKill implements Authorization {
secKillUpdatePar
.
put
(
"goodsId"
,
IdMakeUtil
.
managerEncodingId
(
111
));
secKillUpdatePar
.
put
(
"goodsId"
,
IdMakeUtil
.
managerEncodingId
(
111
));
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"interactNum"
,
3
);
secKillUpdatePar
.
put
(
"interactNum"
,
3
);
secKillUpdatePar
.
put
(
"id"
,
secKillId
);
secKillUpdatePar
.
put
(
"id"
,
ConfSecondKill
.
skIdFirst
);
secKillUpdatePar
.
put
(
"ableAgent"
,
0
);
secKillUpdatePar
.
put
(
"ableAgent"
,
1
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
System
.
out
.
println
(
secKillUpdateRes
.
body
().
asString
());
System
.
out
.
println
(
secKillUpdateRes
.
body
().
asString
());
}
}
...
@@ -67,8 +48,8 @@ public class SecondKill implements Authorization {
...
@@ -67,8 +48,8 @@ public class SecondKill implements Authorization {
secKillUpdatePar
.
put
(
"goodsId"
,
ConfSecondKill
.
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsId"
,
ConfSecondKill
.
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
5
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
5
);
secKillUpdatePar
.
put
(
"interactNum"
,
3
);
secKillUpdatePar
.
put
(
"interactNum"
,
3
);
secKillUpdatePar
.
put
(
"id"
,
secKillId
);
secKillUpdatePar
.
put
(
"id"
,
ConfSecondKill
.
skIdFirst
);
secKillUpdatePar
.
put
(
"ableAgent"
,
0
);
secKillUpdatePar
.
put
(
"ableAgent"
,
1
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
System
.
out
.
println
(
secKillUpdateRes
.
body
().
asString
());
System
.
out
.
println
(
secKillUpdateRes
.
body
().
asString
());
}
}
...
@@ -79,8 +60,8 @@ public class SecondKill implements Authorization {
...
@@ -79,8 +60,8 @@ public class SecondKill implements Authorization {
secKillUpdatePar
.
put
(
"goodsId"
,
ConfSecondKill
.
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsId"
,
ConfSecondKill
.
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"interactNum"
,
1
);
secKillUpdatePar
.
put
(
"interactNum"
,
1
);
secKillUpdatePar
.
put
(
"id"
,
secKillId
);
secKillUpdatePar
.
put
(
"id"
,
ConfSecondKill
.
skIdFirst
);
secKillUpdatePar
.
put
(
"ableAgent"
,
0
);
secKillUpdatePar
.
put
(
"ableAgent"
,
1
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
System
.
out
.
println
(
secKillUpdateRes
.
body
().
asString
());
System
.
out
.
println
(
secKillUpdateRes
.
body
().
asString
());
}
}
...
@@ -91,8 +72,8 @@ public class SecondKill implements Authorization {
...
@@ -91,8 +72,8 @@ public class SecondKill implements Authorization {
secKillUpdatePar
.
put
(
"goodsId"
,
ConfSecondKill
.
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsId"
,
ConfSecondKill
.
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"interactNum"
,
4
);
secKillUpdatePar
.
put
(
"interactNum"
,
4
);
secKillUpdatePar
.
put
(
"id"
,
secKillId
);
secKillUpdatePar
.
put
(
"id"
,
ConfSecondKill
.
skIdFirst
);
secKillUpdatePar
.
put
(
"ableAgent"
,
0
);
secKillUpdatePar
.
put
(
"ableAgent"
,
1
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
try
{
try
{
boolean
data
=
secKillUpdateRes
.
jsonPath
().
getBoolean
(
"data"
);
boolean
data
=
secKillUpdateRes
.
jsonPath
().
getBoolean
(
"data"
);
...
@@ -109,8 +90,8 @@ public class SecondKill implements Authorization {
...
@@ -109,8 +90,8 @@ public class SecondKill implements Authorization {
secKillUpdatePar
.
put
(
"goodsId"
,
ConfSecondKill
.
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsId"
,
ConfSecondKill
.
secKillGoodsIdEncode
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"goodsAmount"
,
1
);
secKillUpdatePar
.
put
(
"interactNum"
,
4
);
secKillUpdatePar
.
put
(
"interactNum"
,
4
);
secKillUpdatePar
.
put
(
"id"
,
secKillId
);
secKillUpdatePar
.
put
(
"id"
,
ConfSecondKill
.
skIdFirst
);
secKillUpdatePar
.
put
(
"ableAgent"
,
1
);
secKillUpdatePar
.
put
(
"ableAgent"
,
0
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
Response
secKillUpdateRes
=
network
.
postResponse
(
secKillUpdatePar
,
BasicConfig
.
ANCHOR_secondKillUpdate
);
try
{
try
{
boolean
data
=
secKillUpdateRes
.
jsonPath
().
getBoolean
(
"data"
);
boolean
data
=
secKillUpdateRes
.
jsonPath
().
getBoolean
(
"data"
);
...
@@ -137,14 +118,14 @@ public class SecondKill implements Authorization {
...
@@ -137,14 +118,14 @@ public class SecondKill implements Authorization {
e
.
printStackTrace
();
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
goodsListPar
,
BasicConfig
.
MOBILE_secondKill_getGoodsList
,
"未获取到数据"
,
goodsListRes
.
body
().
asString
()));
Assert
.
fail
(
network
.
message
(
goodsListPar
,
BasicConfig
.
MOBILE_secondKill_getGoodsList
,
"未获取到数据"
,
goodsListRes
.
body
().
asString
()));
}
}
confId1
=
goodsListRes
.
jsonPath
().
getString
(
"data[0].confId"
);
ConfSecondKill
.
skIdFirst
=
goodsListRes
.
jsonPath
().
getString
(
"data[0].confId"
);
}
}
@Test
(
description
=
"查看秒杀商品详情"
,
priority
=
8
)
@Test
(
description
=
"查看秒杀商品详情"
,
priority
=
8
)
public
void
查看秒杀商品详情
()
{
public
void
查看秒杀商品详情
()
{
Map
<
String
,
Object
>
goodsDetailPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
goodsDetailPar
=
new
HashMap
<>();
goodsDetailPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
goodsDetailPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
goodsDetailPar
.
put
(
"confId"
,
confId1
);
goodsDetailPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
goodsDetailRes
=
network
.
getResponse
(
goodsDetailPar
,
BasicConfig
.
MOBILE_secondKill_getGoodsDetail
);
Response
goodsDetailRes
=
network
.
getResponse
(
goodsDetailPar
,
BasicConfig
.
MOBILE_secondKill_getGoodsDetail
);
try
{
try
{
String
goodsTitle
=
goodsDetailRes
.
jsonPath
().
getString
(
"data.goodsTitle"
);
String
goodsTitle
=
goodsDetailRes
.
jsonPath
().
getString
(
"data.goodsTitle"
);
...
@@ -162,7 +143,7 @@ public class SecondKill implements Authorization {
...
@@ -162,7 +143,7 @@ public class SecondKill implements Authorization {
public
void
助播端上架秒杀
()
{
public
void
助播端上架秒杀
()
{
adminAuth
();
adminAuth
();
Map
<
String
,
Object
>
goodsOnPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
goodsOnPar
=
new
HashMap
<>();
goodsOnPar
.
put
(
"id"
,
secKillId
);
goodsOnPar
.
put
(
"id"
,
ConfSecondKill
.
skIdFirst
);
Response
goodsOnRes
=
network
.
postResponse
(
goodsOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
);
Response
goodsOnRes
=
network
.
postResponse
(
goodsOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
);
try
{
try
{
boolean
data
=
goodsOnRes
.
jsonPath
().
getBoolean
(
"data"
);
boolean
data
=
goodsOnRes
.
jsonPath
().
getBoolean
(
"data"
);
...
@@ -186,8 +167,26 @@ public class SecondKill implements Authorization {
...
@@ -186,8 +167,26 @@ public class SecondKill implements Authorization {
}
}
}
}
@Test
(
description
=
"无法同时上架多轮秒杀"
,
priority
=
10
)
public
void
无法同时上架多轮秒杀
()
{
Map
<
String
,
Object
>
goodsOnPar
=
new
HashMap
<>();
goodsOnPar
.
put
(
"id"
,
ConfSecondKill
.
skIdSecond
);
Response
goodsOnRes
=
network
.
postResponse
(
goodsOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
);
try
{
boolean
success
=
goodsOnRes
.
jsonPath
().
getBoolean
(
"success"
);
if
(
success
){
Assert
.
fail
(
network
.
message
(
goodsOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
,
"同时上架多轮秒杀成功"
,
goodsOnRes
.
body
().
asString
()));
}
String
code
=
goodsOnRes
.
jsonPath
().
getString
(
"code"
);
Assert
.
assertEquals
(
code
,
"07230005"
,
network
.
message
(
goodsOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
,
"失败原因错误"
,
goodsOnRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
goodsOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
,
"未获取到数据"
,
goodsOnRes
.
body
().
asString
()));
}
}
// 切换访客
// 切换访客
@Test
(
description
=
"查看当前秒杀商品"
,
priority
=
1
0
)
@Test
(
description
=
"查看当前秒杀商品"
,
priority
=
1
1
)
public
void
查看当前秒杀商品
()
{
public
void
查看当前秒杀商品
()
{
visitorAuth
();
visitorAuth
();
Map
<
String
,
Object
>
goodsFirstPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
goodsFirstPar
=
new
HashMap
<>();
...
@@ -195,23 +194,37 @@ public class SecondKill implements Authorization {
...
@@ -195,23 +194,37 @@ public class SecondKill implements Authorization {
Response
goodsFirstRes
=
network
.
getResponse
(
goodsFirstPar
,
BasicConfig
.
MOBILE_secondKill_goodsFirst
);
Response
goodsFirstRes
=
network
.
getResponse
(
goodsFirstPar
,
BasicConfig
.
MOBILE_secondKill_goodsFirst
);
try
{
try
{
String
confId
=
goodsFirstRes
.
jsonPath
().
getString
(
"data.confId"
);
String
confId
=
goodsFirstRes
.
jsonPath
().
getString
(
"data.confId"
);
Assert
.
assertEquals
(
confId
,
confId1
,
network
.
message
(
goodsFirstPar
,
BasicConfig
.
MOBILE_secondKill_goodsFirst
,
"当前秒杀商品配置ID错误"
,
goodsFirstRes
.
body
().
asString
()));
Assert
.
assertEquals
(
confId
,
ConfSecondKill
.
skIdFirst
,
network
.
message
(
goodsFirstPar
,
BasicConfig
.
MOBILE_secondKill_goodsFirst
,
"当前秒杀商品配置ID错误"
,
goodsFirstRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
goodsFirstPar
,
BasicConfig
.
MOBILE_secondKill_goodsFirst
,
"未获取到数据"
,
goodsFirstRes
.
body
().
asString
()));
Assert
.
fail
(
network
.
message
(
goodsFirstPar
,
BasicConfig
.
MOBILE_secondKill_goodsFirst
,
"未获取到数据"
,
goodsFirstRes
.
body
().
asString
()));
}
}
}
}
@Test
(
description
=
"当前秒杀商品降级接口"
,
priority
=
12
)
public
void
当前秒杀商品降级接口
()
{
Map
<
String
,
Object
>
downgradeGoodsPar
=
new
HashMap
<>();
downgradeGoodsPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
Response
downgradeGoodsRes
=
network
.
getResponse
(
downgradeGoodsPar
,
BasicConfig
.
MOBILE_secondKill_downgradeGoodsFirst
);
try
{
String
confId
=
downgradeGoodsRes
.
jsonPath
().
getString
(
"data.confId"
);
Assert
.
assertEquals
(
confId
,
ConfSecondKill
.
skIdFirst
,
network
.
message
(
downgradeGoodsPar
,
BasicConfig
.
MOBILE_secondKill_goodsFirst
,
"当前秒杀商品配置ID错误"
,
downgradeGoodsRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
downgradeGoodsPar
,
BasicConfig
.
MOBILE_secondKill_goodsFirst
,
"未获取到数据"
,
downgradeGoodsRes
.
body
().
asString
()));
}
}
/**
/**
* 下单失败
* 下单失败
*/
*/
// 秒杀配置代理人不可参与
// 秒杀配置代理人不可参与
@Test
(
description
=
"代理人下单"
,
priority
=
1
2
)
@Test
(
description
=
"代理人下单"
,
priority
=
1
3
)
public
void
代理人下单
()
{
public
void
代理人下单
()
{
agentAuth
();
agentAuth
();
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"confId"
,
confId1
);
orderPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
try
{
try
{
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
...
@@ -222,11 +235,11 @@ public class SecondKill implements Authorization {
...
@@ -222,11 +235,11 @@ public class SecondKill implements Authorization {
}
}
}
}
@Test
(
description
=
"代理人
获取下单结果"
,
priority
=
13
)
@Test
(
description
=
"代理人
下单失败"
,
priority
=
14
)
public
void
代理人
获取下单结果
()
{
public
void
代理人
下单失败
()
{
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"confId"
,
confId1
);
orderResultPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
orderResultRes
=
null
;
Response
orderResultRes
=
null
;
Object
data
=
null
;
Object
data
=
null
;
int
i
=
0
;
int
i
=
0
;
...
@@ -259,12 +272,12 @@ public class SecondKill implements Authorization {
...
@@ -259,12 +272,12 @@ public class SecondKill implements Authorization {
}
}
// 访客被黑名单限制
// 访客被黑名单限制
@Test
(
description
=
"黑名单客户下单"
,
priority
=
1
4
)
@Test
(
description
=
"黑名单客户下单"
,
priority
=
1
5
)
public
void
黑名单客户下单
()
{
public
void
黑名单客户下单
()
{
visitorAuth7
();
visitorAuth7
();
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"confId"
,
confId1
);
orderPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
try
{
try
{
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
...
@@ -275,11 +288,11 @@ public class SecondKill implements Authorization {
...
@@ -275,11 +288,11 @@ public class SecondKill implements Authorization {
}
}
}
}
@Test
(
description
=
"黑名单客户
获取下单结果"
,
priority
=
15
)
@Test
(
description
=
"黑名单客户
下单失败"
,
priority
=
16
)
public
void
黑名单客户
获取下单结果
()
{
public
void
黑名单客户
下单失败
()
{
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"confId"
,
confId1
);
orderResultPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
orderResultRes
=
null
;
Response
orderResultRes
=
null
;
Object
data
=
null
;
Object
data
=
null
;
int
i
=
0
;
int
i
=
0
;
...
@@ -314,12 +327,12 @@ public class SecondKill implements Authorization {
...
@@ -314,12 +327,12 @@ public class SecondKill implements Authorization {
/**
/**
* 下单
* 下单
*/
*/
@Test
(
description
=
"正常用户下单"
,
priority
=
1
6
)
@Test
(
description
=
"正常用户下单"
,
priority
=
1
9
)
public
void
正常用户下单
()
{
public
void
正常用户下单
()
{
visitorAuth
();
visitorAuth
();
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"confId"
,
confId1
);
orderPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
try
{
try
{
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
...
@@ -330,11 +343,11 @@ public class SecondKill implements Authorization {
...
@@ -330,11 +343,11 @@ public class SecondKill implements Authorization {
}
}
}
}
@Test
(
description
=
"正常用户获取下单结果"
,
priority
=
17
)
@Test
(
description
=
"正常用户获取下单结果"
,
priority
=
20
)
public
void
正常用户获取下单结果
()
{
public
void
正常用户获取下单结果
()
{
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"confId"
,
confId1
);
orderResultPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
orderResultRes
=
null
;
Response
orderResultRes
=
null
;
Object
data
=
null
;
Object
data
=
null
;
int
i
=
0
;
int
i
=
0
;
...
@@ -358,7 +371,7 @@ public class SecondKill implements Authorization {
...
@@ -358,7 +371,7 @@ public class SecondKill implements Authorization {
}
}
}
}
@Test
(
description
=
"查询待支付状态"
,
priority
=
18
)
@Test
(
description
=
"查询待支付状态"
,
priority
=
21
)
public
void
查询待支付状态
()
{
public
void
查询待支付状态
()
{
Map
<
String
,
Object
>
killGoodsPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
killGoodsPar
=
new
HashMap
<>();
killGoodsPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
killGoodsPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
...
@@ -367,7 +380,7 @@ public class SecondKill implements Authorization {
...
@@ -367,7 +380,7 @@ public class SecondKill implements Authorization {
List
<
KillGoods
>
killGoods
=
JsonUtil
.
parseResponseToListBean
(
killGoodsRes
,
KillGoods
.
class
);
List
<
KillGoods
>
killGoods
=
JsonUtil
.
parseResponseToListBean
(
killGoodsRes
,
KillGoods
.
class
);
boolean
hasTarget
=
false
;
boolean
hasTarget
=
false
;
for
(
KillGoods
killGood
:
killGoods
){
for
(
KillGoods
killGood
:
killGoods
){
if
(
killGood
.
getConfId
().
equals
(
confId1
)){
if
(
killGood
.
getConfId
().
equals
(
ConfSecondKill
.
skIdFirst
)){
hasTarget
=
true
;
hasTarget
=
true
;
Assert
.
assertEquals
(
killGood
.
getChargeStatus
(),
1
,
network
.
message
(
killGoodsPar
,
BasicConfig
.
MOBILE_secondKill_killGoods
,
"对应轮次支付状态不为待支付"
,
killGoodsRes
.
body
().
asString
()));
Assert
.
assertEquals
(
killGood
.
getChargeStatus
(),
1
,
network
.
message
(
killGoodsPar
,
BasicConfig
.
MOBILE_secondKill_killGoods
,
"对应轮次支付状态不为待支付"
,
killGoodsRes
.
body
().
asString
()));
}
}
...
@@ -381,7 +394,7 @@ public class SecondKill implements Authorization {
...
@@ -381,7 +394,7 @@ public class SecondKill implements Authorization {
}
}
}
}
@Test
(
description
=
"占用库存"
,
priority
=
19
)
@Test
(
description
=
"占用库存"
,
priority
=
22
)
public
void
占用库存
()
{
public
void
占用库存
()
{
// 切换助播端视角获取当前轮次剩余数量
// 切换助播端视角获取当前轮次剩余数量
adminAuth
();
adminAuth
();
...
@@ -392,7 +405,7 @@ public class SecondKill implements Authorization {
...
@@ -392,7 +405,7 @@ public class SecondKill implements Authorization {
List
<
AnchorGetSKList
>
secKillLists
=
JsonUtil
.
parseResponseToListBean
(
liveSecKillRes
,
AnchorGetSKList
.
class
);
List
<
AnchorGetSKList
>
secKillLists
=
JsonUtil
.
parseResponseToListBean
(
liveSecKillRes
,
AnchorGetSKList
.
class
);
boolean
hasTarget
=
false
;
boolean
hasTarget
=
false
;
for
(
AnchorGetSKList
secKillList
:
secKillLists
){
for
(
AnchorGetSKList
secKillList
:
secKillLists
){
if
(
secKillList
.
getId
().
equals
(
confId1
)){
if
(
secKillList
.
getId
().
equals
(
ConfSecondKill
.
skIdFirst
)){
hasTarget
=
true
;
hasTarget
=
true
;
int
surplusNum
=
secKillList
.
getSurplusNum
();
int
surplusNum
=
secKillList
.
getSurplusNum
();
Assert
.
assertEquals
(
surplusNum
,
3
,
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"对应轮次剩余数量有误"
,
liveSecKillRes
.
body
().
asString
()));
Assert
.
assertEquals
(
surplusNum
,
3
,
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"对应轮次剩余数量有误"
,
liveSecKillRes
.
body
().
asString
()));
...
@@ -407,55 +420,200 @@ public class SecondKill implements Authorization {
...
@@ -407,55 +420,200 @@ public class SecondKill implements Authorization {
}
}
}
}
@Test
(
description
=
"超时未支付"
,
priority
=
2
0
)
@Test
(
description
=
"超时未支付"
,
priority
=
2
3
)
public
void
超时未支付
()
{
public
void
超时未支付
()
{
ThreadSleepUtils
.
sleep
(
150000
);
// 两分钟无操作
// 助播端视角查看库存是否释放
// 助播端视角查看库存是否释放
Map
<
String
,
Object
>
liveSecKillPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
liveSecKillPar
=
new
HashMap
<>();
liveSecKillPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
liveSecKillPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
Response
liveSecKillRes
=
n
etwork
.
getResponse
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
)
;
Response
liveSecKillRes
=
n
ull
;
try
{
try
{
long
beginTime
=
new
Date
().
getTime
();
// 获取开始时间
long
endTime
=
new
Date
().
getTime
();
// 获取结束时间
System
.
out
.
println
(
"开始时间:"
+
beginTime
);
boolean
hasRelease
=
false
;
while
(!
hasRelease
){
if
(
endTime
-
beginTime
<
180000
){
liveSecKillRes
=
network
.
getResponse
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
);
List
<
AnchorGetSKList
>
secKillLists
=
JsonUtil
.
parseResponseToListBean
(
liveSecKillRes
,
AnchorGetSKList
.
class
);
List
<
AnchorGetSKList
>
secKillLists
=
JsonUtil
.
parseResponseToListBean
(
liveSecKillRes
,
AnchorGetSKList
.
class
);
boolean
hasTarget
=
false
;
boolean
hasTarget
=
false
;
for
(
AnchorGetSKList
secKillList
:
secKillLists
){
for
(
AnchorGetSKList
secKillList
:
secKillLists
){
if
(
secKillList
.
getId
().
equals
(
confId1
)){
if
(
secKillList
.
getId
().
equals
(
ConfSecondKill
.
skIdFirst
)){
hasTarget
=
true
;
hasTarget
=
true
;
int
surplusNum
=
secKillList
.
getSurplusNum
();
int
surplusNum
=
secKillList
.
getSurplusNum
();
Assert
.
assertEquals
(
surplusNum
,
4
,
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"对应轮次剩余数量有误"
,
liveSecKillRes
.
body
().
asString
()));
if
(
surplusNum
==
4
){
hasRelease
=
true
;
// 置释放标记为true
break
;
// 若查到对应轮次释放,跳出for循环
}
else
{
endTime
=
new
Date
().
getTime
();
// 若剩余库存还未释放,刷新结束时间,重新获取
System
.
out
.
println
(
"当前时间:"
+
endTime
);
}
}
}
}
}
if
(!
hasTarget
){
if
(!
hasTarget
){
Assert
.
fail
(
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"未获取到对应轮次信息"
,
liveSecKillRes
.
body
().
asString
()));
Assert
.
fail
(
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"未查询到对应轮次信息"
,
liveSecKillRes
.
body
().
asString
()));
}
}
else
{
Assert
.
fail
(
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"订单超时取消3分钟后库存仍未释放出来"
,
liveSecKillRes
.
body
().
asString
()));
}
}
}
}
catch
(
Exception
e
){
}
catch
(
Exception
e
){
e
.
printStackTrace
();
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"获取数据失败"
,
liveSecKillRes
.
body
().
asString
()));
Assert
.
fail
(
network
.
message
(
liveSecKillPar
,
BasicConfig
.
ANCHOR_secondKillLists
,
"获取数据失败"
,
liveSecKillRes
.
body
().
asString
()));
}
}
}
/**
* 放开代理人秒杀限制
* 助播端需先下架秒杀才能进行编辑
*/
@Test
(
description
=
"助播端下架秒杀"
,
priority
=
24
)
public
void
助播端下架秒杀
()
{
adminAuth
();
Map
<
String
,
Object
>
skOffPar
=
new
HashMap
<>();
skOffPar
.
put
(
"id"
,
ConfSecondKill
.
skIdFirst
);
Response
skOffRes
=
network
.
postResponse
(
skOffPar
,
BasicConfig
.
ANCHOR_secondKillOff
);
try
{
boolean
data
=
skOffRes
.
jsonPath
().
getBoolean
(
"data"
);
Assert
.
assertTrue
(
data
,
network
.
message
(
skOffPar
,
BasicConfig
.
ANCHOR_secondKillOff
,
"下架秒杀失败"
,
skOffRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
skOffPar
,
BasicConfig
.
ANCHOR_secondKillOff
,
"获取数据失败"
,
skOffRes
.
body
().
asString
()));
}
}
@Test
(
description
=
"上架第二轮秒杀,代理人可参与"
,
priority
=
25
)
public
void
上架第二轮秒杀
()
{
Map
<
String
,
Object
>
skOnPar
=
new
HashMap
<>();
skOnPar
.
put
(
"id"
,
ConfSecondKill
.
skIdSecond
);
Response
goodsOnRes
=
network
.
postResponse
(
skOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
);
try
{
boolean
data
=
goodsOnRes
.
jsonPath
().
getBoolean
(
"data"
);
Assert
.
assertTrue
(
data
,
network
.
message
(
skOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
,
"上架秒杀失败"
,
goodsOnRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
skOnPar
,
BasicConfig
.
ANCHOR_secondKillOn
,
"未获取到数据"
,
goodsOnRes
.
body
().
asString
()));
}
}
@Test
(
description
=
"代理人成功下单-占用库存"
,
priority
=
26
)
public
void
代理人成功下单
()
{
agentAuth
();
// 下单
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdSecond
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
try
{
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
Assert
.
assertTrue
(
data
,
network
.
message
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
,
"下单失败"
,
orderRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
,
"未获取到数据"
,
orderRes
.
body
().
asString
()));
}
// 获取下单结果
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdSecond
);
Response
orderResultRes
=
null
;
Object
data
=
null
;
int
i
=
0
;
try
{
// 轮训下单接口
while
(
data
==
null
){
ThreadSleepUtils
.
sleep
(
2000
);
orderResultRes
=
network
.
getResponse
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
);
data
=
orderResultRes
.
jsonPath
().
getJsonObject
(
"data"
);
i
++;
if
(
i
==
10
){
Assert
.
fail
(
network
.
message
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
,
"轮训下单结果超过10次"
,
orderResultRes
.
body
().
asString
()));
}
}
int
state
=
orderResultRes
.
jsonPath
().
getInt
(
"data.state"
);
Assert
.
assertEquals
(
state
,
3
,
network
.
message
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
,
"下单未成功"
,
orderResultRes
.
body
().
asString
()));
System
.
out
.
println
(
data
);
}
catch
(
Exception
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
,
"获取数据失败"
,
orderResultRes
.
body
().
asString
()));
}
}
// 访客视角查看轮次状态
@Test
(
description
=
"用户下单无库存秒杀失败"
,
priority
=
27
)
public
void
用户下单无库存秒杀
()
{
visitorAuth
();
visitorAuth
();
Map
<
String
,
Object
>
goodsDetail
Par
=
new
HashMap
<>();
Map
<
String
,
Object
>
order
Par
=
new
HashMap
<>();
goodsDetail
Par
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
order
Par
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
goodsDetailPar
.
put
(
"confId"
,
confId1
);
orderPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdSecond
);
Response
goodsDetailRes
=
network
.
getResponse
(
goodsDetailPar
,
BasicConfig
.
MOBILE_secondKill_getGoodsDetail
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
try
{
try
{
int
chargeStatus
=
goodsDetailRes
.
jsonPath
().
getInt
(
"data.chargeStatus"
);
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
int
interactStatus
=
goodsDetailRes
.
jsonPath
().
getInt
(
"data.interactStatus"
);
Assert
.
assertTrue
(
data
,
network
.
message
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
,
"下单失败"
,
orderRes
.
body
().
asString
()));
Assert
.
assertEquals
(
interactStatus
,
2
,
network
.
message
(
goodsDetailPar
,
BasicConfig
.
MOBILE_secondKill_getGoodsDetail
,
"轮次商品状态错误"
,
goodsDetailRes
.
body
().
asString
()));
Assert
.
assertEquals
(
chargeStatus
,
5
,
network
.
message
(
goodsDetailPar
,
BasicConfig
.
MOBILE_secondKill_getGoodsDetail
,
"轮次支付状态错误"
,
goodsDetailRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
goodsDetailPar
,
BasicConfig
.
MOBILE_secondKill_getGoodsDetail
,
"获取数据失败"
,
goodsDetailRes
.
body
().
asString
()));
Assert
.
fail
(
network
.
message
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
,
"未获取到数据"
,
orderRes
.
body
().
asString
()));
}
// 获取下单结果
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdSecond
);
Response
orderResultRes
=
null
;
Object
data
=
null
;
int
i
=
0
;
try
{
// 轮训下单接口
while
(
data
==
null
){
ThreadSleepUtils
.
sleep
(
2000
);
orderResultRes
=
network
.
getResponse
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
);
data
=
orderResultRes
.
jsonPath
().
getJsonObject
(
"data"
);
i
++;
if
(
i
==
10
){
Assert
.
fail
(
network
.
message
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
,
"轮训下单结果超过10次"
,
orderResultRes
.
body
().
asString
()));
}
}
int
state
=
orderResultRes
.
jsonPath
().
getInt
(
"data.state"
);
if
(
state
==
2
){
int
code
=
orderResultRes
.
jsonPath
().
getInt
(
"data.code"
);
if
(
code
==
4
){
System
.
out
.
println
(
"失败原因code="
+
code
);
}
else
{
Assert
.
assertEquals
(
code
,
2
,
network
.
message
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
,
"失败原因不是库存不足"
,
orderResultRes
.
body
().
asString
()));
}
}
else
{
Assert
.
fail
(
network
.
message
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
,
"库存不足时用户下单成功了"
,
orderResultRes
.
body
().
asString
()));
}
}
catch
(
Exception
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
orderResultPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrderResult
,
"获取数据失败"
,
orderResultRes
.
body
().
asString
()));
}
}
}
}
@Test
(
description
=
"用户成功支付"
,
priority
=
21
)
@Test
(
description
=
"删除已上架过的轮次"
,
priority
=
28
)
public
void
已上架过的轮次无法删除
()
{
long
id
=
IdMakeUtil
.
managerDecodeingId
(
ConfSecondKill
.
skIdFirst
);
Map
<
String
,
Object
>
delSkPar
=
new
HashMap
<>();
delSkPar
.
put
(
"id"
,
id
);
Response
delSkRes
=
network
.
postResponse
(
delSkPar
,
BasicConfig
.
MANAGER_secondKillDel
);
try
{
boolean
success
=
delSkRes
.
jsonPath
().
getBoolean
(
"success"
);
if
(
success
){
Assert
.
fail
(
network
.
message
(
delSkPar
,
BasicConfig
.
MANAGER_secondKillDel
,
"已上架轮次删除成功"
,
delSkRes
.
body
().
asString
()));
}
String
code
=
delSkRes
.
jsonPath
().
getString
(
"code"
);
Assert
.
assertEquals
(
code
,
"95003"
,
network
.
message
(
delSkPar
,
BasicConfig
.
MANAGER_secondKillDel
,
"删除失败原因错误"
,
delSkRes
.
body
().
asString
()));
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
Assert
.
fail
(
network
.
message
(
delSkPar
,
BasicConfig
.
MANAGER_secondKillDel
,
"获取数据失败"
,
delSkRes
.
body
().
asString
()));
}
}
@Test
(
description
=
"用户成功支付"
,
priority
=
29
)
public
void
用户成功支付
()
{
public
void
用户成功支付
()
{
visitorAuth
();
// 新建订单
// 新建订单
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
orderPar
=
new
HashMap
<>();
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderPar
.
put
(
"confId"
,
confId1
);
orderPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
Response
orderRes
=
network
.
postResponse
(
orderPar
,
BasicConfig
.
MOBILE_secondKill_goodsOrder
);
try
{
try
{
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
boolean
data
=
orderRes
.
jsonPath
().
getBoolean
(
"data"
);
...
@@ -467,7 +625,7 @@ public class SecondKill implements Authorization {
...
@@ -467,7 +625,7 @@ public class SecondKill implements Authorization {
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
Map
<
String
,
Object
>
orderResultPar
=
new
HashMap
<>();
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
orderResultPar
.
put
(
"confId"
,
confId1
);
orderResultPar
.
put
(
"confId"
,
ConfSecondKill
.
skIdFirst
);
Response
orderResultRes
=
null
;
Response
orderResultRes
=
null
;
Object
data
=
null
;
Object
data
=
null
;
int
i
=
0
;
int
i
=
0
;
...
...
src/test/java/com/kjj/cases/live/treasure/Treasure.java
View file @
6c519b7b
...
@@ -1055,6 +1055,19 @@ public class Treasure implements Authorization {
...
@@ -1055,6 +1055,19 @@ public class Treasure implements Authorization {
}
}
/**
* 添加代理人绑定关系
*/
@Test
(
description
=
"代理人绑定"
,
priority
=
70
)
public
void
代理人绑定
()
{
agentAuth
();
Map
<
String
,
Object
>
bindingParam
=
new
HashMap
<>();
bindingParam
.
put
(
"liveId"
,
LiveConstants
.
getValue
(
LiveConstants
.
StringKeyEnum
.
ENCODE_LIVE_ID
.
getKey
()));
Response
bindingRes
=
network
.
postResponse
(
bindingParam
,
BasicConfig
.
MOBILE_binding
);
boolean
success
=
bindingRes
.
jsonPath
().
getJsonObject
(
"success"
);
System
.
out
.
println
(
success
);
Assert
.
assertTrue
(
success
,
network
.
message
(
bindingParam
,
BasicConfig
.
MOBILE_binding
,
"绑定失败"
,
bindingRes
.
body
().
asString
()));
}
...
...
src/test/java/com/kjj/config/BasicConfig.java
View file @
6c519b7b
...
@@ -146,7 +146,9 @@ public class BasicConfig {
...
@@ -146,7 +146,9 @@ public class BasicConfig {
public
static
final
String
MOBILE_secondKill_getGoodsList
=
MOBILE_HOST
+
"/clue/goods/list"
;
public
static
final
String
MOBILE_secondKill_getGoodsList
=
MOBILE_HOST
+
"/clue/goods/list"
;
public
static
final
String
MOBILE_secondKill_getGoodsDetail
=
MOBILE_HOST
+
"/clue/goods/detail"
;
public
static
final
String
MOBILE_secondKill_getGoodsDetail
=
MOBILE_HOST
+
"/clue/goods/detail"
;
public
static
final
String
ANCHOR_secondKillOn
=
MOBILE_HOST
+
"/conf/live/second/kill/goods/on"
;
public
static
final
String
ANCHOR_secondKillOn
=
MOBILE_HOST
+
"/conf/live/second/kill/goods/on"
;
public
static
final
String
ANCHOR_secondKillOff
=
MOBILE_HOST
+
"/conf/live/second/kill/goods/off"
;
public
static
final
String
MOBILE_secondKill_goodsFirst
=
MOBILE_HOST
+
"/clue/goods/first"
;
public
static
final
String
MOBILE_secondKill_goodsFirst
=
MOBILE_HOST
+
"/clue/goods/first"
;
public
static
final
String
MOBILE_secondKill_downgradeGoodsFirst
=
MOBILE_HOST
+
"/clue/downgrade/goods"
;
public
static
final
String
MOBILE_secondKill_goodsOrder
=
MOBILE_HOST
+
"/clue/goods/order"
;
public
static
final
String
MOBILE_secondKill_goodsOrder
=
MOBILE_HOST
+
"/clue/goods/order"
;
public
static
final
String
MOBILE_secondKill_goodsOrderResult
=
MOBILE_HOST
+
"/clue/goods/order/result"
;
public
static
final
String
MOBILE_secondKill_goodsOrderResult
=
MOBILE_HOST
+
"/clue/goods/order/result"
;
public
static
final
String
MOBILE_secondKill_killGoods
=
MOBILE_HOST
+
"/clue/goods/killGoods"
;
public
static
final
String
MOBILE_secondKill_killGoods
=
MOBILE_HOST
+
"/clue/goods/killGoods"
;
...
...
src/test/java/com/kjj/utils/IdMakeUtil.java
View file @
6c519b7b
...
@@ -62,5 +62,19 @@ public class IdMakeUtil implements Authorization {
...
@@ -62,5 +62,19 @@ public class IdMakeUtil implements Authorization {
return
encodeId
;
return
encodeId
;
}
}
public
static
long
managerDecodeingId
(
String
code
)
{
BaseUtils
.
ssoLogin
();
Map
<
String
,
Object
>
decodePar
=
new
HashMap
<>();
decodePar
.
put
(
"code"
,
code
);
Response
decodeRes
=
network
.
getResponse
(
decodePar
,
BasicConfig
.
MANAGER_ID_DECODE
);
long
decodeId
=
0
;
try
{
decodeId
=
decodeRes
.
jsonPath
().
getLong
(
"data"
);
}
catch
(
NullPointerException
e
){
e
.
printStackTrace
();
}
return
decodeId
;
}
}
}
src/test/liveTestNG.xml
View file @
6c519b7b
...
@@ -77,173 +77,173 @@
...
@@ -77,173 +77,173 @@
<class
name=
"com.kjj.cases.live.lottery.RelativeLottery"
/>
<class
name=
"com.kjj.cases.live.lottery.RelativeLottery"
/>
</classes>
</classes>
</test>
</test>
<test
preserve-order=
"false"
name=
"翻牌集字红包"
>
<!-- <test preserve-order="false" name="翻牌集字红包">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.flipCard.FlipCard"
/
>
<!-- <class name="com.kjj.cases.live.flipCard.FlipCard"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"中奖规则配置"
>
<!-- <test preserve-order="true" name="中奖规则配置">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.liveConfig.WinningRules"
/
>
<!-- <class name="com.kjj.cases.live.liveConfig.WinningRules"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"指定中奖"
>
<!-- <test preserve-order="true" name="指定中奖">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.lottery.DesignatedWinner"
/
>
<!-- <class name="com.kjj.cases.live.lottery.DesignatedWinner"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"直播前-我的客户页"
>
<!-- <test preserve-order="true" name="直播前-我的客户页">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.agent.LiveBefore"
/
>
<!-- <class name="com.kjj.cases.live.agent.LiveBefore"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"助播-开启直播"
>
<!-- <test preserve-order="true" name="助播-开启直播">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.anchor.OpenLive"
/
>
<!-- <class name="com.kjj.cases.live.anchor.OpenLive"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"访客签到"
>
<!-- <test preserve-order="true" name="访客签到">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.lotteryCode.SignIn"
/
>
<!-- <class name="com.kjj.cases.live.lotteryCode.SignIn"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"宝箱裂变"
>
<!-- <test preserve-order="true" name="宝箱裂变">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.treasure.Treasure"
/
>
<!-- <class name="com.kjj.cases.live.treasure.Treasure"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"直播中抽奖"
>
<!-- <test preserve-order="true" name="直播中抽奖">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.lottery.Lottery"
/
>
<!-- <class name="com.kjj.cases.live.lottery.Lottery"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"秒杀互动"
>
<!-- <test preserve-order="true" name="秒杀互动">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.secondKill.SecondKill"
/
>
<!-- <class name="com.kjj.cases.live.secondKill.SecondKill"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"猜数字红包"
>
<!-- <test preserve-order="true" name="猜数字红包">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.guess.LiveGuess"
/
>
<!-- <class name="com.kjj.cases.live.guess.LiveGuess"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"看直播攒现金"
>
<!-- <test preserve-order="true" name="看直播攒现金">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.treasure.TimeRed"
/
>
<!-- <class name="com.kjj.cases.live.treasure.TimeRed"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"免费领福利"
>
<!-- <test preserve-order="true" name="免费领福利">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.FreeReward.FreeReward"
/
>
<!-- <class name="com.kjj.cases.live.FreeReward.FreeReward"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"我要咨询"
>
<!-- <test preserve-order="true" name="我要咨询">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.agent.Potential"
/
>
<!-- <class name="com.kjj.cases.live.agent.Potential"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"访客领取资料"
>
<!-- <test preserve-order="true" name="访客领取资料">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.anchor.LiveVisitors"
/
>
<!-- <class name="com.kjj.cases.live.anchor.LiveVisitors"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"红包领取"
>
<!-- <test preserve-order="true" name="红包领取">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.red.LiveVistorRed"
/
>
<!-- <class name="com.kjj.cases.live.red.LiveVistorRed"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"有奖答题"
>
<!-- <test preserve-order="true" name="有奖答题">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.answer.Answer"
/
>
<!-- <class name="com.kjj.cases.live.answer.Answer"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"投票"
>
<!-- <test preserve-order="true" name="投票">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.choice.Choice"
/
>
<!-- <class name="com.kjj.cases.live.choice.Choice"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"问题"
>
<!-- <test preserve-order="true" name="问题">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.question.Question"
/
>
<!-- <class name="com.kjj.cases.live.question.Question"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"直播中时长宝箱"
>
<!-- <test preserve-order="true" name="直播中时长宝箱">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.treasure.TreasureTime"
/
>
<!-- <class name="com.kjj.cases.live.treasure.TreasureTime"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"闯关答题"
>
<!-- <test preserve-order="true" name="闯关答题">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.answer.passQues"
/
>
<!-- <class name="com.kjj.cases.live.answer.passQues"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"直播中获取线索统计"
>
<!-- <test preserve-order="true" name="直播中获取线索统计">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.agent.LiveAgent"
/
>
<!-- <class name="com.kjj.cases.live.agent.LiveAgent"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"助播-结束直播"
>
<!-- <test preserve-order="true" name="助播-结束直播">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.anchor.CloseLive"
/
>
<!-- <class name="com.kjj.cases.live.anchor.CloseLive"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"直播结束-我的客户页"
>
<!-- <test preserve-order="true" name="直播结束-我的客户页">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.agent.LiveLater"
/
>
<!-- <class name="com.kjj.cases.live.agent.LiveLater"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"奖品发放配置"
>
<!-- <test preserve-order="true" name="奖品发放配置">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.agent.Reward"
/
>
<!-- <class name="com.kjj.cases.live.agent.Reward"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"指定中奖付款码"
>
<!-- <test preserve-order="true" name="指定中奖付款码">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.liveConfig.spec"
/
>
<!-- <class name="com.kjj.cases.live.liveConfig.spec"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"客户管理"
>
<!-- <test preserve-order="true" name="客户管理">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.agent.Customer"
/
>
<!-- <class name="com.kjj.cases.live.agent.Customer"/>--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"访客端直播结束页"
>
<!-- <test preserve-order="true" name="访客端直播结束页">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.customer.AfterLive"
/
>
<!-- <class name="com.kjj.cases.live.customer.AfterLive" />--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
<test
preserve-order=
"true"
name=
"访客端个人主页"
>
<!-- <test preserve-order="true" name="访客端个人主页">--
>
<classes
>
<!-- <classes>--
>
<class
name=
"com.kjj.cases.live.customer.PersonalPage"
/
>
<!-- <class name="com.kjj.cases.live.customer.PersonalPage" />--
>
</classes
>
<!-- </classes>--
>
</test
>
<!-- </test>--
>
</suite>
</suite>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a 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