mirror of https://github.com/apache/nifi.git
NIFI-12575 Updated nifi-asana-bundle using current API methods
This closes #8212 Signed-off-by: David Handermann <exceptionfactory@apache.org>
This commit is contained in:
parent
726a930b01
commit
62d444ffc8
|
@ -16,14 +16,13 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.processors.asana;
|
package org.apache.nifi.processors.asana;
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
import org.apache.nifi.components.DescribedValue;
|
import org.apache.nifi.components.DescribedValue;
|
||||||
|
|
||||||
public enum AsanaObjectType implements DescribedValue {
|
public enum AsanaObjectType implements DescribedValue {
|
||||||
AV_COLLECT_TASKS(
|
AV_COLLECT_TASKS(
|
||||||
"asana-collect-tasks",
|
"asana-collect-tasks",
|
||||||
"Tasks", ""
|
"Tasks",
|
||||||
+ "Collect tasks matching to the specified conditions."
|
"Collect tasks matching to the specified conditions."
|
||||||
),
|
),
|
||||||
AV_COLLECT_TASK_ATTACHMENTS(
|
AV_COLLECT_TASK_ATTACHMENTS(
|
||||||
"asana-collect-task-attachments",
|
"asana-collect-task-attachments",
|
||||||
|
@ -105,11 +104,4 @@ public enum AsanaObjectType implements DescribedValue {
|
||||||
public String getDescription() {
|
public String getDescription() {
|
||||||
return description;
|
return description;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static AsanaObjectType fromValue(String value) {
|
|
||||||
return Arrays.stream(AsanaObjectType.values())
|
|
||||||
.filter(asanaObjectType -> asanaObjectType.getValue().equals(value))
|
|
||||||
.findFirst()
|
|
||||||
.orElse(null);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,33 +16,6 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.processors.asana;
|
package org.apache.nifi.processors.asana;
|
||||||
|
|
||||||
import static java.lang.String.format;
|
|
||||||
import static java.lang.String.join;
|
|
||||||
import static java.util.Collections.singletonMap;
|
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_EVENTS;
|
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_MEMBERS;
|
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_STATUS_ATTACHMENTS;
|
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_STATUS_UPDATES;
|
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_STORIES;
|
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_TASKS;
|
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_TASK_ATTACHMENTS;
|
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_TEAM_MEMBERS;
|
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.UncheckedIOException;
|
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Map.Entry;
|
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.Set;
|
|
||||||
import org.apache.http.entity.ContentType;
|
import org.apache.http.entity.ContentType;
|
||||||
import org.apache.nifi.annotation.behavior.InputRequirement;
|
import org.apache.nifi.annotation.behavior.InputRequirement;
|
||||||
import org.apache.nifi.annotation.behavior.PrimaryNodeOnly;
|
import org.apache.nifi.annotation.behavior.PrimaryNodeOnly;
|
||||||
|
@ -83,6 +56,32 @@ import org.apache.nifi.processors.asana.utils.AsanaTeamMemberFetcher;
|
||||||
import org.apache.nifi.processors.asana.utils.AsanaUserFetcher;
|
import org.apache.nifi.processors.asana.utils.AsanaUserFetcher;
|
||||||
import org.apache.nifi.reporting.InitializationException;
|
import org.apache.nifi.reporting.InitializationException;
|
||||||
|
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.UncheckedIOException;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import static java.lang.String.format;
|
||||||
|
import static java.lang.String.join;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_EVENTS;
|
||||||
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_MEMBERS;
|
||||||
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_STATUS_ATTACHMENTS;
|
||||||
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_STATUS_UPDATES;
|
||||||
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_STORIES;
|
||||||
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_TASKS;
|
||||||
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_TASK_ATTACHMENTS;
|
||||||
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_TEAM_MEMBERS;
|
||||||
|
|
||||||
@TriggerSerially
|
@TriggerSerially
|
||||||
@PrimaryNodeOnly
|
@PrimaryNodeOnly
|
||||||
@InputRequirement(InputRequirement.Requirement.INPUT_FORBIDDEN)
|
@InputRequirement(InputRequirement.Requirement.INPUT_FORBIDDEN)
|
||||||
|
@ -128,7 +127,7 @@ public class GetAsanaObject extends AbstractProcessor {
|
||||||
.description("Specify what kind of objects to be collected from Asana")
|
.description("Specify what kind of objects to be collected from Asana")
|
||||||
.required(true)
|
.required(true)
|
||||||
.allowableValues(AsanaObjectType.class)
|
.allowableValues(AsanaObjectType.class)
|
||||||
.defaultValue(AV_COLLECT_TASKS.getValue())
|
.defaultValue(AV_COLLECT_TASKS)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
protected static final PropertyDescriptor PROP_ASANA_PROJECT = new PropertyDescriptor.Builder()
|
protected static final PropertyDescriptor PROP_ASANA_PROJECT = new PropertyDescriptor.Builder()
|
||||||
|
@ -191,7 +190,7 @@ public class GetAsanaObject extends AbstractProcessor {
|
||||||
.addValidator(StandardValidators.POSITIVE_INTEGER_VALIDATOR)
|
.addValidator(StandardValidators.POSITIVE_INTEGER_VALIDATOR)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
protected static final List<PropertyDescriptor> DESCRIPTORS = Collections.unmodifiableList(Arrays.asList(
|
protected static final List<PropertyDescriptor> DESCRIPTORS = List.of(
|
||||||
PROP_ASANA_CLIENT_SERVICE,
|
PROP_ASANA_CLIENT_SERVICE,
|
||||||
PROP_DISTRIBUTED_CACHE_SERVICE,
|
PROP_DISTRIBUTED_CACHE_SERVICE,
|
||||||
PROP_ASANA_OBJECT_TYPE,
|
PROP_ASANA_OBJECT_TYPE,
|
||||||
|
@ -200,7 +199,7 @@ public class GetAsanaObject extends AbstractProcessor {
|
||||||
PROP_ASANA_TEAM_NAME,
|
PROP_ASANA_TEAM_NAME,
|
||||||
PROP_ASANA_TAG,
|
PROP_ASANA_TAG,
|
||||||
PROP_ASANA_OUTPUT_BATCH_SIZE
|
PROP_ASANA_OUTPUT_BATCH_SIZE
|
||||||
));
|
);
|
||||||
|
|
||||||
protected static final Relationship REL_NEW = new Relationship.Builder()
|
protected static final Relationship REL_NEW = new Relationship.Builder()
|
||||||
.name(REL_NAME_NEW)
|
.name(REL_NAME_NEW)
|
||||||
|
@ -219,11 +218,11 @@ public class GetAsanaObject extends AbstractProcessor {
|
||||||
+ "are carried by the asana.gid attribute of the generated FlowFiles.")
|
+ "are carried by the asana.gid attribute of the generated FlowFiles.")
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
protected static final Set<Relationship> RELATIONSHIPS = Collections.unmodifiableSet(new HashSet<>(Arrays.asList(
|
protected static final Set<Relationship> RELATIONSHIPS = Set.of(
|
||||||
REL_NEW,
|
REL_NEW,
|
||||||
REL_UPDATED,
|
REL_UPDATED,
|
||||||
REL_REMOVED
|
REL_REMOVED
|
||||||
)));
|
);
|
||||||
protected static final GenericObjectSerDe<String> STATE_MAP_KEY_SERIALIZER = new GenericObjectSerDe<>();
|
protected static final GenericObjectSerDe<String> STATE_MAP_KEY_SERIALIZER = new GenericObjectSerDe<>();
|
||||||
protected static final GenericObjectSerDe<Map<String, String>> STATE_MAP_VALUE_SERIALIZER = new GenericObjectSerDe<>();
|
protected static final GenericObjectSerDe<Map<String, String>> STATE_MAP_VALUE_SERIALIZER = new GenericObjectSerDe<>();
|
||||||
|
|
||||||
|
@ -342,40 +341,26 @@ public class GetAsanaObject extends AbstractProcessor {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected AsanaObjectFetcher createObjectFetcher(final ProcessContext context, AsanaClient client) {
|
protected AsanaObjectFetcher createObjectFetcher(final ProcessContext context, AsanaClient client) {
|
||||||
final String objectType = context.getProperty(PROP_ASANA_OBJECT_TYPE).getValue();
|
final AsanaObjectType objectType = context.getProperty(PROP_ASANA_OBJECT_TYPE).asDescribedValue(AsanaObjectType.class);
|
||||||
final String projectName = context.getProperty(PROP_ASANA_PROJECT).getValue();
|
final String projectName = context.getProperty(PROP_ASANA_PROJECT).getValue();
|
||||||
final String sectionName = context.getProperty(PROP_ASANA_SECTION).getValue();
|
final String sectionName = context.getProperty(PROP_ASANA_SECTION).getValue();
|
||||||
final String teamName = context.getProperty(PROP_ASANA_TEAM_NAME).getValue();
|
final String teamName = context.getProperty(PROP_ASANA_TEAM_NAME).getValue();
|
||||||
final String tagName = context.getProperty(PROP_ASANA_TAG).getValue();
|
final String tagName = context.getProperty(PROP_ASANA_TAG).getValue();
|
||||||
|
|
||||||
switch (AsanaObjectType.fromValue(objectType)) {
|
return switch (objectType) {
|
||||||
case AV_COLLECT_TASKS:
|
case AV_COLLECT_TASKS -> new AsanaTaskFetcher(client, projectName, sectionName, tagName);
|
||||||
return new AsanaTaskFetcher(client, projectName, sectionName, tagName);
|
case AV_COLLECT_PROJECTS -> new AsanaProjectFetcher(client);
|
||||||
case AV_COLLECT_PROJECTS:
|
case AV_COLLECT_PROJECT_EVENTS -> new AsanaProjectEventFetcher(client, projectName);
|
||||||
return new AsanaProjectFetcher(client);
|
case AV_COLLECT_PROJECT_MEMBERS -> new AsanaProjectMembershipFetcher(client, projectName);
|
||||||
case AV_COLLECT_PROJECT_EVENTS:
|
case AV_COLLECT_PROJECT_STATUS_ATTACHMENTS -> new AsanaProjectStatusAttachmentFetcher(client, projectName);
|
||||||
return new AsanaProjectEventFetcher(client, projectName);
|
case AV_COLLECT_PROJECT_STATUS_UPDATES -> new AsanaProjectStatusFetcher(client, projectName);
|
||||||
case AV_COLLECT_PROJECT_MEMBERS:
|
case AV_COLLECT_STORIES -> new AsanaStoryFetcher(client, projectName, sectionName, tagName);
|
||||||
return new AsanaProjectMembershipFetcher(client, projectName);
|
case AV_COLLECT_TAGS -> new AsanaTagFetcher(client);
|
||||||
case AV_COLLECT_PROJECT_STATUS_ATTACHMENTS:
|
case AV_COLLECT_TASK_ATTACHMENTS -> new AsanaTaskAttachmentFetcher(client, projectName, sectionName, tagName);
|
||||||
return new AsanaProjectStatusAttachmentFetcher(client, projectName);
|
case AV_COLLECT_TEAMS -> new AsanaTeamFetcher(client);
|
||||||
case AV_COLLECT_PROJECT_STATUS_UPDATES:
|
case AV_COLLECT_TEAM_MEMBERS -> new AsanaTeamMemberFetcher(client, teamName);
|
||||||
return new AsanaProjectStatusFetcher(client, projectName);
|
case AV_COLLECT_USERS -> new AsanaUserFetcher(client);
|
||||||
case AV_COLLECT_STORIES:
|
};
|
||||||
return new AsanaStoryFetcher(client, projectName, sectionName, tagName);
|
|
||||||
case AV_COLLECT_TAGS:
|
|
||||||
return new AsanaTagFetcher(client);
|
|
||||||
case AV_COLLECT_TASK_ATTACHMENTS:
|
|
||||||
return new AsanaTaskAttachmentFetcher(client, projectName, sectionName, tagName);
|
|
||||||
case AV_COLLECT_TEAMS:
|
|
||||||
return new AsanaTeamFetcher(client);
|
|
||||||
case AV_COLLECT_TEAM_MEMBERS:
|
|
||||||
return new AsanaTeamMemberFetcher(client, teamName);
|
|
||||||
case AV_COLLECT_USERS:
|
|
||||||
return new AsanaUserFetcher(client);
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new ProcessException("Cannot fetch objects of type: " + objectType);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private Optional<Map<String, String>> recoverState(final ProcessContext context) {
|
private Optional<Map<String, String>> recoverState(final ProcessContext context) {
|
||||||
|
|
|
@ -59,8 +59,7 @@ public class AsanaObject {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean equals(Object o) {
|
public boolean equals(Object o) {
|
||||||
if (o instanceof AsanaObject) {
|
if (o instanceof AsanaObject other) {
|
||||||
AsanaObject other = (AsanaObject) o;
|
|
||||||
return state.equals(other.state)
|
return state.equals(other.state)
|
||||||
&& Optional.ofNullable(gid).equals(Optional.ofNullable(other.gid))
|
&& Optional.ofNullable(gid).equals(Optional.ofNullable(other.gid))
|
||||||
&& Optional.ofNullable(content).equals(Optional.ofNullable(other.content))
|
&& Optional.ofNullable(content).equals(Optional.ofNullable(other.content))
|
||||||
|
|
|
@ -16,11 +16,11 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.processors.asana.utils;
|
package org.apache.nifi.processors.asana.utils;
|
||||||
|
|
||||||
import static java.util.Collections.emptySet;
|
|
||||||
|
|
||||||
import com.asana.Json;
|
import com.asana.Json;
|
||||||
import com.asana.models.Resource;
|
import com.asana.models.Resource;
|
||||||
import com.google.gson.reflect.TypeToken;
|
import com.google.gson.reflect.TypeToken;
|
||||||
|
import org.apache.commons.collections4.iterators.FilterIterator;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -40,7 +40,8 @@ import java.util.Set;
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
import java.util.zip.GZIPInputStream;
|
import java.util.zip.GZIPInputStream;
|
||||||
import java.util.zip.GZIPOutputStream;
|
import java.util.zip.GZIPOutputStream;
|
||||||
import org.apache.commons.collections4.iterators.FilterIterator;
|
|
||||||
|
import static java.util.Collections.emptySet;
|
||||||
|
|
||||||
public abstract class GenericAsanaObjectFetcher<T extends Resource> extends AbstractAsanaObjectFetcher {
|
public abstract class GenericAsanaObjectFetcher<T extends Resource> extends AbstractAsanaObjectFetcher {
|
||||||
private static final String LAST_FINGERPRINTS = ".lastFingerprints";
|
private static final String LAST_FINGERPRINTS = ".lastFingerprints";
|
||||||
|
@ -163,7 +164,7 @@ public abstract class GenericAsanaObjectFetcher<T extends Resource> extends Abst
|
||||||
uncompressedBytes.write(buffer, 0, n);
|
uncompressedBytes.write(buffer, 0, n);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new String(uncompressedBytes.toByteArray(), StandardCharsets.UTF_8);
|
return uncompressedBytes.toString(StandardCharsets.UTF_8);
|
||||||
}
|
}
|
||||||
|
|
||||||
private String calculateSecureHash(String input) {
|
private String calculateSecureHash(String input) {
|
||||||
|
|
|
@ -16,6 +16,26 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.processors.asana;
|
package org.apache.nifi.processors.asana;
|
||||||
|
|
||||||
|
import com.asana.models.Project;
|
||||||
|
import com.asana.models.ProjectStatus;
|
||||||
|
import com.asana.models.Tag;
|
||||||
|
import com.asana.models.Task;
|
||||||
|
import com.asana.models.Team;
|
||||||
|
import com.asana.models.User;
|
||||||
|
import com.google.api.client.util.DateTime;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.apache.nifi.controller.asana.AsanaClientProviderService;
|
||||||
|
import org.apache.nifi.controller.asana.AsanaEventsCollection;
|
||||||
|
import org.apache.nifi.distributed.cache.client.DistributedMapCacheClient;
|
||||||
|
import org.apache.nifi.processors.asana.mocks.MockAsanaClientProviderService;
|
||||||
|
import org.apache.nifi.processors.asana.mocks.MockDistributedMapCacheClient;
|
||||||
|
import org.apache.nifi.reporting.InitializationException;
|
||||||
|
import org.apache.nifi.util.TestRunner;
|
||||||
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
import static java.util.Collections.emptyList;
|
import static java.util.Collections.emptyList;
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECTS;
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECTS;
|
||||||
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_EVENTS;
|
import static org.apache.nifi.processors.asana.AsanaObjectType.AV_COLLECT_PROJECT_EVENTS;
|
||||||
|
@ -43,25 +63,6 @@ import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.verifyNoMoreInteractions;
|
import static org.mockito.Mockito.verifyNoMoreInteractions;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import com.asana.models.Project;
|
|
||||||
import com.asana.models.ProjectStatus;
|
|
||||||
import com.asana.models.Tag;
|
|
||||||
import com.asana.models.Task;
|
|
||||||
import com.asana.models.Team;
|
|
||||||
import com.asana.models.User;
|
|
||||||
import com.google.api.client.util.DateTime;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
|
||||||
import org.apache.nifi.controller.asana.AsanaClientProviderService;
|
|
||||||
import org.apache.nifi.controller.asana.AsanaEventsCollection;
|
|
||||||
import org.apache.nifi.distributed.cache.client.DistributedMapCacheClient;
|
|
||||||
import org.apache.nifi.processors.asana.mocks.MockAsanaClientProviderService;
|
|
||||||
import org.apache.nifi.processors.asana.mocks.MockDistributedMapCacheClient;
|
|
||||||
import org.apache.nifi.reporting.InitializationException;
|
|
||||||
import org.apache.nifi.util.TestRunner;
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
|
|
||||||
public class GetAsanaObjectConfigurationTest {
|
public class GetAsanaObjectConfigurationTest {
|
||||||
|
|
||||||
private TestRunner runner;
|
private TestRunner runner;
|
||||||
|
@ -77,14 +78,14 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNotValidWithoutControllerService() {
|
public void testNotValidWithoutControllerService() {
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNotValidWithoutDistributedMapCacheClient() throws InitializationException {
|
public void testNotValidWithoutDistributedMapCacheClient() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -92,7 +93,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testBatchSizeMustBePositiveInteger() throws InitializationException {
|
public void testBatchSizeMustBePositiveInteger() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OUTPUT_BATCH_SIZE, StringUtils.EMPTY);
|
runner.setProperty(PROP_ASANA_OUTPUT_BATCH_SIZE, StringUtils.EMPTY);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
|
@ -114,14 +115,14 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testValidConfigurations() throws InitializationException {
|
public void testValidConfigurations() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
runner.assertValid();
|
runner.assertValid();
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASKS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASKS);
|
||||||
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
||||||
runner.assertValid();
|
runner.assertValid();
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TEAM_MEMBERS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TEAM_MEMBERS);
|
||||||
runner.setProperty(PROP_ASANA_TEAM_NAME, "A team");
|
runner.setProperty(PROP_ASANA_TEAM_NAME, "A team");
|
||||||
runner.assertValid();
|
runner.assertValid();
|
||||||
}
|
}
|
||||||
|
@ -130,25 +131,25 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testConfigurationInvalidWithoutProjectName() throws InitializationException {
|
public void testConfigurationInvalidWithoutProjectName() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASKS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASKS);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_MEMBERS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_MEMBERS);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_STORIES.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_STORIES);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_EVENTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_EVENTS);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_STATUS_ATTACHMENTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_STATUS_ATTACHMENTS);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_STATUS_UPDATES.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_STATUS_UPDATES);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
|
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASK_ATTACHMENTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASK_ATTACHMENTS);
|
||||||
runner.assertNotValid();
|
runner.assertNotValid();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -156,14 +157,14 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testConfigurationInvalidWithoutTeamName() throws InitializationException {
|
public void testConfigurationInvalidWithoutTeamName() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TEAM_MEMBERS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TEAM_MEMBERS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCollectProjects() throws InitializationException {
|
public void testCollectProjects() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
final Project project = new Project();
|
final Project project = new Project();
|
||||||
project.gid = "12345";
|
project.gid = "12345";
|
||||||
|
@ -182,7 +183,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectTeams() throws InitializationException {
|
public void testCollectTeams() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TEAMS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TEAMS);
|
||||||
|
|
||||||
final Team team = new Team();
|
final Team team = new Team();
|
||||||
team.gid = "12345";
|
team.gid = "12345";
|
||||||
|
@ -200,7 +201,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectTeamMembers() throws InitializationException {
|
public void testCollectTeamMembers() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TEAM_MEMBERS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TEAM_MEMBERS);
|
||||||
runner.setProperty(PROP_ASANA_TEAM_NAME, "A team");
|
runner.setProperty(PROP_ASANA_TEAM_NAME, "A team");
|
||||||
|
|
||||||
final Team team = new Team();
|
final Team team = new Team();
|
||||||
|
@ -221,7 +222,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectUsers() throws InitializationException {
|
public void testCollectUsers() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_USERS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_USERS);
|
||||||
|
|
||||||
final User user = new User();
|
final User user = new User();
|
||||||
user.gid = "12345";
|
user.gid = "12345";
|
||||||
|
@ -239,7 +240,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectTags() throws InitializationException {
|
public void testCollectTags() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TAGS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TAGS);
|
||||||
|
|
||||||
final Tag tag = new Tag();
|
final Tag tag = new Tag();
|
||||||
tag.gid = "12345";
|
tag.gid = "12345";
|
||||||
|
@ -257,7 +258,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectProjectEvents() throws InitializationException {
|
public void testCollectProjectEvents() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_EVENTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_EVENTS);
|
||||||
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
||||||
|
|
||||||
final Project project = new Project();
|
final Project project = new Project();
|
||||||
|
@ -281,7 +282,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectProjectMembers() throws InitializationException {
|
public void testCollectProjectMembers() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_MEMBERS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_MEMBERS);
|
||||||
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
||||||
|
|
||||||
final Project project = new Project();
|
final Project project = new Project();
|
||||||
|
@ -303,7 +304,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectProjectStatusUpdates() throws InitializationException {
|
public void testCollectProjectStatusUpdates() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_STATUS_UPDATES.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_STATUS_UPDATES);
|
||||||
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
||||||
|
|
||||||
final Project project = new Project();
|
final Project project = new Project();
|
||||||
|
@ -325,7 +326,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectProjectStatusAttachments() throws InitializationException {
|
public void testCollectProjectStatusAttachments() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_STATUS_ATTACHMENTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECT_STATUS_ATTACHMENTS);
|
||||||
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
||||||
|
|
||||||
final Project project = new Project();
|
final Project project = new Project();
|
||||||
|
@ -352,7 +353,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectTasks() throws InitializationException {
|
public void testCollectTasks() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASKS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASKS);
|
||||||
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
||||||
|
|
||||||
final Project project = new Project();
|
final Project project = new Project();
|
||||||
|
@ -378,7 +379,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectTaskAttachments() throws InitializationException {
|
public void testCollectTaskAttachments() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASK_ATTACHMENTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_TASK_ATTACHMENTS);
|
||||||
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
||||||
|
|
||||||
final Project project = new Project();
|
final Project project = new Project();
|
||||||
|
@ -406,7 +407,7 @@ public class GetAsanaObjectConfigurationTest {
|
||||||
public void testCollectStories() throws InitializationException {
|
public void testCollectStories() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_STORIES.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_STORIES);
|
||||||
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
runner.setProperty(PROP_ASANA_PROJECT, "My Project");
|
||||||
|
|
||||||
final Project project = new Project();
|
final Project project = new Project();
|
||||||
|
|
|
@ -16,6 +16,27 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.processors.asana;
|
package org.apache.nifi.processors.asana;
|
||||||
|
|
||||||
|
import com.google.gson.Gson;
|
||||||
|
import org.apache.nifi.controller.asana.AsanaClientProviderService;
|
||||||
|
import org.apache.nifi.distributed.cache.client.DistributedMapCacheClient;
|
||||||
|
import org.apache.nifi.processors.asana.mocks.MockAsanaClientProviderService;
|
||||||
|
import org.apache.nifi.processors.asana.mocks.MockDistributedMapCacheClient;
|
||||||
|
import org.apache.nifi.processors.asana.mocks.MockGetAsanaObject;
|
||||||
|
import org.apache.nifi.processors.asana.utils.AsanaObject;
|
||||||
|
import org.apache.nifi.processors.asana.utils.AsanaObjectFetcher;
|
||||||
|
import org.apache.nifi.processors.asana.utils.AsanaObjectFetcherException;
|
||||||
|
import org.apache.nifi.processors.asana.utils.AsanaObjectState;
|
||||||
|
import org.apache.nifi.reporting.InitializationException;
|
||||||
|
import org.apache.nifi.util.MockFlowFile;
|
||||||
|
import org.apache.nifi.util.MockProcessContext;
|
||||||
|
import org.apache.nifi.util.TestRunner;
|
||||||
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import static java.util.Arrays.asList;
|
import static java.util.Arrays.asList;
|
||||||
import static java.util.Collections.emptyMap;
|
import static java.util.Collections.emptyMap;
|
||||||
import static java.util.Collections.singletonList;
|
import static java.util.Collections.singletonList;
|
||||||
|
@ -38,27 +59,6 @@ import static org.mockito.Mockito.times;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import com.google.gson.Gson;
|
|
||||||
|
|
||||||
import java.util.LinkedHashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import org.apache.nifi.controller.asana.AsanaClientProviderService;
|
|
||||||
import org.apache.nifi.distributed.cache.client.DistributedMapCacheClient;
|
|
||||||
import org.apache.nifi.processors.asana.mocks.MockAsanaClientProviderService;
|
|
||||||
import org.apache.nifi.processors.asana.mocks.MockDistributedMapCacheClient;
|
|
||||||
import org.apache.nifi.processors.asana.mocks.MockGetAsanaObject;
|
|
||||||
import org.apache.nifi.processors.asana.utils.AsanaObject;
|
|
||||||
import org.apache.nifi.processors.asana.utils.AsanaObjectFetcher;
|
|
||||||
import org.apache.nifi.processors.asana.utils.AsanaObjectFetcherException;
|
|
||||||
import org.apache.nifi.processors.asana.utils.AsanaObjectState;
|
|
||||||
import org.apache.nifi.reporting.InitializationException;
|
|
||||||
import org.apache.nifi.util.MockFlowFile;
|
|
||||||
import org.apache.nifi.util.MockProcessContext;
|
|
||||||
import org.apache.nifi.util.TestRunner;
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
|
|
||||||
public class GetAsanaObjectLifecycleTest {
|
public class GetAsanaObjectLifecycleTest {
|
||||||
|
|
||||||
private static final Gson GSON = new Gson();
|
private static final Gson GSON = new Gson();
|
||||||
|
@ -79,7 +79,7 @@ public class GetAsanaObjectLifecycleTest {
|
||||||
public void testYieldIsCalledWhenNoAsanaObjectsFetched() throws InitializationException {
|
public void testYieldIsCalledWhenNoAsanaObjectsFetched() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
when(mockObjectFetcher.fetchNext()).thenReturn(null);
|
when(mockObjectFetcher.fetchNext()).thenReturn(null);
|
||||||
|
|
||||||
|
@ -98,7 +98,7 @@ public class GetAsanaObjectLifecycleTest {
|
||||||
public void testCollectObjectsFromAsanaThenYield() throws InitializationException {
|
public void testCollectObjectsFromAsanaThenYield() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
when(mockObjectFetcher.fetchNext())
|
when(mockObjectFetcher.fetchNext())
|
||||||
.thenReturn(new AsanaObject(AsanaObjectState.NEW, "1", "Lorem ipsum"))
|
.thenReturn(new AsanaObject(AsanaObjectState.NEW, "1", "Lorem ipsum"))
|
||||||
|
@ -139,19 +139,19 @@ public class GetAsanaObjectLifecycleTest {
|
||||||
|
|
||||||
final List<MockFlowFile> updatedFlowFiles = runner.getFlowFilesForRelationship(REL_UPDATED);
|
final List<MockFlowFile> updatedFlowFiles = runner.getFlowFilesForRelationship(REL_UPDATED);
|
||||||
|
|
||||||
updatedFlowFiles.get(0).assertAttributeEquals(ASANA_GID, "1");
|
updatedFlowFiles.getFirst().assertAttributeEquals(ASANA_GID, "1");
|
||||||
updatedFlowFiles.get(0).assertContentEquals("Lorem Ipsum");
|
updatedFlowFiles.getFirst().assertContentEquals("Lorem Ipsum");
|
||||||
|
|
||||||
final List<MockFlowFile> removedFlowFiles = runner.getFlowFilesForRelationship(REL_REMOVED);
|
final List<MockFlowFile> removedFlowFiles = runner.getFlowFilesForRelationship(REL_REMOVED);
|
||||||
|
|
||||||
removedFlowFiles.get(0).assertAttributeEquals(ASANA_GID, "3");
|
removedFlowFiles.getFirst().assertAttributeEquals(ASANA_GID, "3");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCollectObjectsFromAsanaWithBatchSizeConfigured() throws InitializationException {
|
public void testCollectObjectsFromAsanaWithBatchSizeConfigured() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
runner.setProperty(PROP_ASANA_OUTPUT_BATCH_SIZE, "2");
|
runner.setProperty(PROP_ASANA_OUTPUT_BATCH_SIZE, "2");
|
||||||
|
|
||||||
when(mockObjectFetcher.fetchNext())
|
when(mockObjectFetcher.fetchNext())
|
||||||
|
@ -187,18 +187,18 @@ public class GetAsanaObjectLifecycleTest {
|
||||||
|
|
||||||
final List<MockFlowFile> updatedFlowFiles = runner.getFlowFilesForRelationship(REL_UPDATED);
|
final List<MockFlowFile> updatedFlowFiles = runner.getFlowFilesForRelationship(REL_UPDATED);
|
||||||
|
|
||||||
updatedFlowFiles.get(0).assertContentEquals(GSON.toJson(singletonList("Lorem Ipsum")));
|
updatedFlowFiles.getFirst().assertContentEquals(GSON.toJson(singletonList("Lorem Ipsum")));
|
||||||
|
|
||||||
final List<MockFlowFile> removedFlowFiles = runner.getFlowFilesForRelationship(REL_REMOVED);
|
final List<MockFlowFile> removedFlowFiles = runner.getFlowFilesForRelationship(REL_REMOVED);
|
||||||
|
|
||||||
removedFlowFiles.get(0).assertContentEquals(GSON.toJson(singletonList("Some info about removal")));
|
removedFlowFiles.getFirst().assertContentEquals(GSON.toJson(singletonList("Some info about removal")));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testAttemptLoadStateButNoStatePresent() throws InitializationException {
|
public void testAttemptLoadStateButNoStatePresent() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
when(mockObjectFetcher.fetchNext()).thenReturn(null);
|
when(mockObjectFetcher.fetchNext()).thenReturn(null);
|
||||||
|
|
||||||
|
@ -212,7 +212,7 @@ public class GetAsanaObjectLifecycleTest {
|
||||||
public void testLoadValidState() throws InitializationException {
|
public void testLoadValidState() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
final Map<String, String> validState = new LinkedHashMap<>();
|
final Map<String, String> validState = new LinkedHashMap<>();
|
||||||
validState.put("Key1", "Value1");
|
validState.put("Key1", "Value1");
|
||||||
|
@ -232,7 +232,7 @@ public class GetAsanaObjectLifecycleTest {
|
||||||
public void testAttemptLoadInvalidStateThenClear() throws InitializationException {
|
public void testAttemptLoadInvalidStateThenClear() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
final Map<String, String> invalidState = singletonMap("Key", "Value");
|
final Map<String, String> invalidState = singletonMap("Key", "Value");
|
||||||
|
|
||||||
|
@ -251,7 +251,7 @@ public class GetAsanaObjectLifecycleTest {
|
||||||
public void testStateIsSavedIfProcessorYields() throws InitializationException {
|
public void testStateIsSavedIfProcessorYields() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
final Map<String, String> state = singletonMap("Key", "Value");
|
final Map<String, String> state = singletonMap("Key", "Value");
|
||||||
|
|
||||||
|
@ -267,7 +267,7 @@ public class GetAsanaObjectLifecycleTest {
|
||||||
public void testStateIsSavedIfThereAreObjectsFetched() throws InitializationException {
|
public void testStateIsSavedIfThereAreObjectsFetched() throws InitializationException {
|
||||||
withMockAsanaClientService();
|
withMockAsanaClientService();
|
||||||
withMockDistributedMapCacheClient();
|
withMockDistributedMapCacheClient();
|
||||||
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS.getValue());
|
runner.setProperty(PROP_ASANA_OBJECT_TYPE, AV_COLLECT_PROJECTS);
|
||||||
|
|
||||||
final Map<String, String> state = singletonMap("Key", "Value");
|
final Map<String, String> state = singletonMap("Key", "Value");
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,6 @@ import java.io.UncheckedIOException;
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
import java.util.stream.StreamSupport;
|
import java.util.stream.StreamSupport;
|
||||||
|
|
||||||
|
@ -242,7 +241,7 @@ public class StandardAsanaClient implements AsanaClient {
|
||||||
try {
|
try {
|
||||||
results = collectionRequestToStream(client.workspaces.getWorkspaces(null, null, getSerializedFieldNames(Workspace.class), false))
|
results = collectionRequestToStream(client.workspaces.getWorkspaces(null, null, getSerializedFieldNames(Workspace.class), false))
|
||||||
.filter(w -> w.name.equals(workspaceName))
|
.filter(w -> w.name.equals(workspaceName))
|
||||||
.collect(Collectors.toList());
|
.toList();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new UncheckedIOException(e);
|
throw new UncheckedIOException(e);
|
||||||
}
|
}
|
||||||
|
@ -252,7 +251,7 @@ public class StandardAsanaClient implements AsanaClient {
|
||||||
} else if (results.size() > 1) {
|
} else if (results.size() > 1) {
|
||||||
throw new AsanaClientException("Multiple workspaces match: " + workspaceName);
|
throw new AsanaClientException("Multiple workspaces match: " + workspaceName);
|
||||||
}
|
}
|
||||||
return results.get(0);
|
return results.getFirst();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -16,12 +16,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.controller.asana;
|
package org.apache.nifi.controller.asana;
|
||||||
|
|
||||||
import static org.apache.nifi.controller.asana.StandardAsanaClient.ASANA_CLIENT_OPTION_BASE_URL;
|
|
||||||
|
|
||||||
import com.asana.Client;
|
import com.asana.Client;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
|
||||||
import org.apache.nifi.annotation.documentation.CapabilityDescription;
|
import org.apache.nifi.annotation.documentation.CapabilityDescription;
|
||||||
import org.apache.nifi.annotation.documentation.Tags;
|
import org.apache.nifi.annotation.documentation.Tags;
|
||||||
import org.apache.nifi.annotation.lifecycle.OnEnabled;
|
import org.apache.nifi.annotation.lifecycle.OnEnabled;
|
||||||
|
@ -30,6 +25,10 @@ import org.apache.nifi.controller.AbstractControllerService;
|
||||||
import org.apache.nifi.controller.ConfigurationContext;
|
import org.apache.nifi.controller.ConfigurationContext;
|
||||||
import org.apache.nifi.processor.util.StandardValidators;
|
import org.apache.nifi.processor.util.StandardValidators;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.apache.nifi.controller.asana.StandardAsanaClient.ASANA_CLIENT_OPTION_BASE_URL;
|
||||||
|
|
||||||
@CapabilityDescription("Common service to authenticate with Asana, and to work on a specified workspace.")
|
@CapabilityDescription("Common service to authenticate with Asana, and to work on a specified workspace.")
|
||||||
@Tags({"asana", "service", "authentication"})
|
@Tags({"asana", "service", "authentication"})
|
||||||
public class StandardAsanaClientProviderService extends AbstractControllerService implements AsanaClientProviderService {
|
public class StandardAsanaClientProviderService extends AbstractControllerService implements AsanaClientProviderService {
|
||||||
|
@ -72,11 +71,11 @@ public class StandardAsanaClientProviderService extends AbstractControllerServic
|
||||||
.addValidator(StandardValidators.NON_BLANK_VALIDATOR)
|
.addValidator(StandardValidators.NON_BLANK_VALIDATOR)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
protected static final List<PropertyDescriptor> DESCRIPTORS = Collections.unmodifiableList(Arrays.asList(
|
protected static final List<PropertyDescriptor> DESCRIPTORS = List.of(
|
||||||
PROP_ASANA_API_BASE_URL,
|
PROP_ASANA_API_BASE_URL,
|
||||||
PROP_ASANA_PERSONAL_ACCESS_TOKEN,
|
PROP_ASANA_PERSONAL_ACCESS_TOKEN,
|
||||||
PROP_ASANA_WORKSPACE_NAME
|
PROP_ASANA_WORKSPACE_NAME
|
||||||
));
|
);
|
||||||
|
|
||||||
private volatile String personalAccessToken;
|
private volatile String personalAccessToken;
|
||||||
private volatile String workspaceName;
|
private volatile String workspaceName;
|
||||||
|
|
|
@ -16,18 +16,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.controller.asana;
|
package org.apache.nifi.controller.asana;
|
||||||
|
|
||||||
import static java.util.stream.Collectors.toMap;
|
|
||||||
import static org.apache.nifi.controller.asana.StandardAsanaClientProviderService.PROP_ASANA_API_BASE_URL;
|
|
||||||
import static org.apache.nifi.controller.asana.StandardAsanaClientProviderService.PROP_ASANA_PERSONAL_ACCESS_TOKEN;
|
|
||||||
import static org.apache.nifi.controller.asana.StandardAsanaClientProviderService.PROP_ASANA_WORKSPACE_NAME;
|
|
||||||
import static org.apache.nifi.util.TestRunners.newTestRunner;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertThrows;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
|
||||||
|
|
||||||
import com.asana.models.Project;
|
import com.asana.models.Project;
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.Map;
|
|
||||||
import okhttp3.mockwebserver.MockResponse;
|
import okhttp3.mockwebserver.MockResponse;
|
||||||
import okhttp3.mockwebserver.MockWebServer;
|
import okhttp3.mockwebserver.MockWebServer;
|
||||||
import org.apache.nifi.reporting.InitializationException;
|
import org.apache.nifi.reporting.InitializationException;
|
||||||
|
@ -38,46 +27,60 @@ import org.junit.jupiter.api.AfterEach;
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.stream.Collectors.toMap;
|
||||||
|
import static org.apache.nifi.controller.asana.StandardAsanaClientProviderService.PROP_ASANA_API_BASE_URL;
|
||||||
|
import static org.apache.nifi.controller.asana.StandardAsanaClientProviderService.PROP_ASANA_PERSONAL_ACCESS_TOKEN;
|
||||||
|
import static org.apache.nifi.controller.asana.StandardAsanaClientProviderService.PROP_ASANA_WORKSPACE_NAME;
|
||||||
|
import static org.apache.nifi.util.TestRunners.newTestRunner;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
public class StandardAsanaClientProviderServiceTest {
|
public class StandardAsanaClientProviderServiceTest {
|
||||||
|
|
||||||
private static final String LOCALHOST = "localhost";
|
private static final String LOCALHOST = "localhost";
|
||||||
|
|
||||||
private static final String WORKSPACES = "{\n" +
|
private static final String WORKSPACES = """
|
||||||
" \"data\": [\n" +
|
{
|
||||||
" {\n" +
|
"data": [
|
||||||
" \"gid\": \"1202898619267352\",\n" +
|
{
|
||||||
" \"name\": \"My Workspace\",\n" +
|
"gid": "1202898619267352",
|
||||||
" \"resource_type\": \"workspace\"\n" +
|
"name": "My Workspace",
|
||||||
" },\n" +
|
"resource_type": "workspace"
|
||||||
" {\n" +
|
},
|
||||||
" \"gid\": \"1202939205399549\",\n" +
|
{
|
||||||
" \"name\": \"Company or Team Name\",\n" +
|
"gid": "1202939205399549",
|
||||||
" \"resource_type\": \"workspace\"\n" +
|
"name": "Company or Team Name",
|
||||||
" },\n" +
|
"resource_type": "workspace"
|
||||||
" {\n" +
|
},
|
||||||
" \"gid\": \"1202946450806837\",\n" +
|
{
|
||||||
" \"name\": \"Company or Team Name\",\n" +
|
"gid": "1202946450806837",
|
||||||
" \"resource_type\": \"workspace\"\n" +
|
"name": "Company or Team Name",
|
||||||
" }\n" +
|
"resource_type": "workspace"
|
||||||
" ],\n" +
|
}
|
||||||
" \"next_page\": null\n" +
|
],
|
||||||
"}";
|
"next_page": null
|
||||||
|
}""";
|
||||||
|
|
||||||
private static final String PROJECTS = "{\n" +
|
private static final String PROJECTS = """
|
||||||
" \"data\": [\n" +
|
{
|
||||||
" {\n" +
|
"data": [
|
||||||
" \"gid\": \"1202898619637000\",\n" +
|
{
|
||||||
" \"name\": \"Our First Project\",\n" +
|
"gid": "1202898619637000",
|
||||||
" \"resource_type\": \"project\"\n" +
|
"name": "Our First Project",
|
||||||
" },\n" +
|
"resource_type": "project"
|
||||||
" {\n" +
|
},
|
||||||
" \"gid\": \"1202986168388325\",\n" +
|
{
|
||||||
" \"name\": \"Another Project Again\",\n" +
|
"gid": "1202986168388325",
|
||||||
" \"resource_type\": \"project\"\n" +
|
"name": "Another Project Again",
|
||||||
" }\n" +
|
"resource_type": "project"
|
||||||
" ],\n" +
|
}
|
||||||
" \"next_page\": null\n" +
|
],
|
||||||
"}";
|
"next_page": null
|
||||||
|
}""";
|
||||||
|
|
||||||
private TestRunner runner;
|
private TestRunner runner;
|
||||||
private StandardAsanaClientProviderService service;
|
private StandardAsanaClientProviderService service;
|
||||||
|
|
Loading…
Reference in New Issue