Search in sources :

Example 1 with ConvertableSchema

use of org.apache.nifi.minifi.commons.schema.common.ConvertableSchema in project nifi-minifi by apache.

the class ConfigMainTest method testV1YmlIfPresent.

private void testV1YmlIfPresent(String name, Map<String, Object> yamlMap) throws IOException, SchemaLoaderException {
    InputStream upgradedInputStream = upgradeAndReturn(name + "-v1.yml");
    if (upgradedInputStream != null) {
        ConvertableSchema<ConfigSchema> configSchemaConvertableSchema = SchemaLoader.loadConvertableSchemaFromYaml(upgradedInputStream);
        ConfigSchema configSchemaUpgradedFromV1 = configSchemaConvertableSchema.convert();
        assertTrue(configSchemaUpgradedFromV1.isValid());
        assertEquals(configSchemaConvertableSchema, configSchemaUpgradedFromV1);
        ConfigSchema configSchemaFromCurrent = new ConfigSchema(yamlMap);
        List<ProcessorSchema> currentProcessors = configSchemaFromCurrent.getProcessGroupSchema().getProcessors();
        List<ProcessorSchema> v1Processors = configSchemaUpgradedFromV1.getProcessGroupSchema().getProcessors();
        assertEquals(currentProcessors.size(), v1Processors.size());
        // V1 doesn't have ids so we need to map the autogenerated ones to the ones from the template
        Map<String, String> v1IdToCurrentIdMap = new HashMap<>();
        for (int i = 0; i < currentProcessors.size(); i++) {
            ProcessorSchema currentProcessor = currentProcessors.get(i);
            ProcessorSchema v1Processor = v1Processors.get(i);
            assertEquals(currentProcessor.getName(), v1Processor.getName());
            v1IdToCurrentIdMap.put(v1Processor.getId(), currentProcessor.getId());
            v1Processor.setId(currentProcessor.getId());
        }
        List<RemoteProcessGroupSchema> currentRPGs = configSchemaFromCurrent.getProcessGroupSchema().getRemoteProcessGroups();
        List<RemoteProcessGroupSchema> v1RPGs = configSchemaUpgradedFromV1.getProcessGroupSchema().getRemoteProcessGroups();
        // V1 doesn't have ids so we need to map the autogenerated ones to the ones from the template
        for (int i = 0; i < currentRPGs.size(); i++) {
            RemoteProcessGroupSchema currentRPG = currentRPGs.get(i);
            RemoteProcessGroupSchema v1RPG = v1RPGs.get(i);
            assertEquals(currentRPG.getName(), v1RPG.getName());
            v1IdToCurrentIdMap.put(v1RPG.getId(), currentRPG.getId());
            v1RPG.setId(currentRPG.getId());
        }
        configSchemaUpgradedFromV1.getProcessGroupSchema().getRemoteProcessGroups().stream().flatMap(g -> g.getInputPorts().stream()).map(RemotePortSchema::getId).sequential().forEach(id -> v1IdToCurrentIdMap.put(id, id));
        List<ConnectionSchema> currentConnections = configSchemaFromCurrent.getProcessGroupSchema().getConnections();
        List<ConnectionSchema> v1Connections = configSchemaUpgradedFromV1.getProcessGroupSchema().getConnections();
        // Update source and dest ids, can set connection id equal because it isn't referenced elsewhere
        assertEquals(currentConnections.size(), v1Connections.size());
        for (int i = 0; i < currentConnections.size(); i++) {
            ConnectionSchema currentConnection = currentConnections.get(i);
            ConnectionSchema v1Connection = v1Connections.get(i);
            assertEquals(currentConnection.getName(), v1Connection.getName());
            v1Connection.setId(currentConnection.getId());
            v1Connection.setSourceId(v1IdToCurrentIdMap.get(v1Connection.getSourceId()));
            v1Connection.setDestinationId(v1IdToCurrentIdMap.get(v1Connection.getDestinationId()));
        }
        ConfigSchema.getAllProcessGroups(configSchemaFromCurrent.getProcessGroupSchema()).stream().flatMap(p -> p.getRemoteProcessGroups().stream()).forEach(r -> {
            clearV3orLaterProperties(r);
            r.setTransportProtocol(RemoteProcessGroupSchema.TransportProtocolOptions.RAW.name());
        });
        Map<String, Object> v1YamlMap = configSchemaUpgradedFromV1.toMap();
        assertNoMapDifferences(v1YamlMap, configSchemaFromCurrent.toMap());
    }
}
Also used : RemotePortSchema(org.apache.nifi.minifi.commons.schema.RemotePortSchema) RemoteProcessGroupSchema(org.apache.nifi.minifi.commons.schema.RemoteProcessGroupSchema) ByteArrayOutputStream(java.io.ByteArrayOutputStream) SchemaLoader(org.apache.nifi.minifi.commons.schema.serialization.SchemaLoader) Mock(org.mockito.Mock) ProcessorSchema(org.apache.nifi.minifi.commons.schema.ProcessorSchema) RunWith(org.junit.runner.RunWith) HashMap(java.util.HashMap) ArrayList(java.util.ArrayList) HashSet(java.util.HashSet) ByteArrayInputStream(java.io.ByteArrayInputStream) Map(java.util.Map) Assert.fail(org.junit.Assert.fail) LimitedInputStream(org.apache.nifi.controller.repository.io.LimitedInputStream) Before(org.junit.Before) Charsets(org.apache.commons.io.Charsets) OutputStream(java.io.OutputStream) ConvertableSchema(org.apache.nifi.minifi.commons.schema.common.ConvertableSchema) Set(java.util.Set) Assert.assertTrue(org.junit.Assert.assertTrue) ConfigSchema(org.apache.nifi.minifi.commons.schema.ConfigSchema) Test(org.junit.Test) IOException(java.io.IOException) Mockito.when(org.mockito.Mockito.when) JAXBException(javax.xml.bind.JAXBException) FileNotFoundException(java.io.FileNotFoundException) List(java.util.List) MockitoJUnitRunner(org.mockito.runners.MockitoJUnitRunner) SchemaLoaderException(org.apache.nifi.minifi.commons.schema.exception.SchemaLoaderException) ConnectionSchema(org.apache.nifi.minifi.commons.schema.ConnectionSchema) SUCCESS(org.apache.nifi.minifi.toolkit.configuration.ConfigMain.SUCCESS) Assert.assertEquals(org.junit.Assert.assertEquals) InputStream(java.io.InputStream) ConnectionSchema(org.apache.nifi.minifi.commons.schema.ConnectionSchema) HashMap(java.util.HashMap) ByteArrayInputStream(java.io.ByteArrayInputStream) LimitedInputStream(org.apache.nifi.controller.repository.io.LimitedInputStream) InputStream(java.io.InputStream) RemotePortSchema(org.apache.nifi.minifi.commons.schema.RemotePortSchema) ProcessorSchema(org.apache.nifi.minifi.commons.schema.ProcessorSchema) RemoteProcessGroupSchema(org.apache.nifi.minifi.commons.schema.RemoteProcessGroupSchema) ConfigSchema(org.apache.nifi.minifi.commons.schema.ConfigSchema)

Example 2 with ConvertableSchema

use of org.apache.nifi.minifi.commons.schema.common.ConvertableSchema in project nifi-minifi by apache.

the class ConfigMainTest method testV2YmlIfPresent.

private void testV2YmlIfPresent(String name, Map<String, Object> yamlMap) throws IOException, SchemaLoaderException {
    InputStream upgradedInputStream = upgradeAndReturn(name + "-v2.yml");
    if (upgradedInputStream != null) {
        ConvertableSchema<ConfigSchema> configSchemaConvertableSchema = SchemaLoader.loadConvertableSchemaFromYaml(upgradedInputStream);
        ConfigSchema configSchemaUpgradedFromV2 = configSchemaConvertableSchema.convert();
        ConfigSchema configSchemaFromCurrent = new ConfigSchema(yamlMap);
        ConfigSchema.getAllProcessGroups(configSchemaFromCurrent.getProcessGroupSchema()).stream().flatMap(p -> p.getRemoteProcessGroups().stream()).forEach(r -> {
            clearV3orLaterProperties(r);
        });
        assertNoMapDifferences(configSchemaUpgradedFromV2.toMap(), configSchemaFromCurrent.toMap());
    }
}
Also used : RemotePortSchema(org.apache.nifi.minifi.commons.schema.RemotePortSchema) RemoteProcessGroupSchema(org.apache.nifi.minifi.commons.schema.RemoteProcessGroupSchema) ByteArrayOutputStream(java.io.ByteArrayOutputStream) SchemaLoader(org.apache.nifi.minifi.commons.schema.serialization.SchemaLoader) Mock(org.mockito.Mock) ProcessorSchema(org.apache.nifi.minifi.commons.schema.ProcessorSchema) RunWith(org.junit.runner.RunWith) HashMap(java.util.HashMap) ArrayList(java.util.ArrayList) HashSet(java.util.HashSet) ByteArrayInputStream(java.io.ByteArrayInputStream) Map(java.util.Map) Assert.fail(org.junit.Assert.fail) LimitedInputStream(org.apache.nifi.controller.repository.io.LimitedInputStream) Before(org.junit.Before) Charsets(org.apache.commons.io.Charsets) OutputStream(java.io.OutputStream) ConvertableSchema(org.apache.nifi.minifi.commons.schema.common.ConvertableSchema) Set(java.util.Set) Assert.assertTrue(org.junit.Assert.assertTrue) ConfigSchema(org.apache.nifi.minifi.commons.schema.ConfigSchema) Test(org.junit.Test) IOException(java.io.IOException) Mockito.when(org.mockito.Mockito.when) JAXBException(javax.xml.bind.JAXBException) FileNotFoundException(java.io.FileNotFoundException) List(java.util.List) MockitoJUnitRunner(org.mockito.runners.MockitoJUnitRunner) SchemaLoaderException(org.apache.nifi.minifi.commons.schema.exception.SchemaLoaderException) ConnectionSchema(org.apache.nifi.minifi.commons.schema.ConnectionSchema) SUCCESS(org.apache.nifi.minifi.toolkit.configuration.ConfigMain.SUCCESS) Assert.assertEquals(org.junit.Assert.assertEquals) InputStream(java.io.InputStream) ByteArrayInputStream(java.io.ByteArrayInputStream) LimitedInputStream(org.apache.nifi.controller.repository.io.LimitedInputStream) InputStream(java.io.InputStream) ConfigSchema(org.apache.nifi.minifi.commons.schema.ConfigSchema)

Aggregations

ByteArrayInputStream (java.io.ByteArrayInputStream)2 ByteArrayOutputStream (java.io.ByteArrayOutputStream)2 FileNotFoundException (java.io.FileNotFoundException)2 IOException (java.io.IOException)2 InputStream (java.io.InputStream)2 OutputStream (java.io.OutputStream)2 ArrayList (java.util.ArrayList)2 HashMap (java.util.HashMap)2 HashSet (java.util.HashSet)2 List (java.util.List)2 Map (java.util.Map)2 Set (java.util.Set)2 JAXBException (javax.xml.bind.JAXBException)2 Charsets (org.apache.commons.io.Charsets)2 LimitedInputStream (org.apache.nifi.controller.repository.io.LimitedInputStream)2 ConfigSchema (org.apache.nifi.minifi.commons.schema.ConfigSchema)2 ConnectionSchema (org.apache.nifi.minifi.commons.schema.ConnectionSchema)2 ProcessorSchema (org.apache.nifi.minifi.commons.schema.ProcessorSchema)2 RemotePortSchema (org.apache.nifi.minifi.commons.schema.RemotePortSchema)2 RemoteProcessGroupSchema (org.apache.nifi.minifi.commons.schema.RemoteProcessGroupSchema)2