Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
s920243400
Rocketmq
提交
a4270cff
R
Rocketmq
项目概览
s920243400
/
Rocketmq
与 Fork 源项目一致
Fork自
Apache RocketMQ / Rocketmq
通知
1
Star
1
Fork
0
代码
文件
提交
分支
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看板
提交
a4270cff
编写于
8月 13, 2019
作者:
X
xhpscdx
提交者:
Heng Du
8月 13, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add mqttProcessor unit test (#1374)
上级
5813a8ba
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
186 addition
and
0 deletion
+186
-0
broker/src/test/java/org/apache/rocketmq/broker/processor/MQTTProcessorTest.java
...g/apache/rocketmq/broker/processor/MQTTProcessorTest.java
+186
-0
未找到文件。
broker/src/test/java/org/apache/rocketmq/broker/processor/MQTTProcessorTest.java
0 → 100644
浏览文件 @
a4270cff
package
org.apache.rocketmq.broker.processor
;
import
com.google.gson.Gson
;
import
com.google.gson.reflect.TypeToken
;
import
org.apache.rocketmq.broker.BrokerController
;
import
org.apache.rocketmq.common.BrokerConfig
;
import
org.apache.rocketmq.common.client.ClientRole
;
import
org.apache.rocketmq.common.client.Subscription
;
import
org.apache.rocketmq.common.protocol.RequestCode
;
import
org.apache.rocketmq.common.protocol.header.mqtt.*
;
import
org.apache.rocketmq.common.protocol.heartbeat.MqttSubscriptionData
;
import
org.apache.rocketmq.mqtt.client.MQTTSession
;
import
org.apache.rocketmq.mqtt.constant.MqttConstant
;
import
org.apache.rocketmq.remoting.ClientConfig
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.ServerConfig
;
import
org.apache.rocketmq.remoting.exception.RemotingCommandException
;
import
org.apache.rocketmq.remoting.netty.CodecHelper
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.store.DefaultMQTTInfoStore
;
import
org.apache.rocketmq.store.MQTTInfoStore
;
import
org.apache.rocketmq.store.config.MessageStoreConfig
;
import
org.junit.Before
;
import
org.junit.Test
;
import
org.junit.runner.RunWith
;
import
org.mockito.Mock
;
import
org.mockito.Spy
;
import
org.mockito.junit.MockitoJUnitRunner
;
import
java.net.InetSocketAddress
;
import
java.util.HashSet
;
import
java.util.Set
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
import
static
org
.
mockito
.
Mockito
.
when
;
@RunWith
(
MockitoJUnitRunner
.
class
)
public
class
MQTTProcessorTest
{
private
MQTTProcessor
requestProcessor
;
@Spy
private
BrokerController
brokerController
=
new
BrokerController
(
new
BrokerConfig
(),
new
ServerConfig
(),
new
ClientConfig
(),
new
MessageStoreConfig
());
private
static
MQTTInfoStore
mqttInfoStore
;
@Mock
private
RemotingChannel
remotingChannel
;
private
MQTTSession
mqttSession
;
private
static
final
Gson
GSON
=
new
Gson
();
private
static
final
String
CLIENT_ID
=
"testClient"
;
private
static
final
String
ROOT_TOPIC
=
"rootTopic"
;
private
Subscription
subscription
;
static
{
try
{
mqttInfoStore
=
new
DefaultMQTTInfoStore
();
mqttInfoStore
.
load
();
mqttInfoStore
.
start
();
}
catch
(
Exception
e
)
{
e
.
printStackTrace
();
}
}
@Before
public
void
init
()
throws
Exception
{
when
(
brokerController
.
getMqttInfoStore
()).
thenReturn
(
mqttInfoStore
);
when
(
remotingChannel
.
remoteAddress
()).
thenReturn
(
new
InetSocketAddress
(
1024
));
requestProcessor
=
new
MQTTProcessor
(
brokerController
);
this
.
mqttSession
=
new
MQTTSession
(
CLIENT_ID
,
ClientRole
.
IOTCLIENT
,
new
HashSet
<
String
>()
{
{
add
(
"IOT_GROUP"
);
}
},
true
,
true
,
null
,
System
.
currentTimeMillis
(),
null
);
subscription
=
new
Subscription
();
subscription
.
setCleanSession
(
true
);
subscription
.
getSubscriptionTable
().
put
(
"topic/a"
,
new
MqttSubscriptionData
(
1
,
"client1"
,
"topic/a"
));
subscription
.
getSubscriptionTable
().
put
(
"topic/+"
,
new
MqttSubscriptionData
(
1
,
"client1"
,
"topic/+"
));
subscription
.
setLastUpdateTimestamp
(
System
.
currentTimeMillis
());
}
@Test
public
void
testReqProc_IsClient2SubscriptionPersisted
()
throws
RemotingCommandException
{
mqttInfoStore
.
putData
(
CLIENT_ID
+
MqttConstant
.
PERSIST_CLIENT_SUFFIX
,
GSON
.
toJson
(
mqttSession
));
final
RemotingCommand
request
=
createIsClient2SubscriptionPersistedRequestHeader
(
RequestCode
.
MQTT_IS_CLIENT2SUBSCRIPTION_PERSISTED
);
RemotingCommand
responseToReturn
=
requestProcessor
.
processRequest
(
remotingChannel
,
request
);
if
(
responseToReturn
!=
null
)
{
IsClient2SubscriptionPersistedResponseHeader
mqttHeader
=
(
IsClient2SubscriptionPersistedResponseHeader
)
responseToReturn
.
readCustomHeader
();
assertThat
(
mqttHeader
).
isNotNull
();
assertThat
(
mqttHeader
.
isPersisted
()).
isEqualTo
(
true
);
}
}
private
RemotingCommand
createIsClient2SubscriptionPersistedRequestHeader
(
int
requestCode
)
{
IsClient2SubscriptionPersistedRequestHeader
requestHeader
=
new
IsClient2SubscriptionPersistedRequestHeader
();
requestHeader
.
setClientId
(
CLIENT_ID
);
requestHeader
.
setCleanSession
(
false
);
RemotingCommand
request
=
RemotingCommand
.
createRequestCommand
(
requestCode
,
requestHeader
);
request
.
setBody
(
new
byte
[]{
'a'
});
CodecHelper
.
makeCustomHeaderToNet
(
request
);
return
request
;
}
@Test
public
void
testReqProc_AddorUpdateRootTopic2Clients
()
throws
RemotingCommandException
{
final
RemotingCommand
request
=
createAddorUpdateRootTopic2Clients
(
RequestCode
.
MQTT_ADD_OR_UPDATE_ROOTTOPIC2CLIENTS
);
RemotingCommand
responseToReturn
=
requestProcessor
.
processRequest
(
remotingChannel
,
request
);
if
(
responseToReturn
!=
null
)
{
AddOrUpdateRootTopic2ClientsResponseHeader
mqttHeader
=
(
AddOrUpdateRootTopic2ClientsResponseHeader
)
responseToReturn
.
readCustomHeader
();
assertThat
(
mqttHeader
).
isNotNull
();
assertThat
(
mqttHeader
.
isOperationSuccess
()).
isEqualTo
(
true
);
}
String
value
=
mqttInfoStore
.
getValue
(
ROOT_TOPIC
);
Set
<
String
>
clientsId
;
if
(
value
!=
null
)
{
clientsId
=
GSON
.
fromJson
(
value
,
new
TypeToken
<
Set
<
String
>>()
{
}.
getType
());
}
else
{
clientsId
=
new
HashSet
<>();
}
assertThat
(
clientsId
).
contains
(
CLIENT_ID
);
}
private
RemotingCommand
createAddorUpdateRootTopic2Clients
(
int
requestCode
)
{
AddOrUpdateRootTopic2ClientsRequestHeader
requestHeader
=
new
AddOrUpdateRootTopic2ClientsRequestHeader
();
requestHeader
.
setRootTopic
(
ROOT_TOPIC
);
requestHeader
.
setClientId
(
CLIENT_ID
);
RemotingCommand
request
=
RemotingCommand
.
createRequestCommand
(
requestCode
,
requestHeader
);
request
.
setBody
(
new
byte
[]
{
'a'
});
CodecHelper
.
makeCustomHeaderToNet
(
request
);
return
request
;
}
@Test
public
void
testReqProc_GetSubscriptionByClientId
()
throws
RemotingCommandException
{
String
subscriptionStr
=
GSON
.
toJson
(
subscription
);
this
.
mqttInfoStore
.
putData
(
CLIENT_ID
+
MqttConstant
.
PERSIST_SUBSCRIPTION_SUFFIX
,
subscriptionStr
);
final
RemotingCommand
request
=
createGetSubscriptionByClientId
(
RequestCode
.
MQTT_GET_SUBSCRIPTION_BY_CLIENT_ID
);
RemotingCommand
responseToReturn
=
requestProcessor
.
processRequest
(
remotingChannel
,
request
);
if
(
responseToReturn
!=
null
)
{
GetSubscriptionByClientIdResponseHeader
mqttHeader
=
(
GetSubscriptionByClientIdResponseHeader
)
responseToReturn
.
readCustomHeader
();
assertThat
(
mqttHeader
).
isNotNull
();
assertThat
(
mqttHeader
.
getSubscription
()).
isNotNull
();
assertThat
(
subscription
.
getLastUpdateTimestamp
()).
isEqualTo
(
mqttHeader
.
getSubscription
().
getLastUpdateTimestamp
());
}
}
private
RemotingCommand
createGetSubscriptionByClientId
(
int
requestCode
)
{
GetSubscriptionByClientIdRequestHeader
requestHeader
=
new
GetSubscriptionByClientIdRequestHeader
();
requestHeader
.
setClientId
(
CLIENT_ID
);
RemotingCommand
request
=
RemotingCommand
.
createRequestCommand
(
requestCode
,
requestHeader
);
request
.
setBody
(
new
byte
[]
{
'a'
});
CodecHelper
.
makeCustomHeaderToNet
(
request
);
return
request
;
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录