Ejemplo n.º 1
0
//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes:
//ORIGINAL LINE: @Test(timeout = 5_000) public void shouldGiveUpAddingMessagesInTheQueueIfTheHandlerHasBeenStopped() throws Throwable
//JAVA TO C# CONVERTER WARNING: Method 'throws' clauses are not available in C#:
        public virtual void ShouldGiveUpAddingMessagesInTheQueueIfTheHandlerHasBeenStopped()
        {
            // given
            BatchingMessageHandler batchHandler = new BatchingMessageHandler(_downstreamHandler, new BoundedPriorityQueue.Config(1, 1, 1024), _batchConfig, _jobSchedulerFactory, NullLogProvider.Instance);

            NewEntry.Request message = new NewEntry.Request(null, new ReplicatedString("dummy"));
            batchHandler.Handle(Wrap(message));                   // fill the queue

            System.Threading.CountdownEvent latch = new System.Threading.CountdownEvent(1);

            // when
            Thread thread = new Thread(() =>
            {
                latch.Signal();
                batchHandler.Handle(Wrap(message));
            });

            thread.Start();

            latch.await();

            batchHandler.Stop();

            thread.Join();

            // then we are not stuck and we terminate
        }
Ejemplo n.º 2
0
//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes:
//ORIGINAL LINE: @Test public void shouldPrioritiseCorrectly()
        public virtual void ShouldPrioritiseCorrectly()
        {
            BatchingMessageHandler batchHandler = new BatchingMessageHandler(_downstreamHandler, _inQueueConfig, _batchConfig, _jobSchedulerFactory, NullLogProvider.Instance);

            NewEntry.Request      newEntry    = new NewEntry.Request(null, Content(""));
            AppendEntries.Request append      = new AppendEntries.Request(_leader, 1, -1, -1, Entries(0, 0, 0), 0);
            AppendEntries.Request emptyAppend = new AppendEntries.Request(_leader, 1, -1, -1, RaftLogEntry.empty, 0);
            Heartbeat             heartbeat   = new Heartbeat(null, 0, 0, 0);

            batchHandler.Handle(Wrap(newEntry));
            batchHandler.Handle(Wrap(append));
            batchHandler.Handle(Wrap(heartbeat));
            batchHandler.Handle(Wrap(emptyAppend));
            verifyZeroInteractions(_downstreamHandler);

            // when
            batchHandler.Run();
            batchHandler.Run();
            batchHandler.Run();
            batchHandler.Run();

            // then
            InOrder inOrder = Mockito.inOrder(_downstreamHandler);

            inOrder.verify(_downstreamHandler).handle(Wrap(heartbeat));
            inOrder.verify(_downstreamHandler).handle(Wrap(emptyAppend));
            inOrder.verify(_downstreamHandler).handle(Wrap(append));
            inOrder.verify(_downstreamHandler).handle(Wrap(new NewEntry.BatchRequest(singletonList(Content("")))));
        }
Ejemplo n.º 3
0
//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes:
//ORIGINAL LINE: @Test public void shouldBatchNewEntriesAndHandleOtherMessagesFirst()
        public virtual void ShouldBatchNewEntriesAndHandleOtherMessagesFirst()
        {
            // given
            BatchingMessageHandler batchHandler = new BatchingMessageHandler(_downstreamHandler, _inQueueConfig, _batchConfig, _jobSchedulerFactory, NullLogProvider.Instance);

            ReplicatedString contentA = new ReplicatedString("A");
            ReplicatedString contentC = new ReplicatedString("C");

            NewEntry.Request newEntryA  = new NewEntry.Request(null, contentA);
            Heartbeat        heartbeatA = new Heartbeat(null, 0, 0, 0);

            NewEntry.Request newEntryB  = new NewEntry.Request(null, contentC);
            Heartbeat        heartbeatB = new Heartbeat(null, 1, 1, 1);

            batchHandler.Handle(Wrap(newEntryA));
            batchHandler.Handle(Wrap(heartbeatA));
            batchHandler.Handle(Wrap(newEntryB));
            batchHandler.Handle(Wrap(heartbeatB));
            verifyZeroInteractions(_downstreamHandler);

            // when
            batchHandler.Run();               // heartbeatA
            batchHandler.Run();               // heartbeatB
            batchHandler.Run();               // batchRequest

            // then
            NewEntry.BatchRequest batchRequest = new NewEntry.BatchRequest(asList(contentA, contentC));

            verify(_downstreamHandler).handle(Wrap(heartbeatA));
            verify(_downstreamHandler).handle(Wrap(heartbeatB));
            verify(_downstreamHandler).handle(Wrap(batchRequest));
        }
Ejemplo n.º 4
0
//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes:
//ORIGINAL LINE: @Test public void shouldInvokeHandlerOnQueuedMessage() throws Throwable
//JAVA TO C# CONVERTER WARNING: Method 'throws' clauses are not available in C#:
        public virtual void ShouldInvokeHandlerOnQueuedMessage()
        {
            // given
            BatchingMessageHandler batchHandler = new BatchingMessageHandler(_downstreamHandler, _inQueueConfig, _batchConfig, _jobSchedulerFactory, NullLogProvider.Instance);
            ReplicatedString       content      = new ReplicatedString("dummy");

            NewEntry.Request message = new NewEntry.Request(null, content);

//JAVA TO C# CONVERTER WARNING: Java wildcard generics have no direct equivalent in .NET:
//ORIGINAL LINE: java.util.concurrent.Future<?> future = executor.submit(batchHandler);
            Future <object> future = _executor.submit(batchHandler);

            // Some time for letting the batch handler block on its internal queue.
            //
            // It is fine if it sometimes doesn't get that far in time, just that we
            // usually want to test the wake up from blocking state.
            Thread.Sleep(50);

            // when
            batchHandler.Handle(Wrap(message));

            // then
            future.get();
            NewEntry.BatchRequest expected = new NewEntry.BatchRequest(singletonList(content));
            verify(_downstreamHandler).handle(Wrap(expected));
        }
Ejemplo n.º 5
0
//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes:
//ORIGINAL LINE: @Test public void shouldDropMessagesAfterBeingStopped() throws Throwable
//JAVA TO C# CONVERTER WARNING: Method 'throws' clauses are not available in C#:
        public virtual void ShouldDropMessagesAfterBeingStopped()
        {
            // given
            AssertableLogProvider  logProvider  = new AssertableLogProvider();
            BatchingMessageHandler batchHandler = new BatchingMessageHandler(_downstreamHandler, _inQueueConfig, _batchConfig, _jobSchedulerFactory, logProvider);

            NewEntry.Request message = new NewEntry.Request(null, null);
            batchHandler.Stop();

            // when
            batchHandler.Handle(Wrap(message));
            batchHandler.Run();

            // then
            verify(_downstreamHandler, never()).handle(ArgumentMatchers.any(typeof(RaftMessages_ReceivedInstantClusterIdAwareMessage)));
            logProvider.AssertAtLeastOnce(AssertableLogProvider.inLog(typeof(BatchingMessageHandler)).debug("This handler has been stopped, dropping the message: %s", Wrap(message)));
        }
Ejemplo n.º 6
0
//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes:
//ORIGINAL LINE: @Test public void shouldInvokeInnerHandlerWhenRun()
        public virtual void ShouldInvokeInnerHandlerWhenRun()
        {
            // given
            BatchingMessageHandler batchHandler = new BatchingMessageHandler(_downstreamHandler, _inQueueConfig, _batchConfig, _jobSchedulerFactory, NullLogProvider.Instance);

            NewEntry.Request message = new NewEntry.Request(null, Content("dummy"));

            batchHandler.Handle(Wrap(message));
            verifyZeroInteractions(_downstreamHandler);

            // when
            batchHandler.Run();

            // then
            NewEntry.BatchRequest expected = new NewEntry.BatchRequest(singletonList(new ReplicatedString("dummy")));
            verify(_downstreamHandler).handle(Wrap(expected));
        }
Ejemplo n.º 7
0
//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes:
//ORIGINAL LINE: @Test public void shouldBatchUsingReceivedInstantOfFirstReceivedMessage()
        public virtual void ShouldBatchUsingReceivedInstantOfFirstReceivedMessage()
        {
            // given
            BatchingMessageHandler batchHandler = new BatchingMessageHandler(_downstreamHandler, _inQueueConfig, _batchConfig, _jobSchedulerFactory, NullLogProvider.Instance);
            ReplicatedString       content      = new ReplicatedString("A");

            NewEntry.Request messageA = new NewEntry.Request(null, content);

            Instant firstReceived  = Instant.ofEpochMilli(1L);
            Instant secondReceived = firstReceived.plusMillis(1L);

            batchHandler.Handle(Wrap(firstReceived, messageA));
            batchHandler.Handle(Wrap(secondReceived, messageA));

            // when
            batchHandler.Run();

            // then
            NewEntry.BatchRequest batchRequest = new NewEntry.BatchRequest(asList(content, content));
            verify(_downstreamHandler).handle(Wrap(firstReceived, batchRequest));
        }
Ejemplo n.º 8
0
//JAVA TO C# CONVERTER TODO TASK: Most Java annotations will not have direct .NET equivalent attributes:
//ORIGINAL LINE: @Test public void shouldBatchRequests()
        public virtual void ShouldBatchRequests()
        {
            // given
            BatchingMessageHandler batchHandler = new BatchingMessageHandler(_downstreamHandler, _inQueueConfig, _batchConfig, _jobSchedulerFactory, NullLogProvider.Instance);
            ReplicatedString       contentA     = new ReplicatedString("A");
            ReplicatedString       contentB     = new ReplicatedString("B");

            NewEntry.Request messageA = new NewEntry.Request(null, contentA);
            NewEntry.Request messageB = new NewEntry.Request(null, contentB);

            batchHandler.Handle(Wrap(messageA));
            batchHandler.Handle(Wrap(messageB));
            verifyZeroInteractions(_downstreamHandler);

            // when
            batchHandler.Run();

            // then
            NewEntry.BatchRequest expected = new NewEntry.BatchRequest(asList(contentA, contentB));
            verify(_downstreamHandler).handle(Wrap(expected));
        }