1 package org.apache.maven.it;
2
3 /*
4 * Licensed to the Apache Software Foundation (ASF) under one
5 * or more contributor license agreements. See the NOTICE file
6 * distributed with this work for additional information
7 * regarding copyright ownership. The ASF licenses this file
8 * to you under the Apache License, Version 2.0 (the
9 * "License"); you may not use this file except in compliance
10 * with the License. You may obtain a copy of the License at
11 *
12 * http://www.apache.org/licenses/LICENSE-2.0
13 *
14 * Unless required by applicable law or agreed to in writing,
15 * software distributed under the License is distributed on an
16 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17 * KIND, either express or implied. See the License for the
18 * specific language governing permissions and limitations
19 * under the License.
20 */
21
22 import org.apache.maven.it.util.ResourceExtractor;
23
24 import java.io.File;
25 import java.util.Properties;
26
27 /**
28 * This is a test set for <a href="https://issues.apache.org/jira/browse/MNG-3951">MNG-3951</a>.
29 *
30 * @author Benjamin Bentmann
31 *
32 */
33 public class MavenITmng3951AbsolutePathsTest
34 extends AbstractMavenIntegrationTestCase
35 {
36
37 public MavenITmng3951AbsolutePathsTest()
38 {
39 super( "(2.0.10,2.1.0-M1),(2.1.0-M1,)" );
40 }
41
42 /**
43 * Test that the paths retrieved from the core are always absolute, in particular the drive-relative paths on
44 * Windows must be properly resolved.
45 *
46 * @throws Exception in case of failure
47 */
48 public void testitMNG3951()
49 throws Exception
50 {
51 File testDir = ResourceExtractor.simpleExtractResources( getClass(), "/mng-3951" );
52
53 Verifier verifier = newVerifier( testDir.getAbsolutePath() );
54
55 /*
56 * Cut off anything before the first file separator from the local repo path. This is harmless on a Unix-like
57 * filesystem but will make the path drive-relative on Windows so we can check how Maven handles it.
58 */
59 String repoDir = new File( verifier.getLocalRepository() ).getAbsolutePath();
60 if ( getRoot( new File( repoDir ) ).equals( getRoot( testDir ) ) )
61 {
62 // NOTE: We can only test the local repo if it resides on the same drive as the test
63 verifier.setLocalRepo( repoDir.substring( repoDir.indexOf( File.separator ) ) );
64 }
65
66 verifier.setAutoclean( false );
67 verifier.deleteDirectory( "target" );
68 verifier.executeGoal( "validate" );
69 verifier.verifyErrorFreeLog();
70 verifier.resetStreams();
71
72 verifier.assertFilePresent( "target/path.properties" );
73 Properties props = verifier.loadProperties( "target/path.properties" );
74
75 assertCanonicalFileEquals( new File( testDir, "tmp" ).getAbsoluteFile(), new File( props.getProperty( "fileParams.0" ) ) );
76 assertCanonicalFileEquals( new File( getRoot( testDir ), "tmp" ).getAbsoluteFile(), new File( props.getProperty( "fileParams.1" ) ) );
77 assertCanonicalFileEquals( new File( repoDir ), new File( props.getProperty( "stringParams.0" ) ) );
78 }
79
80 private static File getRoot( File path )
81 {
82 File root = path;
83 for ( File dir = path; dir != null; dir = dir.getParentFile() )
84 {
85 root = dir;
86 }
87 return root;
88 }
89
90 }