added test for negative case to the checkpoint node
This commit is contained in:
parent
8e81bd80e6
commit
7977d50410
@ -43,7 +43,6 @@ public class TbAckNodeTest {
|
|||||||
private EmptyNodeConfiguration config;
|
private EmptyNodeConfiguration config;
|
||||||
private TbNodeConfiguration nodeConfiguration;
|
private TbNodeConfiguration nodeConfiguration;
|
||||||
|
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private TbContext ctxMock;
|
private TbContext ctxMock;
|
||||||
|
|
||||||
|
|||||||
@ -22,6 +22,7 @@ import org.junit.jupiter.api.extension.ExtendWith;
|
|||||||
import org.junit.jupiter.params.ParameterizedTest;
|
import org.junit.jupiter.params.ParameterizedTest;
|
||||||
import org.junit.jupiter.params.provider.Arguments;
|
import org.junit.jupiter.params.provider.Arguments;
|
||||||
import org.junit.jupiter.params.provider.ValueSource;
|
import org.junit.jupiter.params.provider.ValueSource;
|
||||||
|
import org.mockito.ArgumentCaptor;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.junit.jupiter.MockitoExtension;
|
import org.mockito.junit.jupiter.MockitoExtension;
|
||||||
import org.thingsboard.common.util.JacksonUtil;
|
import org.thingsboard.common.util.JacksonUtil;
|
||||||
@ -49,12 +50,13 @@ import static org.mockito.ArgumentMatchers.eq;
|
|||||||
import static org.mockito.BDDMockito.given;
|
import static org.mockito.BDDMockito.given;
|
||||||
import static org.mockito.BDDMockito.spy;
|
import static org.mockito.BDDMockito.spy;
|
||||||
import static org.mockito.BDDMockito.then;
|
import static org.mockito.BDDMockito.then;
|
||||||
import static org.mockito.BDDMockito.willAnswer;
|
|
||||||
|
|
||||||
@Slf4j
|
@Slf4j
|
||||||
@ExtendWith(MockitoExtension.class)
|
@ExtendWith(MockitoExtension.class)
|
||||||
public class TbCheckpointNodeTest extends AbstractRuleNodeUpgradeTest {
|
public class TbCheckpointNodeTest extends AbstractRuleNodeUpgradeTest {
|
||||||
|
|
||||||
|
private final DeviceId DEVICE_ID = new DeviceId(UUID.fromString("37840655-b7dc-4f49-8da3-9429159e0970"));
|
||||||
|
|
||||||
private TbCheckpointNode node;
|
private TbCheckpointNode node;
|
||||||
private EmptyNodeConfiguration config;
|
private EmptyNodeConfiguration config;
|
||||||
private TbNodeConfiguration nodeConfiguration;
|
private TbNodeConfiguration nodeConfiguration;
|
||||||
@ -80,24 +82,37 @@ public class TbCheckpointNodeTest extends AbstractRuleNodeUpgradeTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ParameterizedTest
|
@ParameterizedTest
|
||||||
@ValueSource(strings = {DataConstants.MAIN_QUEUE_NAME, DataConstants.HP_QUEUE_NAME, DataConstants.HP_QUEUE_NAME, "Custom queue"})
|
@ValueSource(strings = {DataConstants.MAIN_QUEUE_NAME, DataConstants.HP_QUEUE_NAME, DataConstants.SQ_QUEUE_NAME, "Custom queue"})
|
||||||
public void givenQueueName_whenOnMsg_thenTransfersMsgToDefinedQueue(String queueName) throws TbNodeException {
|
public void givenQueueName_whenOnMsg_thenTransfersMsgToDefinedQueue(String queueName) throws TbNodeException {
|
||||||
given(ctxMock.getQueueName()).willReturn(queueName);
|
given(ctxMock.getQueueName()).willReturn(queueName);
|
||||||
willAnswer(invocationOnMock -> {
|
|
||||||
Runnable onSuccess = invocationOnMock.getArgument(3);
|
|
||||||
onSuccess.run();
|
|
||||||
return null;
|
|
||||||
}).given(ctxMock).enqueueForTellNext(any(TbMsg.class), any(String.class), any(String.class), any(Runnable.class), any(Consumer.class));
|
|
||||||
|
|
||||||
node.init(ctxMock, nodeConfiguration);
|
node.init(ctxMock, nodeConfiguration);
|
||||||
DeviceId deviceId = new DeviceId(UUID.fromString("2cd04871-7f07-41d1-b850-95dd444a6506"));
|
TbMsg msg = TbMsg.newMsg(TbMsgType.POST_TELEMETRY_REQUEST, DEVICE_ID, TbMsgMetaData.EMPTY, TbMsg.EMPTY_JSON_OBJECT);
|
||||||
TbMsg msg = TbMsg.newMsg(TbMsgType.POST_TELEMETRY_REQUEST, deviceId, TbMsgMetaData.EMPTY, TbMsg.EMPTY_JSON_OBJECT);
|
|
||||||
node.onMsg(ctxMock, msg);
|
node.onMsg(ctxMock, msg);
|
||||||
|
|
||||||
then(ctxMock).should().enqueueForTellNext(eq(msg), eq(queueName), eq(TbNodeConnectionType.SUCCESS), any(), any());
|
ArgumentCaptor<Runnable> onSuccess = ArgumentCaptor.forClass(Runnable.class);
|
||||||
|
then(ctxMock).should().enqueueForTellNext(eq(msg), eq(queueName), eq(TbNodeConnectionType.SUCCESS), onSuccess.capture(), any());
|
||||||
|
onSuccess.getValue().run();
|
||||||
then(ctxMock).should().ack(msg);
|
then(ctxMock).should().ack(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenErrorDuringTransfer_whenOnMsg_thenTellFailure() throws TbNodeException {
|
||||||
|
given(ctxMock.getQueueName()).willReturn(DataConstants.HP_QUEUE_NAME);
|
||||||
|
|
||||||
|
node.init(ctxMock, nodeConfiguration);
|
||||||
|
TbMsg msg = TbMsg.newMsg(TbMsgType.POST_TELEMETRY_REQUEST, DEVICE_ID, TbMsgMetaData.EMPTY, TbMsg.EMPTY_JSON_OBJECT);
|
||||||
|
node.onMsg(ctxMock, msg);
|
||||||
|
|
||||||
|
ArgumentCaptor<Consumer<Throwable>> onFailure = ArgumentCaptor.forClass(Consumer.class);
|
||||||
|
then(ctxMock).should().enqueueForTellNext(eq(msg), eq(DataConstants.HP_QUEUE_NAME), eq(TbNodeConnectionType.SUCCESS), any(), onFailure.capture());
|
||||||
|
String errorMsg = "Something went wrong.";
|
||||||
|
onFailure.getValue().accept(new RuntimeException(errorMsg));
|
||||||
|
ArgumentCaptor<Throwable> throwable = ArgumentCaptor.forClass(Throwable.class);
|
||||||
|
then(ctxMock).should().tellFailure(eq(msg), throwable.capture());
|
||||||
|
assertThat(throwable.getValue()).isInstanceOf(RuntimeException.class).hasMessage(errorMsg);
|
||||||
|
}
|
||||||
|
|
||||||
// Rule nodes upgrade
|
// Rule nodes upgrade
|
||||||
private static Stream<Arguments> givenFromVersionAndConfig_whenUpgrade_thenVerifyHasChangesAndConfig() {
|
private static Stream<Arguments> givenFromVersionAndConfig_whenUpgrade_thenVerifyHasChangesAndConfig() {
|
||||||
return Stream.of(
|
return Stream.of(
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user