Merge pull request #1824 from dturanski/gh-1824
* gh-1824: Add "include filter" support for the Maven plugin
This commit is contained in:
commit
55ccd07ace
|
|
@ -33,10 +33,20 @@ import org.apache.maven.shared.artifact.filter.collection.FilterArtifacts;
|
||||||
* A base mojo filtering the dependencies of the project.
|
* A base mojo filtering the dependencies of the project.
|
||||||
*
|
*
|
||||||
* @author Stephane Nicoll
|
* @author Stephane Nicoll
|
||||||
|
* @author David Turanski
|
||||||
* @since 1.1
|
* @since 1.1
|
||||||
*/
|
*/
|
||||||
public abstract class AbstractDependencyFilterMojo extends AbstractMojo {
|
public abstract class AbstractDependencyFilterMojo extends AbstractMojo {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Collection of artifact definitions to include. The {@link Include} element defines
|
||||||
|
* a {@code groupId} and {@code artifactId} mandatory properties and an optional
|
||||||
|
* {@code classifier} property.
|
||||||
|
* @since 1.2
|
||||||
|
*/
|
||||||
|
@Parameter
|
||||||
|
private List<Include> includes;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Collection of artifact definitions to exclude. The {@link Exclude} element defines
|
* Collection of artifact definitions to exclude. The {@link Exclude} element defines
|
||||||
* a {@code groupId} and {@code artifactId} mandatory properties and an optional
|
* a {@code groupId} and {@code artifactId} mandatory properties and an optional
|
||||||
|
|
@ -64,6 +74,10 @@ public abstract class AbstractDependencyFilterMojo extends AbstractMojo {
|
||||||
this.excludes = excludes;
|
this.excludes = excludes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void setIncludes(List<Include> includes) {
|
||||||
|
this.includes = includes;
|
||||||
|
}
|
||||||
|
|
||||||
protected void setExcludeGroupIds(String excludeGroupIds) {
|
protected void setExcludeGroupIds(String excludeGroupIds) {
|
||||||
this.excludeGroupIds = excludeGroupIds;
|
this.excludeGroupIds = excludeGroupIds;
|
||||||
}
|
}
|
||||||
|
|
@ -97,7 +111,10 @@ public abstract class AbstractDependencyFilterMojo extends AbstractMojo {
|
||||||
cleanFilterConfig(this.excludeArtifactIds)));
|
cleanFilterConfig(this.excludeArtifactIds)));
|
||||||
filters.addFilter(new MatchingGroupIdFilter(
|
filters.addFilter(new MatchingGroupIdFilter(
|
||||||
cleanFilterConfig(this.excludeGroupIds)));
|
cleanFilterConfig(this.excludeGroupIds)));
|
||||||
if (this.excludes != null) {
|
if (this.includes != null && !this.includes.isEmpty()) {
|
||||||
|
filters.addFilter(new IncludeFilter(this.includes));
|
||||||
|
}
|
||||||
|
if (this.excludes != null && !this.excludes.isEmpty()) {
|
||||||
filters.addFilter(new ExcludeFilter(this.excludes));
|
filters.addFilter(new ExcludeFilter(this.excludes));
|
||||||
}
|
}
|
||||||
return filters;
|
return filters;
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,79 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2014 the original author or authors.
|
||||||
|
* 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.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.maven;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.apache.maven.artifact.Artifact;
|
||||||
|
import org.apache.maven.shared.artifact.filter.collection.AbstractArtifactsFilter;
|
||||||
|
import org.apache.maven.shared.artifact.filter.collection.ArtifactFilterException;
|
||||||
|
import org.apache.maven.shared.artifact.filter.collection.ArtifactsFilter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base class for {@link ArtifactsFilter} based on a {@link FilterableDependency} list.
|
||||||
|
*
|
||||||
|
* @author Stephane Nicol
|
||||||
|
* @author David Turanski
|
||||||
|
* @since 1.2
|
||||||
|
*/
|
||||||
|
public abstract class DependencyFilter extends AbstractArtifactsFilter {
|
||||||
|
|
||||||
|
private final List<? extends FilterableDependency> filters;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new instance with the list of {@link FilterableDependency} instance(s) to use.
|
||||||
|
*/
|
||||||
|
public DependencyFilter(List<? extends FilterableDependency> dependencies) {
|
||||||
|
this.filters = dependencies;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@SuppressWarnings({ "rawtypes", "unchecked" })
|
||||||
|
public Set filter(Set artifacts) throws ArtifactFilterException {
|
||||||
|
Set result = new HashSet();
|
||||||
|
for (Object artifact : artifacts) {
|
||||||
|
if (!filter((Artifact) artifact)) {
|
||||||
|
result.add(artifact);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract boolean filter(Artifact artifact);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if the specified {@link org.apache.maven.artifact.Artifact} matches the
|
||||||
|
* specified {@link org.springframework.boot.maven.FilterableDependency}. Returns {@code true}
|
||||||
|
* if it should be excluded
|
||||||
|
*/
|
||||||
|
protected final boolean equals(Artifact artifact, FilterableDependency dependency) {
|
||||||
|
if (!dependency.getGroupId().equals(artifact.getGroupId())) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!dependency.getArtifactId().equals(artifact.getArtifactId())) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return (dependency.getClassifier() == null || artifact.getClassifier() != null
|
||||||
|
&& dependency.getClassifier().equals(artifact.getClassifier()));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected final List<? extends FilterableDependency> getFilters() {
|
||||||
|
return this.filters;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -16,55 +16,12 @@
|
||||||
|
|
||||||
package org.springframework.boot.maven;
|
package org.springframework.boot.maven;
|
||||||
|
|
||||||
import org.apache.maven.plugins.annotations.Parameter;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A model for a dependency to exclude.
|
* A model for a dependency to exclude.
|
||||||
*
|
*
|
||||||
* @author Stephane Nicoll
|
* @author Stephane Nicoll
|
||||||
* @since 1.1
|
* @since 1.1
|
||||||
*/
|
*/
|
||||||
public class Exclude {
|
public class Exclude extends FilterableDependency {
|
||||||
|
|
||||||
/**
|
|
||||||
* The groupId of the artifact to exclude.
|
|
||||||
*/
|
|
||||||
@Parameter(required = true)
|
|
||||||
private String groupId;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The artifactId of the artifact to exclude.
|
|
||||||
*/
|
|
||||||
@Parameter(required = true)
|
|
||||||
private String artifactId;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The classifier of the artifact to exclude
|
|
||||||
*/
|
|
||||||
@Parameter
|
|
||||||
private String classifier;
|
|
||||||
|
|
||||||
public String getGroupId() {
|
|
||||||
return this.groupId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setGroupId(String groupId) {
|
|
||||||
this.groupId = groupId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getArtifactId() {
|
|
||||||
return this.artifactId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setArtifactId(String artifactId) {
|
|
||||||
this.artifactId = artifactId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getClassifier() {
|
|
||||||
return this.classifier;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setClassifier(String classifier) {
|
|
||||||
this.classifier = classifier;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -16,73 +16,32 @@
|
||||||
|
|
||||||
package org.springframework.boot.maven;
|
package org.springframework.boot.maven;
|
||||||
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.apache.maven.artifact.Artifact;
|
import org.apache.maven.artifact.Artifact;
|
||||||
import org.apache.maven.shared.artifact.filter.collection.AbstractArtifactsFilter;
|
|
||||||
import org.apache.maven.shared.artifact.filter.collection.ArtifactFilterException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An {@link org.apache.maven.shared.artifact.filter.collection.ArtifactsFilter
|
* An {@ArtifactsFilter} that filters out any artifact matching an
|
||||||
* ArtifactsFilter} that filters out any artifact matching a configurable list of
|
* {@link Exclude}.
|
||||||
* {@link Exclude} instances.
|
|
||||||
*
|
*
|
||||||
* @author Stephane Nicoll
|
* @author Stephane Nicoll
|
||||||
|
* @author David Turanski
|
||||||
* @since 1.1
|
* @since 1.1
|
||||||
*/
|
*/
|
||||||
public class ExcludeFilter extends AbstractArtifactsFilter {
|
public class ExcludeFilter extends DependencyFilter {
|
||||||
|
|
||||||
private final List<Exclude> excludes;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a new instance with the list of {@link Exclude} instance(s) to use.
|
|
||||||
*/
|
|
||||||
public ExcludeFilter(List<Exclude> excludes) {
|
public ExcludeFilter(List<Exclude> excludes) {
|
||||||
this.excludes = excludes;
|
super(excludes);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("rawtypes")
|
protected boolean filter(Artifact artifact) {
|
||||||
public Set filter(Set artifacts) throws ArtifactFilterException {
|
for (FilterableDependency dependency : getFilters()) {
|
||||||
Set<Artifact> result = new HashSet<Artifact>();
|
if (equals(artifact, dependency)) {
|
||||||
for (Object a : artifacts) {
|
|
||||||
Artifact artifact = (Artifact) a;
|
|
||||||
if (!matchExclude(artifact)) {
|
|
||||||
result.add(artifact);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if the specified {@link Artifact} matches one of the known excludes. Returns
|
|
||||||
* {@code true} if it should be excluded
|
|
||||||
*/
|
|
||||||
private boolean matchExclude(Artifact artifact) {
|
|
||||||
for (Exclude exclude : this.excludes) {
|
|
||||||
if (match(artifact, exclude)) {
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if the specified {@link Artifact} matches the specified {@link Exclude}.
|
|
||||||
* Returns {@code true} if it should be excluded
|
|
||||||
*/
|
|
||||||
private boolean match(Artifact artifact, Exclude exclude) {
|
|
||||||
if (!exclude.getGroupId().equals(artifact.getGroupId())) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!exclude.getArtifactId().equals(artifact.getArtifactId())) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return (exclude.getClassifier() == null || artifact.getClassifier() != null
|
|
||||||
&& exclude.getClassifier().equals(artifact.getClassifier()));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,72 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2014 the original author or authors.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.maven;
|
||||||
|
|
||||||
|
import org.apache.maven.plugins.annotations.Parameter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A model for a dependency to include or exclude.
|
||||||
|
*
|
||||||
|
* @author Stephane Nicoll
|
||||||
|
* @author David Turanski
|
||||||
|
* @since 1.2
|
||||||
|
*/
|
||||||
|
abstract class FilterableDependency {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The groupId of the artifact to exclude.
|
||||||
|
*/
|
||||||
|
@Parameter(required = true)
|
||||||
|
private String groupId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The artifactId of the artifact to exclude.
|
||||||
|
*/
|
||||||
|
@Parameter(required = true)
|
||||||
|
private String artifactId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The classifier of the artifact to exclude
|
||||||
|
*/
|
||||||
|
@Parameter
|
||||||
|
private String classifier;
|
||||||
|
|
||||||
|
public String getGroupId() {
|
||||||
|
return this.groupId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setGroupId(String groupId) {
|
||||||
|
this.groupId = groupId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getArtifactId() {
|
||||||
|
return this.artifactId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setArtifactId(String artifactId) {
|
||||||
|
this.artifactId = artifactId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getClassifier() {
|
||||||
|
return this.classifier;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setClassifier(String classifier) {
|
||||||
|
this.classifier = classifier;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,27 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2014 the original author or authors.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.maven;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A model for a dependency to include.
|
||||||
|
*
|
||||||
|
* @author David Turanski
|
||||||
|
* @since 1.2
|
||||||
|
*/
|
||||||
|
public class Include extends FilterableDependency {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,46 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2014 the original author or authors.
|
||||||
|
* 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.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.maven;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.maven.artifact.Artifact;
|
||||||
|
import org.apache.maven.shared.artifact.filter.collection.ArtifactsFilter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An {@link ArtifactsFilter} that filters out any artifact not matching an
|
||||||
|
* {@link Include}.
|
||||||
|
*
|
||||||
|
* @author David Turanski
|
||||||
|
* @since 1.2
|
||||||
|
*/
|
||||||
|
public class IncludeFilter extends DependencyFilter {
|
||||||
|
|
||||||
|
public IncludeFilter(List<Include> includes) {
|
||||||
|
super(includes);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean filter(Artifact artifact) {
|
||||||
|
for (FilterableDependency dependency : getFilters()) {
|
||||||
|
if (equals(artifact, dependency)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -34,6 +34,7 @@ import static org.mockito.Mockito.mock;
|
||||||
* Tests for {@link ExcludeFilter}.
|
* Tests for {@link ExcludeFilter}.
|
||||||
*
|
*
|
||||||
* @author Stephane Nicoll
|
* @author Stephane Nicoll
|
||||||
|
* @author David Turanski
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("rawtypes")
|
@SuppressWarnings("rawtypes")
|
||||||
public class ExcludeFilterTests {
|
public class ExcludeFilterTests {
|
||||||
|
|
@ -111,20 +112,20 @@ public class ExcludeFilterTests {
|
||||||
assertSame(anotherAcme, result.iterator().next());
|
assertSame(anotherAcme, result.iterator().next());
|
||||||
}
|
}
|
||||||
|
|
||||||
private Exclude createExclude(String groupId, String artifactId, String classifier) {
|
|
||||||
Exclude e = new Exclude();
|
|
||||||
e.setGroupId(groupId);
|
|
||||||
e.setArtifactId(artifactId);
|
|
||||||
if (classifier != null) {
|
|
||||||
e.setClassifier(classifier);
|
|
||||||
}
|
|
||||||
return e;
|
|
||||||
}
|
|
||||||
|
|
||||||
private Exclude createExclude(String groupId, String artifactId) {
|
private Exclude createExclude(String groupId, String artifactId) {
|
||||||
return createExclude(groupId, artifactId, null);
|
return createExclude(groupId, artifactId, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Exclude createExclude(String groupId, String artifactId, String classifier) {
|
||||||
|
Exclude exclude = new Exclude();
|
||||||
|
exclude.setGroupId(groupId);
|
||||||
|
exclude.setArtifactId(artifactId);
|
||||||
|
if (classifier != null) {
|
||||||
|
exclude.setClassifier(classifier);
|
||||||
|
}
|
||||||
|
return exclude;
|
||||||
|
}
|
||||||
|
|
||||||
private Artifact createArtifact(String groupId, String artifactId, String classifier) {
|
private Artifact createArtifact(String groupId, String artifactId, String classifier) {
|
||||||
Artifact a = mock(Artifact.class);
|
Artifact a = mock(Artifact.class);
|
||||||
given(a.getGroupId()).willReturn(groupId);
|
given(a.getGroupId()).willReturn(groupId);
|
||||||
|
|
@ -136,4 +137,5 @@ public class ExcludeFilterTests {
|
||||||
private Artifact createArtifact(String groupId, String artifactId) {
|
private Artifact createArtifact(String groupId, String artifactId) {
|
||||||
return createArtifact(groupId, artifactId, null);
|
return createArtifact(groupId, artifactId, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,136 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2014 the original author or authors.
|
||||||
|
* 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.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.maven;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.apache.maven.artifact.Artifact;
|
||||||
|
import org.apache.maven.shared.artifact.filter.collection.ArtifactFilterException;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertSame;
|
||||||
|
import static org.mockito.BDDMockito.given;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link org.springframework.boot.maven.IncludeFilter}.
|
||||||
|
*
|
||||||
|
* @author David Turanski
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("rawtypes")
|
||||||
|
public class IncludeFilterTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void includeSimple() throws ArtifactFilterException {
|
||||||
|
IncludeFilter filter = new IncludeFilter(Arrays.asList(createInclude("com.foo",
|
||||||
|
"bar")));
|
||||||
|
Artifact artifact = createArtifact("com.foo", "bar");
|
||||||
|
Set result = filter.filter(Collections.singleton(artifact));
|
||||||
|
assertEquals("Should not have been filtered", 1, result.size());
|
||||||
|
assertSame(artifact, result.iterator().next());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void includeGroupIdNoMatch() throws ArtifactFilterException {
|
||||||
|
IncludeFilter filter = new IncludeFilter(Arrays.asList(createInclude("com.foo",
|
||||||
|
"bar")));
|
||||||
|
Artifact artifact = createArtifact("com.baz", "bar");
|
||||||
|
Set result = filter.filter(Collections.singleton(artifact));
|
||||||
|
assertEquals("Should have been filtered", 0, result.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void includeArtifactIdNoMatch() throws ArtifactFilterException {
|
||||||
|
IncludeFilter filter = new IncludeFilter(Arrays.asList(createInclude("com.foo",
|
||||||
|
"bar")));
|
||||||
|
Artifact artifact = createArtifact("com.foo", "biz");
|
||||||
|
Set result = filter.filter(Collections.singleton(artifact));
|
||||||
|
assertEquals("Should have been filtered", 0, result.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void includeClassifier() throws ArtifactFilterException {
|
||||||
|
IncludeFilter filter = new IncludeFilter(Arrays.asList(createInclude("com.foo",
|
||||||
|
"bar", "jdk5")));
|
||||||
|
Artifact artifact = createArtifact("com.foo", "bar", "jdk5");
|
||||||
|
Set result = filter.filter(Collections.singleton(artifact));
|
||||||
|
assertEquals("Should not have been filtered", 1, result.size());
|
||||||
|
assertSame(artifact, result.iterator().next());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void includeClassifierNoTargetClassifier() throws ArtifactFilterException {
|
||||||
|
IncludeFilter filter = new IncludeFilter(Arrays.asList(createInclude("com.foo",
|
||||||
|
"bar", "jdk5")));
|
||||||
|
Artifact artifact = createArtifact("com.foo", "bar");
|
||||||
|
Set result = filter.filter(Collections.singleton(artifact));
|
||||||
|
assertEquals("Should have been filtered", 0, result.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void includeClassifierNoMatch() throws ArtifactFilterException {
|
||||||
|
IncludeFilter filter = new IncludeFilter(Arrays.asList(createInclude("com.foo",
|
||||||
|
"bar", "jdk5")));
|
||||||
|
Artifact artifact = createArtifact("com.foo", "bar", "jdk6");
|
||||||
|
Set result = filter.filter(Collections.singleton(artifact));
|
||||||
|
assertEquals("Should have been filtered", 0, result.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void includeMulti() throws ArtifactFilterException {
|
||||||
|
IncludeFilter filter = new IncludeFilter(Arrays.asList(
|
||||||
|
createInclude("com.foo", "bar"), createInclude("com.foo", "bar2"),
|
||||||
|
createInclude("org.acme", "app")));
|
||||||
|
Set<Artifact> artifacts = new HashSet<Artifact>();
|
||||||
|
artifacts.add(createArtifact("com.foo", "bar"));
|
||||||
|
artifacts.add(createArtifact("com.foo", "bar"));
|
||||||
|
Artifact anotherAcme = createArtifact("org.acme", "another-app");
|
||||||
|
artifacts.add(anotherAcme);
|
||||||
|
Set result = filter.filter(artifacts);
|
||||||
|
assertEquals("One dependency should have been filtered", 2, result.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
private Include createInclude(String groupId, String artifactId) {
|
||||||
|
return createInclude(groupId, artifactId, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Include createInclude(String groupId, String artifactId, String classifier) {
|
||||||
|
Include include = new Include();
|
||||||
|
include.setGroupId(groupId);
|
||||||
|
include.setArtifactId(artifactId);
|
||||||
|
if (classifier != null) {
|
||||||
|
include.setClassifier(classifier);
|
||||||
|
}
|
||||||
|
return include;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Artifact createArtifact(String groupId, String artifactId, String classifier) {
|
||||||
|
Artifact a = mock(Artifact.class);
|
||||||
|
given(a.getGroupId()).willReturn(groupId);
|
||||||
|
given(a.getArtifactId()).willReturn(artifactId);
|
||||||
|
given(a.getClassifier()).willReturn(classifier);
|
||||||
|
return a;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Artifact createArtifact(String groupId, String artifactId) {
|
||||||
|
return createArtifact(groupId, artifactId, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue