【消息队列开发】 实现 MqClientTests 类——测试客户端

🍃前言

本次开发任务

  • 测试客户端接口
    在这里插入图片描述

🌳所需属性

所需要一共三个属性

BrokerServer:服务器

ConnectionFactory:Connection 工厂

Thread:创建一个线程执行 服务启动的线程

private BrokerServer brokerServer = null;
private ConnectionFactory factory = null;
private Thread t = null;

🌴@BeforeEach

这里我们实现步骤有两步:

  1. 启动服务器

  2. 配置 ConnectionFactory

这里注意,我们在启动服务器的时候,由于服务器启动后,就会一直循环下去,就不会执行到后面的配置 ConnectionFactory了,所以我们这里得另起一个线程来启动服务器。

代码实现如下:

@BeforeEach
public void setUp() throws IOException {
    // 1. 先启动服务器
    MqApplication.context = SpringApplication.run(MqApplication.class);
    brokerServer = new BrokerServer(9090);
    t = new Thread(() -> {
        // 这个 start 方法会进入一个死循环. 使用一个新的线程来运行 start 即可!
        try {
            brokerServer.start();
        } catch (IOException e) {
            e.printStackTrace();
        }
    });
    t.start();

    // 2. 配置 ConnectionFactory
    factory = new ConnectionFactory();
    factory.setHost("127.0.0.1");
    factory.setPort(9090);
}

🌲@AfterEach

实现步骤分为两步:

  1. 停止服务器
  2. 删除必要的文件

代码实现如下:

    @AfterEach
    public void tearDown() throws IOException {
        // 停止服务器
        brokerServer.stop();
        // t.join();
        MqApplication.context.close();

        // 删除必要的文件
        File file = new File("./data");
        FileUtils.deleteDirectory(file);

        factory = null;
    }

🎍API测试

API 部分我们调用,再使用判断即可。

这里就不一一讲解了,代码实现如下:

@Test
public void testConnection() throws IOException {
    Connection connection = factory.newConnection();
    Assertions.assertNotNull(connection);
}

@Test
public void testChannel() throws IOException {
    Connection connection = factory.newConnection();
    Assertions.assertNotNull(connection);
    Channel channel = connection.createChannel();
    Assertions.assertNotNull(channel);
}

@Test
public void testExchange() throws IOException {
    Connection connection = factory.newConnection();
    Assertions.assertNotNull(connection);
    Channel channel = connection.createChannel();
    Assertions.assertNotNull(channel);

    boolean ok = channel.exchangeDeclare("testExchange", ExchangeType.DIRECT, true, false, null);
    Assertions.assertTrue(ok);

    ok = channel.exchangeDelete("testExchange");
    Assertions.assertTrue(ok);

    // 此处稳妥起见, 把改关闭的要进行关闭.
    channel.close();
    connection.close();
}

@Test
public void testQueue() throws IOException {
    Connection connection = factory.newConnection();
    Assertions.assertNotNull(connection);
    Channel channel = connection.createChannel();
    Assertions.assertNotNull(channel);

    boolean ok = channel.queueDeclare("testQueue", true, false, false, null);
    Assertions.assertTrue(ok);

    ok = channel.queueDelete("testQueue");
    Assertions.assertTrue(ok);

    channel.close();
    connection.close();
}

@Test
public void testBinding() throws IOException {
    Connection connection = factory.newConnection();
    Assertions.assertNotNull(connection);
    Channel channel = connection.createChannel();
    Assertions.assertNotNull(channel);

    boolean ok = channel.exchangeDeclare("testExchange", ExchangeType.DIRECT, true, false, null);
    Assertions.assertTrue(ok);
    ok = channel.queueDeclare("testQueue", true, false, false, null);
    Assertions.assertTrue(ok);

    ok = channel.queueBind("testQueue", "testExchange", "testBindingKey");
    Assertions.assertTrue(ok);

    ok = channel.queueUnbind("testQueue", "testExchange");
    Assertions.assertTrue(ok);

    channel.close();
    connection.close();
}

@Test
public void testMessage() throws IOException, MqException, InterruptedException {
    Connection connection = factory.newConnection();
    Assertions.assertNotNull(connection);
    Channel channel = connection.createChannel();
    Assertions.assertNotNull(channel);

    boolean ok = channel.exchangeDeclare("testExchange", ExchangeType.DIRECT, true, false, null);
    Assertions.assertTrue(ok);
    ok = channel.queueDeclare("testQueue", true, false, false, null);
    Assertions.assertTrue(ok);

    byte[] requestBody = "hello".getBytes();
    ok = channel.basicPublish("testExchange", "testQueue", null, requestBody);
    Assertions.assertTrue(ok);

    ok = channel.basicConsume("testQueue", true, new Consumer() {
        @Override
        public void handleDelivery(String consumerTag, BasicProperties basicProperties, byte[] body) throws MqException, IOException {
            System.out.println("[消费数据] 开始!");
            System.out.println("consumerTag=" + consumerTag);
            System.out.println("basicProperties=" + basicProperties);
            Assertions.assertArrayEquals(requestBody, body);
            System.out.println("[消费数据] 结束!");
        }
    });
    Assertions.assertTrue(ok);

    Thread.sleep(500);

    channel.close();
    connection.close();
}

⭕总结

关于《【消息队列开发】 实现 MqClientTests 类——测试客户端》就讲解到这儿,感谢大家的支持,欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下

  • 19
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

遇事问春风乄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值