Github user cshannon commented on a diff in the pull request:

    https://github.com/apache/activemq-artemis/pull/2009#discussion_r180774964
  
    --- Diff: 
tests/integration-tests/src/test/java/org/apache/activemq/artemis/tests/integration/management/QueueControlTest.java
 ---
    @@ -2510,6 +2510,39 @@ public void testSendMessage() throws Exception {
           Assert.assertEquals(new String(body), "theBody");
        }
     
    +   @Test
    +   public void testGetScheduledCountOnRemove() throws Exception {
    +      long delay = Integer.MAX_VALUE;
    +      SimpleString address = RandomUtil.randomSimpleString();
    +      SimpleString queue = RandomUtil.randomSimpleString();
    +
    +      session.createQueue(address, RoutingType.MULTICAST, queue, null, 
durable);
    +
    +      QueueControl queueControl = createManagementControl(address, queue);
    +      Assert.assertEquals(0, queueControl.getScheduledCount());
    +
    +      Field queueMemorySizeField = 
QueueImpl.class.getDeclaredField("queueMemorySize");
    +      queueMemorySizeField.setAccessible(true);
    +      final LocalQueueBinding binding = (LocalQueueBinding) 
server.getPostOffice().getBinding(queue);
    +      Queue q = binding.getQueue();
    +      AtomicInteger queueMemorySize1 = (AtomicInteger) 
queueMemorySizeField.get(q);
    +      assertTrue(queueMemorySize1.get() == 0);
    +
    +      ClientProducer producer = session.createProducer(address);
    +      ClientMessage message = session.createMessage(durable);
    +      message.putLongProperty(Message.HDR_SCHEDULED_DELIVERY_TIME, 
System.currentTimeMillis() + delay);
    +      producer.send(message);
    +
    +      queueControl.removeAllMessages();
    +
    +      Assert.assertEquals(0, queueControl.getMessageCount());
    --- End diff --
    
    I think the removeAllMessages() call is synchronous but if it's an issue 
it's easy enough to switch out the assertion in the test


---

Reply via email to