org.apache.rocketmq.console.service.impl.ConsumerServiceImplTest.java Source code

Java tutorial

Introduction

Here is the source code for org.apache.rocketmq.console.service.impl.ConsumerServiceImplTest.java

Source

/*
 * 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.console.service.impl;

import com.google.common.base.Function;
import com.google.common.collect.Lists;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.apache.commons.collections.CollectionUtils;
import org.apache.rocketmq.common.protocol.body.Connection;
import org.apache.rocketmq.common.protocol.body.ConsumerConnection;
import org.apache.rocketmq.console.model.ConsumerGroupRollBackStat;
import org.apache.rocketmq.console.model.GroupConsumeInfo;
import org.apache.rocketmq.console.model.TopicConsumerInfo;
import org.apache.rocketmq.console.model.request.ConsumerConfigInfo;
import org.apache.rocketmq.console.model.request.DeleteSubGroupRequest;
import org.apache.rocketmq.console.model.request.ResetOffsetRequest;
import org.apache.rocketmq.console.testbase.RocketMQConsoleTestBase;
import org.apache.rocketmq.console.testbase.TestConstant;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.BeanUtils;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.annotation.DirtiesContext;
import org.springframework.test.context.junit4.SpringRunner;

@RunWith(SpringRunner.class)
@SpringBootTest
@DirtiesContext
public class ConsumerServiceImplTest extends RocketMQConsoleTestBase {

    @Before
    public void setUp() throws Exception {
        initMQClientEnv();
        registerTestMQTopic();
        sendTestTopicMessage();
    }

    @After
    public void tearDown() throws Exception {
        destroyMQClientEnv();
    }

    @Test
    public void queryGroupList() throws Exception {
        List<GroupConsumeInfo> consumeInfoList = consumerService.queryGroupList();
        Assert.assertTrue(CollectionUtils.isNotEmpty(consumeInfoList));
    }

    @Test
    public void queryGroup() throws Exception {
        GroupConsumeInfo consumeInfo = consumerService.queryGroup(TEST_CONSUMER_GROUP);
        //            if (consumeInfo.getCount() < 1) {
        //                Thread.sleep(2000);
        //                continue;
        //            }
        Assert.assertNotNull(consumeInfo);
        Assert.assertEquals(consumeInfo.getGroup(), TEST_CONSUMER_GROUP);
        //            Assert.assertTrue(consumeInfo.getCount() == 1);
    }

    @Test
    public void queryConsumeStatsListByGroupName() throws Exception {
        // todo can't use if don't consume a message
        List<TopicConsumerInfo> topicConsumerInfoList = new RetryTempLate<List<TopicConsumerInfo>>() {
            @Override
            protected List<TopicConsumerInfo> process() throws Exception {
                return consumerService.queryConsumeStatsListByGroupName(TEST_CONSUMER_GROUP);
            }
        }.execute(10, 2000);
        Assert.assertNotNull(topicConsumerInfoList);
        Assert.assertTrue(CollectionUtils.isNotEmpty(topicConsumerInfoList));
    }

    @Test
    public void queryConsumeStatsList() throws Exception {
        List<TopicConsumerInfo> topicConsumerInfoList = new RetryTempLate<List<TopicConsumerInfo>>() {
            @Override
            protected List<TopicConsumerInfo> process() throws Exception {
                return consumerService.queryConsumeStatsList(TEST_CONSOLE_TOPIC, TEST_CONSUMER_GROUP);
            }
        }.execute(10, 2000);
        Assert.assertNotNull(topicConsumerInfoList);
        Assert.assertTrue(CollectionUtils.isNotEmpty(topicConsumerInfoList));
    }

    @Test
    public void queryConsumeStatsListByTopicName() throws Exception {
        Map<String, TopicConsumerInfo> consumeTopicMap = new RetryTempLate<Map<String, TopicConsumerInfo>>() {
            @Override
            protected Map<String, TopicConsumerInfo> process() throws Exception {
                return consumerService.queryConsumeStatsListByTopicName(TEST_CONSOLE_TOPIC);
            }
        }.execute(10, 2000);
        Assert.assertNotNull(consumeTopicMap);
        Assert.assertNotNull(consumeTopicMap.get(TEST_CONSUMER_GROUP));

    }

    @Test
    public void resetOffset() throws Exception {
        ResetOffsetRequest resetOffsetRequest = new ResetOffsetRequest();
        resetOffsetRequest.setConsumerGroupList(Lists.<String>newArrayList(TEST_CONSUMER_GROUP));
        resetOffsetRequest.setForce(true);
        resetOffsetRequest.setTopic(TEST_CONSOLE_TOPIC);
        resetOffsetRequest.setResetTime(System.currentTimeMillis() - 1000);
        Map<String /*consumerGroup*/, ConsumerGroupRollBackStat> consumerGroupRollBackStatMap = consumerService
                .resetOffset(resetOffsetRequest);
        Assert.assertNotNull(consumerGroupRollBackStatMap);
        Assert.assertNotNull(consumerGroupRollBackStatMap.get(TEST_CONSUMER_GROUP));

    }

    @Test
    public void examineSubscriptionGroupConfig() throws Exception {
        List<ConsumerConfigInfo> configInfoList = consumerService
                .examineSubscriptionGroupConfig(TEST_CONSUMER_GROUP);
        Assert.assertTrue(configInfoList.size() == 1);
        Assert.assertTrue(
                configInfoList.get(0).getSubscriptionGroupConfig().getGroupName().equals(TEST_CONSUMER_GROUP));
        Assert.assertTrue(
                configInfoList.get(0).getSubscriptionGroupConfig().getRetryQueueNums() == RETRY_QUEUE_NUMS);

    }

    @Test
    public void deleteSubGroup() throws Exception {
        createAndUpdateSubscriptionGroupConfig();
        DeleteSubGroupRequest deleteSubGroupRequest = new DeleteSubGroupRequest();
        deleteSubGroupRequest.setBrokerNameList(Lists.<String>newArrayList(TestConstant.TEST_BROKER_NAME));
        deleteSubGroupRequest.setGroupName(TEST_CREATE_DELETE_CONSUMER_GROUP);
        Assert.assertTrue(consumerService.deleteSubGroup(deleteSubGroupRequest));
        List<ConsumerConfigInfo> groupConsumeInfoList = consumerService
                .examineSubscriptionGroupConfig(TEST_CREATE_DELETE_CONSUMER_GROUP);
        Assert.assertTrue(CollectionUtils.isEmpty(groupConsumeInfoList));
    }

    @Test
    public void createAndUpdateSubscriptionGroupConfig() throws Exception {
        ConsumerConfigInfo consumerConfigInfoForCreate = new ConsumerConfigInfo();
        BeanUtils.copyProperties(consumerConfigInfo, consumerConfigInfoForCreate);
        consumerConfigInfoForCreate.getSubscriptionGroupConfig().setGroupName(TEST_CREATE_DELETE_CONSUMER_GROUP);
        Assert.assertTrue(consumerService.createAndUpdateSubscriptionGroupConfig(consumerConfigInfoForCreate));
        Assert.assertTrue(CollectionUtils
                .isNotEmpty(consumerService.examineSubscriptionGroupConfig(TEST_CREATE_DELETE_CONSUMER_GROUP)));

    }

    @Test
    public void fetchBrokerNameSetBySubscriptionGroup() throws Exception {
        Set<String> xx = consumerService.fetchBrokerNameSetBySubscriptionGroup(TEST_CONSUMER_GROUP);
        Assert.assertTrue(xx.contains(TestConstant.TEST_BROKER_NAME));
    }

    @Test
    public void getConsumerConnection() throws Exception {
        ConsumerConnection consumerConnection = new RetryTempLate<ConsumerConnection>() {
            @Override
            protected ConsumerConnection process() throws Exception {
                return consumerService.getConsumerConnection(TEST_CONSUMER_GROUP);
            }
        }.execute(10, 2000);
        Assert.assertNotNull(consumerConnection);
        Assert.assertTrue(CollectionUtils.isNotEmpty(consumerConnection.getConnectionSet()));
        Assert.assertTrue(Lists.transform(Lists.newArrayList(consumerConnection.getConnectionSet()),
                new Function<Connection, String>() {
                    @Override
                    public String apply(Connection input) {
                        return input.getClientAddr().split(":")[0];
                    }
                }).contains(TestConstant.BROKER_IP));
    }

}