Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Apache RocketMQ
Rocketmq
提交
02e2abb5
R
Rocketmq
项目概览
Apache RocketMQ
/
Rocketmq
上一次同步 大约 3 年
通知
270
Star
16139
Fork
68
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rocketmq
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
02e2abb5
编写于
3月 08, 2019
作者:
Z
zhangjidi2016
提交者:
Hu Zongtang
3月 08, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[RIP-10] Add test cases for ConsumerRunningInfo (#923)
上级
de34ce7e
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
108 addition
and
0 deletion
+108
-0
common/src/test/java/org/apache/rocketmq/common/protocol/body/ConsumerRunningInfoTest.java
...ocketmq/common/protocol/body/ConsumerRunningInfoTest.java
+108
-0
未找到文件。
common/src/test/java/org/apache/rocketmq/common/protocol/body/ConsumerRunningInfoTest.java
0 → 100644
浏览文件 @
02e2abb5
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package
org.apache.rocketmq.common.protocol.body
;
import
org.apache.rocketmq.common.message.MessageQueue
;
import
org.apache.rocketmq.common.protocol.heartbeat.ConsumeType
;
import
org.apache.rocketmq.common.protocol.heartbeat.SubscriptionData
;
import
org.apache.rocketmq.remoting.protocol.RemotingSerializable
;
import
org.junit.Before
;
import
org.junit.Test
;
import
java.util.Properties
;
import
java.util.TreeMap
;
import
java.util.TreeSet
;
import
static
org
.
apache
.
rocketmq
.
common
.
protocol
.
heartbeat
.
ConsumeType
.
CONSUME_ACTIVELY
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
public
class
ConsumerRunningInfoTest
{
private
ConsumerRunningInfo
consumerRunningInfo
;
private
TreeMap
<
String
,
ConsumerRunningInfo
>
criTable
;
private
MessageQueue
messageQueue
;
@Before
public
void
init
()
{
consumerRunningInfo
=
new
ConsumerRunningInfo
();
consumerRunningInfo
.
setJstack
(
"test"
);
TreeMap
<
MessageQueue
,
ProcessQueueInfo
>
mqTable
=
new
TreeMap
<
MessageQueue
,
ProcessQueueInfo
>();
messageQueue
=
new
MessageQueue
(
"topicA"
,
"broker"
,
1
);
mqTable
.
put
(
messageQueue
,
new
ProcessQueueInfo
());
consumerRunningInfo
.
setMqTable
(
mqTable
);
TreeMap
<
String
,
ConsumeStatus
>
statusTable
=
new
TreeMap
<
String
,
ConsumeStatus
>();
statusTable
.
put
(
"topicA"
,
new
ConsumeStatus
());
consumerRunningInfo
.
setStatusTable
(
statusTable
);
TreeSet
<
SubscriptionData
>
subscriptionSet
=
new
TreeSet
<
SubscriptionData
>();
subscriptionSet
.
add
(
new
SubscriptionData
());
consumerRunningInfo
.
setSubscriptionSet
(
subscriptionSet
);
Properties
properties
=
new
Properties
();
properties
.
put
(
ConsumerRunningInfo
.
PROP_CONSUME_TYPE
,
CONSUME_ACTIVELY
);
properties
.
put
(
ConsumerRunningInfo
.
PROP_CONSUMER_START_TIMESTAMP
,
System
.
currentTimeMillis
());
consumerRunningInfo
.
setProperties
(
properties
);
criTable
=
new
TreeMap
<
String
,
ConsumerRunningInfo
>();
criTable
.
put
(
"client_id"
,
consumerRunningInfo
);
}
@Test
public
void
testFromJson
()
{
String
toJson
=
RemotingSerializable
.
toJson
(
consumerRunningInfo
,
true
);
ConsumerRunningInfo
fromJson
=
RemotingSerializable
.
fromJson
(
toJson
,
ConsumerRunningInfo
.
class
);
assertThat
(
fromJson
.
getJstack
()).
isEqualTo
(
"test"
);
assertThat
(
fromJson
.
getProperties
().
get
(
ConsumerRunningInfo
.
PROP_CONSUME_TYPE
)).
isEqualTo
(
ConsumeType
.
CONSUME_ACTIVELY
.
name
());
ConsumeStatus
consumeStatus
=
fromJson
.
getStatusTable
().
get
(
"topicA"
);
assertThat
(
consumeStatus
).
isExactlyInstanceOf
(
ConsumeStatus
.
class
);
SubscriptionData
subscription
=
fromJson
.
getSubscriptionSet
().
first
();
assertThat
(
subscription
).
isExactlyInstanceOf
(
SubscriptionData
.
class
);
ProcessQueueInfo
processQueueInfo
=
fromJson
.
getMqTable
().
get
(
messageQueue
);
assertThat
(
processQueueInfo
).
isExactlyInstanceOf
(
ProcessQueueInfo
.
class
);
}
@Test
public
void
testAnalyzeRebalance
(){
boolean
result
=
ConsumerRunningInfo
.
analyzeRebalance
(
criTable
);
assertThat
(
result
).
isTrue
();
}
@Test
public
void
testAnalyzeProcessQueue
(){
String
result
=
ConsumerRunningInfo
.
analyzeProcessQueue
(
"client_id"
,
consumerRunningInfo
);
assertThat
(
result
).
isEmpty
();
}
@Test
public
void
testAnalyzeSubscription
(){
boolean
result
=
ConsumerRunningInfo
.
analyzeSubscription
(
criTable
);
assertThat
(
result
).
isTrue
();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录