1 package org.apache.maven.it;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import org.apache.maven.it.util.ResourceExtractor;
23
24 import java.io.File;
25 import java.util.List;
26
27
28
29
30
31
32 public class MavenITmng4275RelocationWarningTest
33 extends AbstractMavenIntegrationTestCase
34 {
35
36 public MavenITmng4275RelocationWarningTest()
37 {
38 super( "[2.0,2.0.9),[2.2.1,3.0-alpha-1),[3.0-alpha-3,)" );
39 }
40
41
42
43
44
45
46 public void testit()
47 throws Exception
48 {
49 File testDir = ResourceExtractor.simpleExtractResources( getClass(), "/mng-4275" );
50
51 Verifier verifier = newVerifier( testDir.getAbsolutePath() );
52 verifier.setAutoclean( false );
53 verifier.deleteDirectory( "target" );
54 verifier.deleteArtifacts( "org.apache.maven.its.mng4275" );
55 verifier.filterFile( "settings-template.xml", "settings.xml", "UTF-8", verifier.newDefaultFilterProperties() );
56 verifier.addCliOption( "--settings" );
57 verifier.addCliOption( "settings.xml" );
58 verifier.executeGoal( "validate" );
59 verifier.verifyErrorFreeLog();
60 verifier.resetStreams();
61
62 List<String> lines = verifier.loadFile( new File( testDir, verifier.getLogFileName() ), false );
63 boolean foundWarning = false;
64 for ( String line : lines )
65 {
66 if ( foundWarning )
67 {
68 assertTrue( "Relocation target should have been logged right after warning.", line.contains(
69 "This artifact has been relocated to org.apache.maven.its.mng4275:relocated:1" ) );
70 break;
71 }
72 else if ( line.startsWith( "[WARNING] While downloading org.apache.maven.its.mng4275:relocation:1" ) )
73 {
74 foundWarning = true;
75 }
76 else if ( line.matches(
77 "\\[WARNING\\].* org.apache.maven.its.mng4275:relocation:jar:1 .* org.apache.maven.its"
78 + ".mng4275:relocated:jar:1.*" ) )
79 {
80 foundWarning = true;
81 break;
82 }
83 }
84
85 assertTrue( "Relocation warning should haven been logged.", foundWarning );
86 }
87
88 }