2018-02-08 16:26:50 -08:00
|
|
|
/**
|
|
|
|
* Copyright 2015 LinkedIn Corp. All rights reserved.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
*/
|
|
|
|
package wherehows.util;
|
|
|
|
|
2018-02-20 14:27:15 -08:00
|
|
|
import com.google.common.collect.ImmutableSet;
|
2018-06-12 15:58:33 -07:00
|
|
|
import com.linkedin.events.metadata.ChangeType;
|
|
|
|
import com.linkedin.events.metadata.DataOrigin;
|
|
|
|
import com.linkedin.events.metadata.DatasetIdentifier;
|
|
|
|
import com.linkedin.events.metadata.MetadataChangeEvent;
|
2018-02-20 14:27:15 -08:00
|
|
|
import com.typesafe.config.Config;
|
2018-02-08 16:26:50 -08:00
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Arrays;
|
|
|
|
import java.util.Collections;
|
|
|
|
import java.util.List;
|
2018-02-20 14:27:15 -08:00
|
|
|
import java.util.Set;
|
2018-02-08 16:26:50 -08:00
|
|
|
import java.util.regex.Pattern;
|
|
|
|
import org.testng.annotations.Test;
|
|
|
|
import wherehows.utils.ProcessorUtil;
|
|
|
|
|
2018-02-20 14:27:15 -08:00
|
|
|
import static org.mockito.Mockito.*;
|
2018-02-08 16:26:50 -08:00
|
|
|
import static org.testng.Assert.*;
|
|
|
|
|
|
|
|
|
|
|
|
public class ProcessorUtilTest {
|
|
|
|
|
2018-06-12 16:07:22 -07:00
|
|
|
@Test
|
|
|
|
public void testDedupeDatasets() {
|
|
|
|
DatasetIdentifier ds1 = makeDataset("test1");
|
|
|
|
DatasetIdentifier ds2 = makeDataset("test2");
|
|
|
|
DatasetIdentifier ds3 = makeDataset("test1");
|
|
|
|
List<DatasetIdentifier> datasets = Arrays.asList(ds1, ds2, ds3);
|
|
|
|
|
|
|
|
List<DatasetIdentifier> deduped = ProcessorUtil.dedupeDatasets(datasets);
|
|
|
|
assertEquals(deduped, Arrays.asList(ds1, ds2));
|
|
|
|
}
|
|
|
|
|
2018-02-08 16:26:50 -08:00
|
|
|
@Test
|
|
|
|
public void testListDiffWithExclusion() {
|
|
|
|
List<String> existing = new ArrayList<>(Arrays.asList("a", "b", "c"));
|
|
|
|
List<String> updated = new ArrayList<>(Arrays.asList("b", "d"));
|
|
|
|
|
|
|
|
assertEquals(ProcessorUtil.listDiffWithExclusion(existing, updated, Collections.emptyList()),
|
|
|
|
Arrays.asList("a", "c"));
|
|
|
|
|
|
|
|
List<Pattern> exclusions = Collections.singletonList(Pattern.compile("a"));
|
|
|
|
|
|
|
|
assertEquals(ProcessorUtil.listDiffWithExclusion(existing, updated, exclusions), Arrays.asList("c"));
|
|
|
|
}
|
2018-02-20 14:27:15 -08:00
|
|
|
|
|
|
|
@Test
|
|
|
|
public void testGetWhitelistedActors() {
|
|
|
|
Config config = mock(Config.class);
|
|
|
|
when(config.hasPath("whitelist")).thenReturn(true);
|
|
|
|
when(config.getString("whitelist")).thenReturn("foo;bar");
|
|
|
|
|
|
|
|
Set<String> actors = ProcessorUtil.getWhitelistedActors(config, "whitelist");
|
|
|
|
|
|
|
|
assertEquals(actors, ImmutableSet.of("foo", "bar"));
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void testGetWhitelistedActorsNoPath() {
|
|
|
|
Config config = mock(Config.class);
|
|
|
|
when(config.hasPath("whitelist")).thenReturn(false);
|
|
|
|
|
|
|
|
Set<String> actors = ProcessorUtil.getWhitelistedActors(config, "whitelist");
|
|
|
|
|
|
|
|
assertEquals(actors, null);
|
|
|
|
}
|
2018-02-20 17:02:54 -08:00
|
|
|
|
|
|
|
@Test
|
|
|
|
public void testGetWhitelistedActorsEmptyValue() {
|
|
|
|
Config config = mock(Config.class);
|
|
|
|
when(config.hasPath("whitelist")).thenReturn(true);
|
|
|
|
when(config.getString("whitelist")).thenReturn("");
|
|
|
|
|
|
|
|
Set<String> actors = ProcessorUtil.getWhitelistedActors(config, "whitelist");
|
|
|
|
|
|
|
|
assertEquals(actors, null);
|
|
|
|
}
|
2018-06-12 15:58:33 -07:00
|
|
|
|
|
|
|
@Test
|
|
|
|
public void testMceDelete() {
|
|
|
|
String actor = "tester";
|
|
|
|
DatasetIdentifier dataset = makeDataset("test");
|
|
|
|
MetadataChangeEvent mce = ProcessorUtil.mceDelete(dataset, actor);
|
|
|
|
|
|
|
|
assertEquals(mce.datasetIdentifier, dataset);
|
|
|
|
assertEquals(mce.changeAuditStamp.type, ChangeType.DELETE);
|
|
|
|
assertEquals(mce.changeAuditStamp.actorUrn, actor);
|
|
|
|
}
|
|
|
|
|
2018-06-12 16:07:22 -07:00
|
|
|
public static DatasetIdentifier makeDataset(String datasetName) {
|
2018-06-12 15:58:33 -07:00
|
|
|
DatasetIdentifier identifier = new DatasetIdentifier();
|
|
|
|
identifier.nativeName = datasetName;
|
|
|
|
identifier.dataPlatformUrn = "urn:li:dataPlatform:hive";
|
|
|
|
identifier.dataOrigin = DataOrigin.DEV;
|
|
|
|
return identifier;
|
|
|
|
}
|
2018-02-08 16:26:50 -08:00
|
|
|
}
|