NIFI-11746 Fixed FlowSynchronizationIT.testComponentsRecreatedOnRestart()

- Ensure that testComponentsRecreatedOnRestart only counts components in its own group

This closes #7466

Signed-off-by: David Handermann <exceptionfactory@apache.org>
This commit is contained in:
Mark Payne 2023-07-10 11:02:21 -04:00 committed by exceptionfactory
parent a04cbe7f07
commit 96be7377b3
No known key found for this signature in database
GPG Key ID: 29B6A52D2AAE8DBA
1 changed files with 5 additions and 6 deletions

View File

@ -30,7 +30,6 @@ import org.apache.nifi.tests.system.NiFiInstanceFactory;
import org.apache.nifi.tests.system.NiFiSystemIT; import org.apache.nifi.tests.system.NiFiSystemIT;
import org.apache.nifi.toolkit.cli.impl.client.nifi.NiFiClientException; import org.apache.nifi.toolkit.cli.impl.client.nifi.NiFiClientException;
import org.apache.nifi.toolkit.cli.impl.client.nifi.ProcessorClient; import org.apache.nifi.toolkit.cli.impl.client.nifi.ProcessorClient;
import org.apache.nifi.toolkit.cli.impl.client.nifi.RequestConfig;
import org.apache.nifi.web.api.dto.ControllerServiceDTO; import org.apache.nifi.web.api.dto.ControllerServiceDTO;
import org.apache.nifi.web.api.dto.NodeDTO; import org.apache.nifi.web.api.dto.NodeDTO;
import org.apache.nifi.web.api.dto.PortDTO; import org.apache.nifi.web.api.dto.PortDTO;
@ -73,7 +72,6 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
public class FlowSynchronizationIT extends NiFiSystemIT { public class FlowSynchronizationIT extends NiFiSystemIT {
private static final Logger logger = LoggerFactory.getLogger(FlowSynchronizationIT.class); private static final Logger logger = LoggerFactory.getLogger(FlowSynchronizationIT.class);
private static final RequestConfig DO_NOT_REPLICATE = () -> Collections.singletonMap("X-Request-Replicated", "value");
private static final String RUNNING_STATE = "RUNNING"; private static final String RUNNING_STATE = "RUNNING";
private static final String ENABLED_STATE = "ENABLED"; private static final String ENABLED_STATE = "ENABLED";
private static final String SENSITIVE_VALUE_MASK = "********"; private static final String SENSITIVE_VALUE_MASK = "********";
@ -577,12 +575,13 @@ public class FlowSynchronizationIT extends NiFiSystemIT {
@Test @Test
public void testComponentsRecreatedOnRestart() throws NiFiClientException, IOException, InterruptedException { public void testComponentsRecreatedOnRestart() throws NiFiClientException, IOException, InterruptedException {
// Build dataflow with processors at root level and an inner group that contains an input port, output port, and a processor, as well as a Controller Service that the processor will use. // Build dataflow with processors at root level and an inner group that contains an input port, output port, and a processor, as well as a Controller Service that the processor will use.
final ProcessorEntity generate = getClientUtil().createProcessor("GenerateFlowFile"); final ProcessGroupEntity topLevelGroup = getClientUtil().createProcessGroup("testComponentsRecreatedOnRestart", "root");
final ProcessGroupEntity group = getClientUtil().createProcessGroup("Inner Group", "root"); final ProcessorEntity generate = getClientUtil().createProcessor("GenerateFlowFile", topLevelGroup.getId());
final ProcessGroupEntity group = getClientUtil().createProcessGroup("Inner Group", topLevelGroup.getId());
final PortEntity inPort = getClientUtil().createInputPort("In", group.getId()); final PortEntity inPort = getClientUtil().createInputPort("In", group.getId());
final PortEntity outPort = getClientUtil().createOutputPort("Out", group.getId()); final PortEntity outPort = getClientUtil().createOutputPort("Out", group.getId());
final ProcessorEntity count = getClientUtil().createProcessor("CountFlowFiles", group.getId()); final ProcessorEntity count = getClientUtil().createProcessor("CountFlowFiles", group.getId());
final ProcessorEntity terminate = getClientUtil().createProcessor("TerminateFlowFile"); final ProcessorEntity terminate = getClientUtil().createProcessor("TerminateFlowFile", topLevelGroup.getId());
getClientUtil().updateProcessorSchedulingPeriod(generate, "60 sec"); getClientUtil().updateProcessorSchedulingPeriod(generate, "60 sec");
final ControllerServiceEntity countService = getClientUtil().createControllerService("StandardCountService", group.getId()); final ControllerServiceEntity countService = getClientUtil().createControllerService("StandardCountService", group.getId());
@ -622,7 +621,7 @@ public class FlowSynchronizationIT extends NiFiSystemIT {
// is on Node 2. // is on Node 2.
switchClientToNode(2); switchClientToNode(2);
final ProcessGroupFlowEntity flow = getNifiClient().getFlowClient(DO_NOT_REPLICATE).getProcessGroup("root"); final ProcessGroupFlowEntity flow = getNifiClient().getFlowClient(DO_NOT_REPLICATE).getProcessGroup(topLevelGroup.getId());
final FlowDTO flowDto = flow.getProcessGroupFlow().getFlow(); final FlowDTO flowDto = flow.getProcessGroupFlow().getFlow();
assertEquals(2, flowDto.getConnections().size()); assertEquals(2, flowDto.getConnections().size());
assertEquals(2, flowDto.getProcessors().size()); assertEquals(2, flowDto.getProcessors().size());