blob: 94cf07a61f1661cc8b5515c602eff6d6ea4af357 [file] [log] [blame]
/*
* 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.spring.support;
import com.fasterxml.jackson.databind.ObjectMapper;
import java.util.Arrays;
import org.apache.rocketmq.acl.common.AclClientRPCHook;
import org.apache.rocketmq.acl.common.SessionCredentials;
import org.apache.rocketmq.common.UtilAll;
import org.apache.rocketmq.remoting.RPCHook;
import org.junit.Test;
import org.springframework.messaging.Message;
import org.springframework.messaging.support.MessageBuilder;
import static org.apache.rocketmq.spring.support.RocketMQUtil.toRocketHeaderKey;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertTrue;
public class RocketMQUtilTest {
private ObjectMapper objectMapper = new ObjectMapper();
@Test
public void testMessageBuilder() {
Message msg = MessageBuilder.withPayload("test").
setHeader("A", "test1").
setHeader("B", "test2").
build();
System.out.printf("header size=%d %s %n", msg.getHeaders().size(), msg.getHeaders().toString());
assertTrue(msg.getHeaders().get("A") != null);
assertTrue(msg.getHeaders().get("B") != null);
}
@Test
public void testPayload() {
String charset = "UTF-8";
String destination = "test-topic";
Message msgWithStringPayload = MessageBuilder.withPayload("test").build();
org.apache.rocketmq.common.message.Message rocketMsg1 = RocketMQUtil.convertToRocketMessage(objectMapper,
charset, destination, msgWithStringPayload);
Message msgWithBytePayload = MessageBuilder.withPayload("test".getBytes()).build();
org.apache.rocketmq.common.message.Message rocketMsg2 = RocketMQUtil.convertToRocketMessage(objectMapper,
charset, destination, msgWithBytePayload);
assertTrue(Arrays.equals(((String) msgWithStringPayload.getPayload()).getBytes(), rocketMsg1.getBody()));
assertTrue(Arrays.equals((byte[]) msgWithBytePayload.getPayload(), rocketMsg2.getBody()));
}
@Test
public void testHeaderConvertToRMQMsg() {
Message msgWithStringPayload = MessageBuilder.withPayload("test body")
.setHeader("test", 1)
.setHeader(RocketMQHeaders.TAGS, "tags")
.setHeader(RocketMQHeaders.KEYS, "my_keys")
.build();
org.apache.rocketmq.common.message.Message rocketMsg = RocketMQUtil.convertToRocketMessage(objectMapper,
"UTF-8", "test-topic", msgWithStringPayload);
assertEquals(String.valueOf("1"), rocketMsg.getProperty("test"));
assertNull(rocketMsg.getProperty(RocketMQHeaders.TAGS));
assertEquals("my_keys", rocketMsg.getProperty(RocketMQHeaders.KEYS));
}
@Test
public void testHeaderConvertToSpringMsg() {
org.apache.rocketmq.common.message.Message rmqMsg = new org.apache.rocketmq.common.message.Message();
rmqMsg.setBody("test body".getBytes());
rmqMsg.setTopic("test-topic");
rmqMsg.putUserProperty("test", "1");
rmqMsg.setTags("tags");
Message springMsg = RocketMQUtil.convertToSpringMessage(rmqMsg);
assertEquals(String.valueOf("1"), springMsg.getHeaders().get("test"));
assertEquals("tags", springMsg.getHeaders().get(RocketMQHeaders.PREFIX + RocketMQHeaders.TAGS));
org.apache.rocketmq.common.message.Message rocketMsg = RocketMQUtil.convertToRocketMessage(objectMapper,
"UTF-8", "test-topic", springMsg);
assertEquals(String.valueOf("1"), rocketMsg.getProperty("test"));
assertEquals(String.valueOf("tags"), rocketMsg.getProperty(RocketMQHeaders.PREFIX + RocketMQHeaders.TAGS));
assertNull(rocketMsg.getTags());
rmqMsg.putUserProperty(toRocketHeaderKey(RocketMQHeaders.TAGS), "tags2");
springMsg = RocketMQUtil.convertToSpringMessage(rmqMsg);
assertEquals("tags", springMsg.getHeaders().get(RocketMQHeaders.PREFIX + RocketMQHeaders.TAGS));
}
@Test
public void testConvertToRocketMessageWithMessageConvert() {
Message msgWithStringPayload = MessageBuilder.withPayload("test body")
.setHeader("test", 1)
.setHeader(RocketMQHeaders.TAGS, "tags")
.setHeader(RocketMQHeaders.KEYS, "my_keys")
.build();
RocketMQMessageConverter messageConverter = new RocketMQMessageConverter();
org.apache.rocketmq.common.message.Message rocketMsg = RocketMQUtil.convertToRocketMessage(messageConverter.getMessageConverter(),
"UTF-8", "test-topic", msgWithStringPayload);
assertEquals("1", rocketMsg.getProperty("test"));
assertNull(rocketMsg.getProperty(RocketMQHeaders.TAGS));
assertEquals("my_keys", rocketMsg.getProperty(RocketMQHeaders.KEYS));
Message msgWithBytesPayload = MessageBuilder.withPayload("123".getBytes()).build();
org.apache.rocketmq.common.message.Message rocketMsgWithObj = RocketMQUtil.convertToRocketMessage(messageConverter.getMessageConverter(),
"UTF-8", "test-topic", msgWithBytesPayload);
assertEquals("123", new String(rocketMsgWithObj.getBody()));
}
@Test
public void testConvertToSpringMessage() {
org.apache.rocketmq.common.message.MessageExt rocketMsg = new org.apache.rocketmq.common.message.MessageExt();
rocketMsg.setTopic("test");
rocketMsg.setBody("123".getBytes());
rocketMsg.setTags("tagA");
rocketMsg.setKeys("key1");
Message message = RocketMQUtil.convertToSpringMessage(rocketMsg);
assertEquals("test", message.getHeaders().get(toRocketHeaderKey(RocketMQHeaders.TOPIC)));
assertEquals("tagA", message.getHeaders().get(toRocketHeaderKey(RocketMQHeaders.TAGS)));
assertEquals("key1", message.getHeaders().get(toRocketHeaderKey(RocketMQHeaders.KEYS)));
}
@Test
public void testGetInstanceName() {
String ak = "123";
String sk = "456";
String consumerGroup = "consumerGroup";
RPCHook rpcHook = new AclClientRPCHook(new SessionCredentials(ak, sk));
String expected = "123|456|consumerGroup|";
assertEquals(expected + UtilAll.getPid(), RocketMQUtil.getInstanceName(rpcHook, consumerGroup));
}
}