From 8c7f2032465740efc228aa8905a2990678e28691 Mon Sep 17 00:00:00 2001 From: Benjamin Bentmann Date: Sat, 7 Mar 2009 00:17:27 +0000 Subject: [PATCH] [MNG-4072] [regression] Repositories from inactive profiles are used for artifact resolution o Added IT git-svn-id: https://svn.apache.org/repos/asf/maven/core-integration-testing/trunk@751145 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/maven/it/IntegrationTestSuite.java | 1 + ...avenITmng4072InactiveProfileReposTest.java | 75 ++++++++++++++++ .../test/resources/mng-4072/pom-template.xml | 80 ++++++++++++++++++ .../resources/mng-4072/profiles-template.xml | 45 ++++++++++ .../apache/maven/its/mng4072/a/0.1/a-0.1.jar | Bin 0 -> 1929 bytes .../apache/maven/its/mng4072/a/0.1/a-0.1.pom | 36 ++++++++ .../maven/its/mng4072/a/maven-metadata.xml | 13 +++ .../resources/mng-4072/settings-template.xml | 49 +++++++++++ 8 files changed, 299 insertions(+) create mode 100644 its/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng4072InactiveProfileReposTest.java create mode 100644 its/core-it-suite/src/test/resources/mng-4072/pom-template.xml create mode 100644 its/core-it-suite/src/test/resources/mng-4072/profiles-template.xml create mode 100644 its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/0.1/a-0.1.jar create mode 100644 its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/0.1/a-0.1.pom create mode 100644 its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/maven-metadata.xml create mode 100644 its/core-it-suite/src/test/resources/mng-4072/settings-template.xml diff --git a/its/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java b/its/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java index 8f45f4c311..0fd852a436 100644 --- a/its/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java +++ b/its/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java @@ -91,6 +91,7 @@ public static Test suite() // suite.addTestSuite( MavenIT0109ReleaseUpdateTest.class ); // suite.addTestSuite( MavenIT0108SnapshotUpdateTest.class ); -- MNG-3137 + suite.addTestSuite( MavenITmng4072InactiveProfileReposTest.class ); suite.addTestSuite( MavenITmng4070WhitespaceTrimmingTest.class ); suite.addTestSuite( MavenITmng4068AuthenticatedMirrorTest.class ); suite.addTestSuite( MavenITmng4056ClassifierBasedDepResolutionFromReactorTest.class ); diff --git a/its/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng4072InactiveProfileReposTest.java b/its/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng4072InactiveProfileReposTest.java new file mode 100644 index 0000000000..b49dcb162e --- /dev/null +++ b/its/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng4072InactiveProfileReposTest.java @@ -0,0 +1,75 @@ +package org.apache.maven.it; + +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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. + */ + +import org.apache.maven.it.Verifier; +import org.apache.maven.it.util.ResourceExtractor; + +import java.io.File; +import java.util.Properties; + +/** + * This is a test set for MNG-4072. + * + * @author Benjamin Bentmann + */ +public class MavenITmng4072InactiveProfileReposTest + extends AbstractMavenIntegrationTestCase +{ + + public MavenITmng4072InactiveProfileReposTest() + { + super( ALL_MAVEN_VERSIONS ); + } + + /** + * Test that repositories from inactive profiles are actually not used for artifact resolution. + */ + public void testit() + throws Exception + { + File testDir = ResourceExtractor.simpleExtractResources( getClass(), "/mng-4072" ); + + Verifier verifier = new Verifier( testDir.getAbsolutePath() ); + verifier.setAutoclean( false ); + verifier.deleteArtifacts( "org.apache.maven.its.mng4072" ); + Properties filterProps = verifier.newDefaultFilterProperties(); + verifier.filterFile( "pom-template.xml", "pom.xml", "UTF-8", filterProps ); + verifier.filterFile( "profiles-template.xml", "profiles.xml", "UTF-8", filterProps ); + verifier.filterFile( "settings-template.xml", "settings.xml", "UTF-8", filterProps ); + verifier.getCliOptions().add( "--settings" ); + verifier.getCliOptions().add( "settings.xml" ); + try + { + verifier.executeGoal( "validate" ); + verifier.verifyErrorFreeLog(); + fail( "Dependency resolution succeeded although all profiles are inactive" ); + } + catch ( Exception e ) + { + // expected, all profiles are inactive, hence the repos inaccessible + } + finally + { + verifier.resetStreams(); + } + } + +} diff --git a/its/core-it-suite/src/test/resources/mng-4072/pom-template.xml b/its/core-it-suite/src/test/resources/mng-4072/pom-template.xml new file mode 100644 index 0000000000..3e1011f0bc --- /dev/null +++ b/its/core-it-suite/src/test/resources/mng-4072/pom-template.xml @@ -0,0 +1,80 @@ + + + + + + 4.0.0 + + org.apache.maven.its.mng4072 + test + 1.0 + jar + + Maven Integration Test :: MNG-4072 + + Test that repositories from inactive profiles are actually not used for artifact resolution. + + + + + org.apache.maven.its.mng4072 + a + 0.1 + + + + + + + org.apache.maven.its.plugins + maven-it-plugin-dependency-resolution + 2.1-SNAPSHOT + + + test + validate + + compile + + + + + + + + + + + maven-core-it-repo-pom + + + maven-core-it + @baseurl@/repo + + ignore + + + false + + + + + + diff --git a/its/core-it-suite/src/test/resources/mng-4072/profiles-template.xml b/its/core-it-suite/src/test/resources/mng-4072/profiles-template.xml new file mode 100644 index 0000000000..89d39ba23f --- /dev/null +++ b/its/core-it-suite/src/test/resources/mng-4072/profiles-template.xml @@ -0,0 +1,45 @@ + + + + + + + + + maven-core-it-repo-profiles + + + maven-core-it + @baseurl@/repo + + ignore + + + false + + + + + + false + + + + diff --git a/its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/0.1/a-0.1.jar b/its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/0.1/a-0.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..d40d839c3e59a9797d0e298e4e8cdb94d4299248 GIT binary patch literal 1929 zcmWIWW@h1H0D(ZZbSp3eN^k;cU)K;vT~9wZ{Q#&k4u$}rva`3+m{Nh#)j%wQtjyQZ z&(qB{I7H9a?X&Nh(>~t1dKY=Ub+yi&Ilno`;EM5sr$stm=T7K&>pF3;KUoqsMNIpE zO2y7O-9f_MLBS<+wbqKra0^W~4ic>qJ{|NKDC1>Z>~-Lg-#Wi_0(D*M!oAE+6d2n! zS1=dH>BZ?Wz?_BYdVXYQat zllT=kjY`2eu8$c4o~;ttw1?xJ_~j4I1v7uldw(?l(1q`Lu6>sh7{eN4m3^e)JGft2pz>?pr2y?yC#P=sy(xsHhI4IyGt&F$wJ)?1oQYY9#Lvm%sQ;KD0^Z=e(OYYjaLHE|WD_R6WPRsjx_8M#_XV#+rF4nPyGxB_C7k_BXVj zyn8ogn@7IUjQa<#)|AcFyY#ciFL=fox!U*HR=edGCwZ8##Y?|^Anf)~tv?VtAa=a0X;XT06? zOK9ENh>v$J%{>0*#TEDV<+FPhZ=SLDO?zO=F8j}uG}QcKj=w38S@34i_W|@>0QFEmzsHttBx()U?_Z4@zyJ?!rQ*uC+_`=Df;Ej@wa=Yn_=<6 zg~q>Em!A38-4gKL^&c-RzjA;}n+qmeZWjR)c_|Rvkd@dAit-Cmi%K$6i$%|DD?W=s z#U2EJEZzrX!cBk`f-vi`7lR1RuQ4?fC=_v<3@R2O0OTxFMhs`+H5pV$!pz2AOu|fG z(%49{+0a50*$Plqh@LnRR^$Q8X0%Wx;Czr3h@=|e&B_KcjU5Orfn~iFD~JaG(HWFr literal 0 HcmV?d00001 diff --git a/its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/0.1/a-0.1.pom b/its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/0.1/a-0.1.pom new file mode 100644 index 0000000000..ad69cf3b34 --- /dev/null +++ b/its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/0.1/a-0.1.pom @@ -0,0 +1,36 @@ + + + + + + 4.0.0 + + org.apache.maven.its.mng4072 + a + 0.1 + jar + + + + maven-core-it + file:///${basedir}/repo + + + diff --git a/its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/maven-metadata.xml b/its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/maven-metadata.xml new file mode 100644 index 0000000000..ba6b3ad03f --- /dev/null +++ b/its/core-it-suite/src/test/resources/mng-4072/repo/org/apache/maven/its/mng4072/a/maven-metadata.xml @@ -0,0 +1,13 @@ + + + org.apache.maven.its.mng4072 + a + 0.1 + + 0.1 + + 0.1 + + 20090306235034 + + diff --git a/its/core-it-suite/src/test/resources/mng-4072/settings-template.xml b/its/core-it-suite/src/test/resources/mng-4072/settings-template.xml new file mode 100644 index 0000000000..cc6b5c447d --- /dev/null +++ b/its/core-it-suite/src/test/resources/mng-4072/settings-template.xml @@ -0,0 +1,49 @@ + + + + + + + + + maven-core-it-repo-settings + + + maven-core-it + @baseurl@/repo + + ignore + + + false + + + + + + + + + central + @baseurl@/null + central + + +