add corresponding test
This commit is contained in:
parent
570eda50d0
commit
95a426015e
@ -57,6 +57,7 @@ import static org.junit.Assert.assertTrue;
|
||||
import static org.mockito.ArgumentMatchers.any;
|
||||
import static org.mockito.ArgumentMatchers.nullable;
|
||||
import static org.mockito.Mockito.anyLong;
|
||||
import static org.mockito.Mockito.atMost;
|
||||
import static org.mockito.Mockito.doAnswer;
|
||||
import static org.mockito.Mockito.eq;
|
||||
import static org.mockito.Mockito.same;
|
||||
@ -513,6 +514,70 @@ public class TbAlarmNodeTest {
|
||||
assertEquals(expectedAlarm, actualAlarm);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testCreateAlarmsWithPropagationToTenantWithDynamicTypes() throws Exception{
|
||||
for (int i = 0; i < 10; i++) {
|
||||
var config = new TbCreateAlarmNodeConfiguration();
|
||||
config.setPropagateToTenant(true);
|
||||
config.setSeverity(CRITICAL.name());
|
||||
config.setAlarmType("SomeType" + i);
|
||||
config.setAlarmDetailsBuildJs("DETAILS");
|
||||
config.setDynamicSeverity(true);
|
||||
ObjectMapper mapper = new ObjectMapper();
|
||||
TbNodeConfiguration nodeConfiguration = new TbNodeConfiguration(mapper.valueToTree(config));
|
||||
|
||||
when(ctx.createJsScriptEngine("DETAILS")).thenReturn(detailsJs);
|
||||
|
||||
when(ctx.getTenantId()).thenReturn(tenantId);
|
||||
when(ctx.getAlarmService()).thenReturn(alarmService);
|
||||
when(ctx.getDbCallbackExecutor()).thenReturn(dbExecutor);
|
||||
|
||||
node = new TbCreateAlarmNode();
|
||||
node.init(ctx, nodeConfiguration);
|
||||
|
||||
metaData.putValue("key", "value");
|
||||
TbMsg msg = TbMsg.newMsg("USER", originator, metaData, TbMsgDataType.JSON, rawJson, ruleChainId, ruleNodeId);
|
||||
|
||||
when(detailsJs.executeJsonAsync(msg)).thenReturn(Futures.immediateFuture(null));
|
||||
when(alarmService.findLatestByOriginatorAndType(tenantId, originator, "SomeType" + i)).thenReturn(Futures.immediateFuture(null));
|
||||
doAnswer((Answer<Alarm>) invocationOnMock -> (Alarm) (invocationOnMock.getArguments())[0]).when(alarmService).createOrUpdateAlarm(any(Alarm.class));
|
||||
long ts = msg.getTs();
|
||||
node.onMsg(ctx, msg);
|
||||
|
||||
verify(ctx, atMost(10)).enqueue(any(), successCaptor.capture(), failureCaptor.capture());
|
||||
successCaptor.getValue().run();
|
||||
verify(ctx, atMost(10)).tellNext(any(), eq("Created"));
|
||||
|
||||
ArgumentCaptor<TbMsg> msgCaptor = ArgumentCaptor.forClass(TbMsg.class);
|
||||
ArgumentCaptor<String> typeCaptor = ArgumentCaptor.forClass(String.class);
|
||||
ArgumentCaptor<EntityId> originatorCaptor = ArgumentCaptor.forClass(EntityId.class);
|
||||
ArgumentCaptor<TbMsgMetaData> metadataCaptor = ArgumentCaptor.forClass(TbMsgMetaData.class);
|
||||
ArgumentCaptor<String> dataCaptor = ArgumentCaptor.forClass(String.class);
|
||||
verify(ctx, atMost(10)).transformMsg(msgCaptor.capture(), typeCaptor.capture(), originatorCaptor.capture(), metadataCaptor.capture(), dataCaptor.capture());
|
||||
|
||||
assertEquals("ALARM", typeCaptor.getValue());
|
||||
assertEquals(originator, originatorCaptor.getValue());
|
||||
assertEquals("value", metadataCaptor.getValue().getValue("key"));
|
||||
assertEquals(Boolean.TRUE.toString(), metadataCaptor.getValue().getValue(IS_NEW_ALARM));
|
||||
assertNotSame(metaData, metadataCaptor.getValue());
|
||||
|
||||
Alarm actualAlarm = new ObjectMapper().readValue(dataCaptor.getValue().getBytes(), Alarm.class);
|
||||
Alarm expectedAlarm = Alarm.builder()
|
||||
.startTs(ts)
|
||||
.endTs(ts)
|
||||
.tenantId(tenantId)
|
||||
.originator(originator)
|
||||
.status(ACTIVE_UNACK)
|
||||
.severity(CRITICAL)
|
||||
.propagateToTenant(true)
|
||||
.type("SomeType" + i)
|
||||
.details(null)
|
||||
.build();
|
||||
|
||||
assertEquals(expectedAlarm, actualAlarm);
|
||||
}
|
||||
}
|
||||
|
||||
private void initWithCreateAlarmScript() {
|
||||
try {
|
||||
TbCreateAlarmNodeConfiguration config = new TbCreateAlarmNodeConfiguration();
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user