Skip to content

Commit

Permalink
[#74] rework integration tests pt.2
Browse files Browse the repository at this point in the history
  • Loading branch information
bmarwell committed Oct 27, 2023
1 parent ee7d0b4 commit 6f174f1
Show file tree
Hide file tree
Showing 19 changed files with 143 additions and 43 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/maven.yml
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,8 @@ jobs:
name: Verify
uses: apache/maven-gh-actions-shared/.github/workflows/maven-verify.yml@v3
with:
ff-goal: '-P run-its install' # site use project version for reporting
verify-goal: '-P run-its install' # should be the same as for first build
ff-goal: '-ntp -P run-its install' # site use project version for reporting
verify-goal: '-ntp -P run-its install' # should be the same as for first build

deploy:
name: Deploy
Expand Down
18 changes: 18 additions & 0 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -183,6 +183,12 @@
<artifactId>slf4j-api</artifactId>
<version>1.7.9</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.7.9</version>
<scope>test</scope>
</dependency>

<!-- needed to debug plugin under m2e -->
<dependency>
Expand Down Expand Up @@ -210,6 +216,18 @@
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-server</artifactId>
<version>9.4.51.v20230217</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-http</artifactId>
<version>9.4.51.v20230217</version>
<scope>test</scope>
</dependency>
</dependencies>

<build>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -80,4 +80,4 @@ private void disconnectWagon( Wagon wagon )
}
}

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -92,4 +92,4 @@ public void execute()
protected abstract void execute( Wagon wagon )
throws MojoExecutionException, WagonException, IOException;

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -61,4 +61,4 @@ protected WagonFileSet getWagonFileSet( String fromDir, String includes, String
{
return WagonUtils.getWagonFileSet( fromDir, includes, excludes, caseSensitive, toDir );
}
}
}
2 changes: 1 addition & 1 deletion src/main/java/org/codehaus/mojo/wagon/CopyMojo.java
Original file line number Diff line number Diff line change
Expand Up @@ -78,4 +78,4 @@ protected void copy( Wagon srcWagon, Wagon targetWagon )
wagonCopy.copy( srcWagon, fileSet, targetWagon, optimize, this.getLog() );
}

}
}
2 changes: 1 addition & 1 deletion src/main/java/org/codehaus/mojo/wagon/ExistMojo.java
Original file line number Diff line number Diff line change
Expand Up @@ -56,4 +56,4 @@ protected void execute( Wagon wagon )
}
}

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -45,4 +45,4 @@ protected void copy( Wagon srcWagon, Wagon targetWagon )
mavenRepoMerger.merge( srcWagon, targetWagon, optimize, this.getLog() );
}

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@
import java.io.IOException;
import java.util.Arrays;

import org.apache.maven.plugin.logging.Log;
import org.apache.maven.shared.model.fileset.FileSet;
import org.apache.maven.shared.model.fileset.util.FileSetManager;
import org.apache.maven.wagon.CommandExecutor;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@

import java.io.IOException;

import org.apache.maven.plugin.logging.Log;
import org.apache.maven.shared.model.fileset.FileSet;
import org.apache.maven.wagon.Wagon;
import org.apache.maven.wagon.WagonException;
Expand Down
51 changes: 51 additions & 0 deletions src/test/java/org/codehaus/mojo/wagon/AbstractJettyIT.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
package org.codehaus.mojo.wagon;

import java.io.IOException;
import java.nio.file.Path;
import org.eclipse.jetty.server.Handler;
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.server.ServerConnector;
import org.eclipse.jetty.server.handler.DefaultHandler;
import org.eclipse.jetty.server.handler.HandlerList;
import org.eclipse.jetty.server.handler.ResourceHandler;
import org.junit.After;
import org.junit.Before;

public abstract class AbstractJettyIT {

private Server server;
private int port;

@Before
public void runJetty() throws Exception {
server = new Server();
ServerConnector connector = new ServerConnector(server);
connector.setPort(0);
connector.setHost("localhost");
server.addConnector(connector);

ResourceHandler resource_handler = new ResourceHandler();
resource_handler.setDirectoriesListed(true);
resource_handler.setResourceBase(getDirectoryToServe().toString());

HandlerList handlers = new HandlerList();
handlers.setHandlers(new Handler[] { resource_handler, new DefaultHandler() });
server.setHandler(handlers);

server.start();
this.port = connector.getLocalPort();
}


@After
public void tearDown() throws Exception {
server.stop();
}

protected int getServerPort() {
return this.port;
}

protected abstract Path getDirectoryToServe() throws IOException;

}
16 changes: 7 additions & 9 deletions src/test/java/org/codehaus/mojo/wagon/WagonMojoFtpBasicIT.java
Original file line number Diff line number Diff line change
@@ -1,7 +1,13 @@
package org.codehaus.mojo.wagon;

import io.takari.maven.testing.TestResources;
import io.takari.maven.testing.executor.MavenExecution;
import io.takari.maven.testing.executor.MavenExecutionResult;
import io.takari.maven.testing.executor.MavenRuntime;
import io.takari.maven.testing.executor.MavenRuntime.MavenRuntimeBuilder;
import io.takari.maven.testing.executor.MavenVersions;
import io.takari.maven.testing.executor.junit.MavenJUnitTestRunner;
import java.io.File;

import org.apache.ftpserver.ConnectionConfigFactory;
import org.apache.ftpserver.FtpServer;
import org.apache.ftpserver.FtpServerFactory;
Expand All @@ -15,14 +21,6 @@
import org.junit.Test;
import org.junit.runner.RunWith;

import io.takari.maven.testing.TestResources;
import io.takari.maven.testing.executor.MavenExecution;
import io.takari.maven.testing.executor.MavenExecutionResult;
import io.takari.maven.testing.executor.MavenRuntime;
import io.takari.maven.testing.executor.MavenRuntime.MavenRuntimeBuilder;
import io.takari.maven.testing.executor.MavenVersions;
import io.takari.maven.testing.executor.junit.MavenJUnitTestRunner;

@RunWith( MavenJUnitTestRunner.class )
@MavenVersions( { "3.2.5" } )
public class WagonMojoFtpBasicIT
Expand Down
37 changes: 27 additions & 10 deletions src/test/java/org/codehaus/mojo/wagon/WagonMojoHttpIT.java
Original file line number Diff line number Diff line change
@@ -1,11 +1,6 @@
package org.codehaus.mojo.wagon;

import java.io.File;

import org.junit.Assert;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
import static java.util.Objects.requireNonNull;

import io.takari.maven.testing.TestResources;
import io.takari.maven.testing.executor.MavenExecution;
Expand All @@ -14,20 +9,36 @@
import io.takari.maven.testing.executor.MavenRuntime.MavenRuntimeBuilder;
import io.takari.maven.testing.executor.MavenVersions;
import io.takari.maven.testing.executor.junit.MavenJUnitTestRunner;
import java.io.File;
import java.io.IOException;
import java.net.URL;
import java.nio.file.Path;
import java.nio.file.Paths;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;

@RunWith( MavenJUnitTestRunner.class )
@MavenVersions( { "3.2.5" } )
public class WagonMojoHttpIT
public class WagonMojoHttpIT extends AbstractJettyIT
{
@Rule
public final TestResources resources = new TestResources();
private final MavenRuntimeBuilder mavenBuilder;

public final MavenRuntime maven;
public MavenRuntime maven;

public WagonMojoHttpIT( MavenRuntimeBuilder builder )
throws Exception
{
this.maven = builder.withCliOptions( "-B" ).build();
this.mavenBuilder = builder.withCliOptions( "-B" );
}

@Before
public void setPort() throws Exception {
this.maven = this.mavenBuilder.withCliOptions( "-Dserver.port=" + getServerPort() ).build();
}

@Test
Expand All @@ -41,6 +52,12 @@ public void testDownload()
result.assertErrorFreeLog();

Assert.assertTrue( new File( result.getBasedir(),
"target/it/http-download/1.1/commons-dbutils-1.1-sources.jar" ).exists() );
"target/it/http-download/1.1/commons-dbutils-1.1-sources.txt" ).exists() );
}

@Override
protected Path getDirectoryToServe() throws IOException {
return resources.getBasedir("http-download").toPath()
.resolve("files");
}
}
31 changes: 22 additions & 9 deletions src/test/java/org/codehaus/mojo/wagon/WagonMojoHttpSettingsIT.java
Original file line number Diff line number Diff line change
@@ -1,32 +1,39 @@
package org.codehaus.mojo.wagon;

import java.io.File;

import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;

import io.takari.maven.testing.TestResources;
import io.takari.maven.testing.executor.MavenExecution;
import io.takari.maven.testing.executor.MavenExecutionResult;
import io.takari.maven.testing.executor.MavenRuntime;
import io.takari.maven.testing.executor.MavenRuntime.MavenRuntimeBuilder;
import io.takari.maven.testing.executor.MavenVersions;
import io.takari.maven.testing.executor.junit.MavenJUnitTestRunner;
import java.io.File;
import java.io.IOException;
import java.nio.file.Path;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;

@RunWith( MavenJUnitTestRunner.class )
@MavenVersions( { "3.2.5" } )
public class WagonMojoHttpSettingsIT
public class WagonMojoHttpSettingsIT extends AbstractJettyIT
{
@Rule
public final TestResources resources = new TestResources();

public final MavenRuntime maven;
public MavenRuntime maven;
private final MavenRuntimeBuilder mavenBuilder;

public WagonMojoHttpSettingsIT( MavenRuntimeBuilder builder )
throws Exception
{
this.maven = builder.withCliOptions( "-B", "-e", "-s", "settings.xml" ).build();
this.mavenBuilder = builder.withCliOptions( "-B", "-e", "-s", "settings.xml");
}

@Before
public void setPort() throws Exception {
this.maven = this.mavenBuilder.withCliOptions( "-Dserver.port=" + getServerPort() ).build();
}

@Test
Expand All @@ -39,4 +46,10 @@ public void testDownload()
MavenExecutionResult result = mavenExec.execute( "clean", "verify" );
result.assertErrorFreeLog();
}

@Override
protected Path getDirectoryToServe() throws IOException {
return resources.getBasedir("http-download").toPath()
.resolve("files");
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
empty
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
empty
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
empty
11 changes: 6 additions & 5 deletions src/test/projects/http-download/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
<properties>
<downloadDirectory.base>${project.build.directory}/it/http-download</downloadDirectory.base>
<wagon.api.version>3.0.0</wagon.api.version>
<server.port>8080</server.port>
</properties>

<build>
Expand Down Expand Up @@ -42,7 +43,7 @@
<goal>list</goal>
</goals>
<configuration>
<url>https://repo1.maven.org/maven2/commons-dbutils/commons-dbutils</url>
<url>http://localhost:${server.port}/maven2/commons-dbutils/commons-dbutils</url>
</configuration>
</execution>

Expand All @@ -54,8 +55,8 @@
<goal>download-single</goal>
</goals>
<configuration>
<url>https://repo1.maven.org/maven2/commons-dbutils/commons-dbutils/1.1</url>
<fromFile>commons-dbutils-1.1-sources.jar</fromFile>
<url>http://localhost:${server.port}/maven2/commons-dbutils/commons-dbutils/1.1</url>
<fromFile>commons-dbutils-1.1-sources.txt</fromFile>
<toDir>${downloadDirectory.base}</toDir>
</configuration>
</execution>
Expand All @@ -66,7 +67,7 @@
<goal>download-single</goal>
</goals>
<configuration>
<url>https://repo1.maven.org/maven2/commons-dbutils/commons-dbutils/1.2/commons-dbutils-1.2-sources.jar</url>
<url>http://localhost:${server.port}/maven2/commons-dbutils/commons-dbutils/1.2/commons-dbutils-1.2-sources.txt</url>
<toDir>${downloadDirectory.base}</toDir>
</configuration>
</execution>
Expand All @@ -77,7 +78,7 @@
<goal>download</goal>
</goals>
<configuration>
<url>https://repo1.maven.org/maven2/commons-dbutils/commons-dbutils</url>
<url>http://localhost:${server.port}/maven2/commons-dbutils/commons-dbutils</url>
<includes>1.1/**</includes>
<excludes>1.0/**, 1.2/**, 1.3/**, 1.4/**, 1.5/**, 1.6/**</excludes>
<toDir>${downloadDirectory.base}</toDir>
Expand Down
1 change: 1 addition & 0 deletions src/test/resources/simplelogger.properties
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
org.slf4j.simpleLogger.defaultLogLevel=warn

0 comments on commit 6f174f1

Please sign in to comment.