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 java.io.File;
23 import java.util.List;
24 import java.util.regex.Matcher;
25 import java.util.regex.Pattern;
26
27 import org.apache.maven.it.util.ResourceExtractor;
28
29
30
31
32
33
34
35 public class MavenITmng3719PomExecutionOrderingTest
36 extends AbstractMavenIntegrationTestCase
37 {
38
39 public MavenITmng3719PomExecutionOrderingTest()
40 {
41 super( "[2.0.11,2.1.0-M1),[2.1.0-M2,)" );
42 }
43
44
45
46
47 public void testitMNG3719()
48 throws Exception
49 {
50 File testDir = ResourceExtractor.simpleExtractResources( getClass(), "/mng-3719" );
51
52 Verifier verifier = newVerifier( testDir.getAbsolutePath() );
53 verifier.setAutoclean( false );
54 verifier.deleteDirectory( "target" );
55 verifier.executeGoal( "validate" );
56 verifier.verifyErrorFreeLog();
57 verifier.resetStreams();
58
59 Pattern pattern = Pattern.compile( ".*step-([0-9])\\.properties.*" );
60
61 int[] stepLines = new int[3];
62 List content = verifier.loadFile( verifier.getBasedir(), verifier.getLogFileName(), false );
63 for ( int i = 0; i < content.size(); i++ )
64 {
65 String line = (String) content.get( i );
66
67 Matcher m = pattern.matcher( line );
68 if ( m.matches() )
69 {
70 int step = Integer.valueOf( m.group( 1 ) ).intValue();
71 stepLines[step - 1] = i + 1;
72 }
73 }
74
75
76 assertTrue( "Step 1 should be found", stepLines[0] > 0 );
77 assertTrue( "Step 3 should be second", stepLines[0] < stepLines[2] );
78 assertTrue( "Step 2 should be third", stepLines[2] < stepLines[1] );
79 }
80 }