mirror of https://github.com/apache/nifi.git
NIFI-8789 Corrected TestListenUDP to use getAvailableUdpPort()
Signed-off-by: Pierre Villard <pierre.villard.fr@gmail.com> This closes #5219.
This commit is contained in:
parent
e4ff6f95a0
commit
00f385b51b
|
@ -31,17 +31,22 @@ import org.apache.nifi.util.TestRunners;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
|
import org.mockito.junit.MockitoJUnitRunner;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.DatagramPacket;
|
import java.net.DatagramPacket;
|
||||||
import java.net.DatagramSocket;
|
import java.net.DatagramSocket;
|
||||||
import java.net.InetSocketAddress;
|
import java.net.InetSocketAddress;
|
||||||
|
import java.nio.channels.DatagramChannel;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.concurrent.BlockingQueue;
|
import java.util.concurrent.BlockingQueue;
|
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
public class TestListenUDP {
|
public class TestListenUDP {
|
||||||
|
|
||||||
private static final String LOCALHOST = "localhost";
|
private static final String LOCALHOST = "localhost";
|
||||||
|
@ -50,10 +55,13 @@ public class TestListenUDP {
|
||||||
|
|
||||||
private TestRunner runner;
|
private TestRunner runner;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private ChannelResponder<DatagramChannel> responder;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
runner = TestRunners.newTestRunner(ListenUDP.class);
|
runner = TestRunners.newTestRunner(ListenUDP.class);
|
||||||
port = NetworkUtils.availablePort();
|
port = NetworkUtils.getAvailableUdpPort();
|
||||||
runner.setProperty(ListenUDP.PORT, Integer.toString(port));
|
runner.setProperty(ListenUDP.PORT, Integer.toString(port));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,7 +70,7 @@ public class TestListenUDP {
|
||||||
runner.setProperty(ListenUDP.PORT, "1");
|
runner.setProperty(ListenUDP.PORT, "1");
|
||||||
runner.assertValid();
|
runner.assertValid();
|
||||||
|
|
||||||
runner.setProperty(ListenUDP.SENDING_HOST, "localhost");
|
runner.setProperty(ListenUDP.SENDING_HOST, LOCALHOST);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
|
|
||||||
runner.setProperty(ListenUDP.SENDING_HOST_PORT, "1234");
|
runner.setProperty(ListenUDP.SENDING_HOST_PORT, "1234");
|
||||||
|
@ -75,12 +83,9 @@ public class TestListenUDP {
|
||||||
@Test
|
@Test
|
||||||
public void testDefaultBehavior() throws IOException, InterruptedException {
|
public void testDefaultBehavior() throws IOException, InterruptedException {
|
||||||
final List<String> messages = getMessages(15);
|
final List<String> messages = getMessages(15);
|
||||||
final int expectedQueued = messages.size();
|
|
||||||
final int expectedTransferred = messages.size();
|
final int expectedTransferred = messages.size();
|
||||||
|
|
||||||
// default behavior should produce a FlowFile per message sent
|
run(new DatagramSocket(), messages, expectedTransferred);
|
||||||
|
|
||||||
run(new DatagramSocket(), messages, expectedQueued, expectedTransferred);
|
|
||||||
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, messages.size());
|
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, messages.size());
|
||||||
|
|
||||||
List<MockFlowFile> mockFlowFiles = runner.getFlowFilesForRelationship(ListenUDP.REL_SUCCESS);
|
List<MockFlowFile> mockFlowFiles = runner.getFlowFilesForRelationship(ListenUDP.REL_SUCCESS);
|
||||||
|
@ -95,7 +100,7 @@ public class TestListenUDP {
|
||||||
|
|
||||||
final List<String> messages = getMessages(20);
|
final List<String> messages = getMessages(20);
|
||||||
|
|
||||||
run(new DatagramSocket(), messages, maxQueueSize, maxQueueSize);
|
run(new DatagramSocket(), messages, maxQueueSize);
|
||||||
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, maxQueueSize);
|
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, maxQueueSize);
|
||||||
|
|
||||||
List<MockFlowFile> mockFlowFiles = runner.getFlowFilesForRelationship(ListenUDP.REL_SUCCESS);
|
List<MockFlowFile> mockFlowFiles = runner.getFlowFilesForRelationship(ListenUDP.REL_SUCCESS);
|
||||||
|
@ -110,10 +115,9 @@ public class TestListenUDP {
|
||||||
runner.setProperty(ListenUDP.MAX_BATCH_SIZE, "3");
|
runner.setProperty(ListenUDP.MAX_BATCH_SIZE, "3");
|
||||||
|
|
||||||
final List<String> messages = getMessages(5);
|
final List<String> messages = getMessages(5);
|
||||||
final int expectedQueued = messages.size();
|
|
||||||
final int expectedTransferred = 2;
|
final int expectedTransferred = 2;
|
||||||
|
|
||||||
run(new DatagramSocket(), messages, expectedQueued, expectedTransferred);
|
run(new DatagramSocket(), messages, expectedTransferred);
|
||||||
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, expectedTransferred);
|
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, expectedTransferred);
|
||||||
|
|
||||||
List<MockFlowFile> mockFlowFiles = runner.getFlowFilesForRelationship(ListenUDP.REL_SUCCESS);
|
List<MockFlowFile> mockFlowFiles = runner.getFlowFilesForRelationship(ListenUDP.REL_SUCCESS);
|
||||||
|
@ -131,55 +135,52 @@ public class TestListenUDP {
|
||||||
public void testBatchingWithDifferentSenders() {
|
public void testBatchingWithDifferentSenders() {
|
||||||
final String sender1 = "sender1";
|
final String sender1 = "sender1";
|
||||||
final String sender2 = "sender2";
|
final String sender2 = "sender2";
|
||||||
final ChannelResponder responder = Mockito.mock(ChannelResponder.class);
|
|
||||||
final byte[] message = "test message".getBytes(StandardCharsets.UTF_8);
|
final byte[] message = "test message".getBytes(StandardCharsets.UTF_8);
|
||||||
|
|
||||||
final List<StandardEvent> mockEvents = new ArrayList<>();
|
final List<StandardEvent<DatagramChannel>> mockEvents = new ArrayList<>();
|
||||||
mockEvents.add(new StandardEvent(sender1, message, responder));
|
mockEvents.add(new StandardEvent<>(sender1, message, responder));
|
||||||
mockEvents.add(new StandardEvent(sender1, message, responder));
|
mockEvents.add(new StandardEvent<>(sender1, message, responder));
|
||||||
mockEvents.add(new StandardEvent(sender2, message, responder));
|
mockEvents.add(new StandardEvent<>(sender2, message, responder));
|
||||||
mockEvents.add(new StandardEvent(sender2, message, responder));
|
mockEvents.add(new StandardEvent<>(sender2, message, responder));
|
||||||
|
|
||||||
MockListenUDP mockListenUDP = new MockListenUDP(mockEvents);
|
MockListenUDP mockListenUDP = new MockListenUDP(mockEvents);
|
||||||
runner = TestRunners.newTestRunner(mockListenUDP);
|
runner = TestRunners.newTestRunner(mockListenUDP);
|
||||||
runner.setProperty(ListenRELP.PORT, "1");
|
runner.setProperty(ListenUDP.PORT, "1");
|
||||||
runner.setProperty(ListenRELP.MAX_BATCH_SIZE, "10");
|
runner.setProperty(ListenUDP.MAX_BATCH_SIZE, "10");
|
||||||
|
|
||||||
// sending 4 messages with a batch size of 10, but should get 2 FlowFiles because of different senders
|
// sending 4 messages with a batch size of 10, but should get 2 FlowFiles because of different senders
|
||||||
runner.run();
|
runner.run();
|
||||||
runner.assertAllFlowFilesTransferred(ListenRELP.REL_SUCCESS, 2);
|
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, 2);
|
||||||
|
|
||||||
verifyProvenance(2);
|
verifyProvenance(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testRunWhenNoEventsAvailable() {
|
public void testRunWhenNoEventsAvailable() {
|
||||||
final List<StandardEvent> mockEvents = new ArrayList<>();
|
final List<StandardEvent<DatagramChannel>> mockEvents = new ArrayList<>();
|
||||||
|
|
||||||
MockListenUDP mockListenUDP = new MockListenUDP(mockEvents);
|
MockListenUDP mockListenUDP = new MockListenUDP(mockEvents);
|
||||||
runner = TestRunners.newTestRunner(mockListenUDP);
|
runner = TestRunners.newTestRunner(mockListenUDP);
|
||||||
runner.setProperty(ListenRELP.PORT, "1");
|
runner.setProperty(ListenUDP.PORT, "1");
|
||||||
runner.setProperty(ListenRELP.MAX_BATCH_SIZE, "10");
|
runner.setProperty(ListenUDP.MAX_BATCH_SIZE, "10");
|
||||||
|
|
||||||
runner.run(5);
|
runner.run(5);
|
||||||
runner.assertAllFlowFilesTransferred(ListenRELP.REL_SUCCESS, 0);
|
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testWithSendingHostAndPortSameAsSender() throws IOException, InterruptedException {
|
public void testWithSendingHostAndPortSameAsSender() throws IOException, InterruptedException {
|
||||||
final String sendingHost = "localhost";
|
final Integer sendingPort = NetworkUtils.getAvailableUdpPort();
|
||||||
final Integer sendingPort = 21001;
|
runner.setProperty(ListenUDP.SENDING_HOST, LOCALHOST);
|
||||||
runner.setProperty(ListenUDP.SENDING_HOST, sendingHost);
|
|
||||||
runner.setProperty(ListenUDP.SENDING_HOST_PORT, String.valueOf(sendingPort));
|
runner.setProperty(ListenUDP.SENDING_HOST_PORT, String.valueOf(sendingPort));
|
||||||
|
|
||||||
// bind to the same sending port that processor has for Sending Host Port
|
// bind to the same sending port that processor has for Sending Host Port
|
||||||
final DatagramSocket socket = new DatagramSocket(sendingPort);
|
final DatagramSocket socket = new DatagramSocket(sendingPort);
|
||||||
|
|
||||||
final List<String> messages = getMessages(6);
|
final List<String> messages = getMessages(6);
|
||||||
final int expectedQueued = messages.size();
|
|
||||||
final int expectedTransferred = messages.size();
|
final int expectedTransferred = messages.size();
|
||||||
|
|
||||||
run(socket, messages, expectedQueued, expectedTransferred);
|
run(socket, messages, expectedTransferred);
|
||||||
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, messages.size());
|
runner.assertAllFlowFilesTransferred(ListenUDP.REL_SUCCESS, messages.size());
|
||||||
|
|
||||||
List<MockFlowFile> mockFlowFiles = runner.getFlowFilesForRelationship(ListenUDP.REL_SUCCESS);
|
List<MockFlowFile> mockFlowFiles = runner.getFlowFilesForRelationship(ListenUDP.REL_SUCCESS);
|
||||||
|
@ -214,11 +215,8 @@ public class TestListenUDP {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void run(final DatagramSocket socket, final List<String> messages, final int expectedQueueSize, final int expectedTransferred)
|
protected void run(final DatagramSocket socket, final List<String> messages, final int expectedTransferred)
|
||||||
throws IOException, InterruptedException {
|
throws IOException, InterruptedException {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Run Processor and start Dispatcher without shutting down
|
// Run Processor and start Dispatcher without shutting down
|
||||||
runner.run(1, false, true);
|
runner.run(1, false, true);
|
||||||
|
|
||||||
|
@ -242,9 +240,9 @@ public class TestListenUDP {
|
||||||
// Extend ListenUDP to mock the ChannelDispatcher and allow us to return staged events
|
// Extend ListenUDP to mock the ChannelDispatcher and allow us to return staged events
|
||||||
private static class MockListenUDP extends ListenUDP {
|
private static class MockListenUDP extends ListenUDP {
|
||||||
|
|
||||||
private List<StandardEvent> mockEvents;
|
private final List<StandardEvent<DatagramChannel>> mockEvents;
|
||||||
|
|
||||||
public MockListenUDP(List<StandardEvent> mockEvents) {
|
public MockListenUDP(List<StandardEvent<DatagramChannel>> mockEvents) {
|
||||||
this.mockEvents = mockEvents;
|
this.mockEvents = mockEvents;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -259,7 +257,5 @@ public class TestListenUDP {
|
||||||
protected ChannelDispatcher createDispatcher(ProcessContext context, BlockingQueue<StandardEvent> events) {
|
protected ChannelDispatcher createDispatcher(ProcessContext context, BlockingQueue<StandardEvent> events) {
|
||||||
return Mockito.mock(ChannelDispatcher.class);
|
return Mockito.mock(ChannelDispatcher.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue