o Reduced coupling to format of warning

git-svn-id: https://svn.apache.org/repos/asf/maven/core-integration-testing/trunk@788374 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Benjamin Bentmann 2009-06-25 14:57:30 +00:00
parent 1b3b083744
commit a5e86ea439
1 changed files with 29 additions and 65 deletions

View File

@ -25,6 +25,7 @@ import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
import java.util.regex.Pattern;
import junit.framework.TestCase; import junit.framework.TestCase;
@ -71,26 +72,11 @@ public class MavenITmng2690MojoLoadingErrorsTest
List lines = verifier.loadFile( new File( testDir, "log.txt" ), false ); List lines = verifier.loadFile( new File( testDir, "log.txt" ), false );
boolean foundMessage = false; int msg = indexOf( lines, "(?i).*required class is missing.*" );
boolean foundClass = false; assertTrue( "User-friendly message was not found in output.", msg >= 0 );
for ( Iterator it = lines.iterator(); it.hasNext(); )
{
String line = (String) it.next();
if ( line.indexOf( "A required class is missing" ) > -1 )
{
foundMessage = true;
}
// trigger AFTER the required-class message is found, since the class name should come afterward. int cls = lines.get( msg ).toString().replace( '/', '.' ).indexOf( TestCase.class.getName() );
if ( foundMessage && line.replace( '/', '.' ).indexOf( TestCase.class.getName() ) > -1 ) assertTrue( "Missing class name was not found in output.", cls >= 0 );
{
foundClass = true;
break;
}
}
assertTrue( "User-friendly message was not found in output.", foundMessage );
assertTrue( "Missing class name was not found in output.", foundClass );
} }
public void testNoClassDefFromMojoConfiguration() public void testNoClassDefFromMojoConfiguration()
@ -118,26 +104,11 @@ public class MavenITmng2690MojoLoadingErrorsTest
List lines = verifier.loadFile( new File( testDir, "log.txt" ), false ); List lines = verifier.loadFile( new File( testDir, "log.txt" ), false );
boolean foundMessage = false; int msg = indexOf( lines, "(?i).*required class was missing during mojo configuration.*" );
boolean foundClass = false; assertTrue( "User-friendly message was not found in output.", msg >= 0 );
for ( Iterator it = lines.iterator(); it.hasNext(); )
{
String line = (String) it.next();
if ( line.indexOf( "A required class was missing during mojo configuration" ) > -1 )
{
foundMessage = true;
}
// trigger AFTER the required-class message is found, since the class name should come afterward. int cls = lines.get( msg ).toString().replace( '/', '.' ).indexOf( TestCase.class.getName() );
if ( foundMessage && line.replace( '/', '.' ).indexOf( TestCase.class.getName() ) > -1 ) assertTrue( "Missing class name was not found in output.", cls >= 0 );
{
foundClass = true;
break;
}
}
assertTrue( "User-friendly message was not found in output.", foundMessage );
assertTrue( "Missing class name was not found in output.", foundClass );
} }
public void testMojoComponentLookupException() public void testMojoComponentLookupException()
@ -165,23 +136,11 @@ public class MavenITmng2690MojoLoadingErrorsTest
List lines = verifier.loadFile( new File( testDir, "log.txt" ), false ); List lines = verifier.loadFile( new File( testDir, "log.txt" ), false );
String compLookupMessage = String compLookupMsg =
"Unable to find the mojo 'mojo-component-lookup-exception' " "(?i).*unable to .* mojo 'mojo-component-lookup-exception' .* plugin "
+ "(or one of its required components) in the plugin " + "'org\\.apache\\.maven\\.its\\.plugins:maven-it-plugin-error.*";
+ "'org.apache.maven.its.plugins:maven-it-plugin-error";
boolean foundMessage = false; assertTrue( "User-friendly message was not found in output.", indexOf( lines, compLookupMsg ) > 0 );
for ( Iterator it = lines.iterator(); it.hasNext(); )
{
String line = (String) it.next();
if ( line.indexOf( compLookupMessage ) > -1 )
{
foundMessage = true;
break;
}
}
assertTrue( "User-friendly message was not found in output.", foundMessage );
} }
public void testMojoRequirementComponentLookupException() public void testMojoRequirementComponentLookupException()
@ -209,23 +168,28 @@ public class MavenITmng2690MojoLoadingErrorsTest
List lines = verifier.loadFile( new File( testDir, "log.txt" ), false ); List lines = verifier.loadFile( new File( testDir, "log.txt" ), false );
String compLookupMessage = String compLookupMsg =
"Unable to find the mojo 'requirement-component-lookup-exception' " "(?i).*unable to .* mojo 'requirement-component-lookup-exception' .* plugin "
+ "(or one of its required components) in the plugin " + "'org\\.apache\\.maven\\.its\\.plugins:maven-it-plugin-error.*";
+ "'org.apache.maven.its.plugins:maven-it-plugin-error";
boolean foundMessage = false; assertTrue( "User-friendly message was not found in output.", indexOf( lines, compLookupMsg ) > 0 );
for ( Iterator it = lines.iterator(); it.hasNext(); ) }
private int indexOf( List logLines, String regex )
{
Pattern pattern = Pattern.compile( regex );
for ( int i = 0; i < logLines.size(); i++ )
{ {
String line = (String) it.next(); String logLine = (String) logLines.get( i );
if ( line.indexOf( compLookupMessage ) > -1 )
if ( pattern.matcher( logLine ).matches() )
{ {
foundMessage = true; return i;
break;
} }
} }
assertTrue( "User-friendly message was not found in output.", foundMessage ); return -1;
} }
} }