create a testrule to get a temp folder with a predictible name

This commit is contained in:
Eric Barboni 2014-09-30 22:39:24 +02:00
parent a2d62a3c0b
commit 705fbd95c4
3 changed files with 128 additions and 48 deletions

View File

@ -39,9 +39,9 @@ import org.junit.Before;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import java.io.File; import java.io.File;
import java.nio.charset.Charset; import java.nio.charset.Charset;
import java.nio.file.Files;
import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThat;
import org.junit.Rule;
/** /**
* AbstractRepositoryServletProxiedTestCase * AbstractRepositoryServletProxiedTestCase
@ -94,6 +94,9 @@ public abstract class AbstractRepositoryServletProxiedTestCase
protected RemoteRepoInfo remoteSnapshots; protected RemoteRepoInfo remoteSnapshots;
@Rule
public ArchivaTemporaryFolderRule repoRootInternali = new ArchivaTemporaryFolderRule();
@Before @Before
@Override @Override
public void setUp() public void setUp()
@ -119,8 +122,8 @@ public abstract class AbstractRepositoryServletProxiedTestCase
RemoteRepoInfo repo = new RemoteRepoInfo(); RemoteRepoInfo repo = new RemoteRepoInfo();
repo.id = id; repo.id = id;
repo.context = "/" + id; repo.context = "/" + id;
repo.root = Files.createTempDirectory( repo.root = repoRootInternali.getRoot();/*Files.createTempDirectory(
"temp" ).toFile();// new File( System.getProperty( "basedir" ) + "target/remote-repos/" + id + "/" ); "temp" ).toFile();*/// new File( System.getProperty( "basedir" ) + "target/remote-repos/" + id + "/" );
// Remove exising root contents. // Remove exising root contents.
if ( repo.root.exists() ) if ( repo.root.exists() )

View File

@ -0,0 +1,86 @@
/*
* Copyright 2014 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.archiva.webdav;
import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import org.apache.commons.io.FileUtils;
import org.junit.rules.TestRule;
import org.junit.runner.Description;
import org.junit.runners.model.Statement;
/**
* Rule to help creating folder for repository based on testmethod name
* @author Eric
*/
public class ArchivaTemporaryFolderRule implements TestRule {
private File d;
private Description desc = Description.EMPTY;
public void before() throws IOException {
// hard coded maven target file
File f1 = new File("target" + File.separator + "archivarepo" + File.separator + ArchivaTemporaryFolderRule.resumepackage(desc.getClassName()) + File.separator + desc.getMethodName());
f1.mkdirs();
Path p = Files.createDirectories(f1.toPath());
d = p.toFile();
}
public File getRoot() {
return d;
}
public void after() throws IOException {
FileUtils.deleteDirectory(getRoot());
}
@Override
public Statement apply(Statement base, Description description) {
desc = description;
return statement(base);
}
private Statement statement(final Statement base) {
return new Statement() {
@Override
public void evaluate() throws Throwable {
before();
try {
base.evaluate();
} finally {
after();
}
}
};
}
/**
* Return a filepath from FQN class name with only first char of package and classname
* @param packagename
* @return
*/
public static String resumepackage(String packagename) {
StringBuilder sb = new StringBuilder();
String[] p = packagename.split("\\.");
for (int i = 0; i < p.length - 2; i++)
{
sb.append(p[i].charAt(0)).append(File.separator);
}
sb.append(p[p.length - 1]);
return sb.toString();
}
}

View File

@ -20,8 +20,6 @@ package org.apache.archiva.webdav;
*/ */
import com.gargoylesoftware.htmlunit.WebRequest;
import com.gargoylesoftware.htmlunit.WebResponse;
import junit.framework.TestCase; import junit.framework.TestCase;
import net.sf.ehcache.CacheManager; import net.sf.ehcache.CacheManager;
import org.apache.archiva.configuration.ArchivaConfiguration; import org.apache.archiva.configuration.ArchivaConfiguration;
@ -42,13 +40,11 @@ import org.apache.archiva.test.utils.ArchivaSpringJUnit4ClassRunner;
import org.apache.archiva.webdav.util.MavenIndexerCleaner; import org.apache.archiva.webdav.util.MavenIndexerCleaner;
import org.apache.commons.io.FileUtils; import org.apache.commons.io.FileUtils;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.commons.lang.StringUtils;
import org.apache.jackrabbit.webdav.DavSessionProvider; import org.apache.jackrabbit.webdav.DavSessionProvider;
import org.easymock.EasyMock; import org.easymock.EasyMock;
import org.easymock.IMocksControl; import org.easymock.IMocksControl;
import org.junit.After; import org.junit.After;
import org.junit.Before; import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test; import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContext;
@ -57,22 +53,22 @@ import org.springframework.mock.web.MockHttpServletResponse;
import org.springframework.mock.web.MockServletConfig; import org.springframework.mock.web.MockServletConfig;
import org.springframework.mock.web.MockServletContext; import org.springframework.mock.web.MockServletContext;
import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.ContextConfiguration;
import org.springframework.web.context.ContextLoaderListener;
import org.springframework.web.context.WebApplicationContext; import org.springframework.web.context.WebApplicationContext;
import javax.inject.Inject; import javax.inject.Inject;
import javax.servlet.Servlet;
import javax.servlet.ServletContext; import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession; import javax.servlet.http.HttpSession;
import java.io.File; import java.io.File;
import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.nio.charset.Charset; import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.List;
import static org.easymock.EasyMock.anyObject; import static org.easymock.EasyMock.anyObject;
import static org.easymock.EasyMock.eq; import static org.easymock.EasyMock.eq;
import org.junit.Rule;
/** /**
* RepositoryServletSecurityTest Test the flow of the authentication and authorization checks. This does not necessarily * RepositoryServletSecurityTest Test the flow of the authentication and authorization checks. This does not necessarily
@ -85,9 +81,6 @@ public class RepositoryServletSecurityTest
{ {
protected static final String REPOID_INTERNAL = "internal"; protected static final String REPOID_INTERNAL = "internal";
protected File repoRootInternal;
@Inject @Inject
protected ArchivaConfiguration archivaConfiguration; protected ArchivaConfiguration archivaConfiguration;
@ -105,12 +98,17 @@ public class RepositoryServletSecurityTest
@Inject @Inject
ApplicationContext applicationContext; ApplicationContext applicationContext;
@Rule
public ArchivaTemporaryFolderRule repoRootInternal = new ArchivaTemporaryFolderRule();
@Before @Before
@Override @Override
public void setUp() public void setUp()
throws Exception throws Exception
{ {
super.setUp(); super.setUp();
String appserverBase = String appserverBase =
@ -119,16 +117,20 @@ public class RepositoryServletSecurityTest
File testConf = new File( "src/test/resources/repository-archiva.xml" ); File testConf = new File( "src/test/resources/repository-archiva.xml" );
File testConfDest = new File( appserverBase, "conf/archiva.xml" ); File testConfDest = new File( appserverBase, "conf/archiva.xml" );
FileUtils.copyFile( testConf, testConfDest ); FileUtils.copyFile( testConf, testConfDest );
repoRootInternal = new File( appserverBase, "data/repositories/internal" );
Configuration config = archivaConfiguration.getConfiguration(); Configuration config = archivaConfiguration.getConfiguration();
// clear managed repository
if ( !config.getManagedRepositoriesAsMap().containsKey( REPOID_INTERNAL ) ) List<ManagedRepositoryConfiguration> f1 = new ArrayList<>(config.getManagedRepositories());
{ for (ManagedRepositoryConfiguration f: f1 ) {
config.addManagedRepository( config.removeManagedRepository(f);
createManagedRepository( REPOID_INTERNAL, "Internal Test Repo", repoRootInternal ) );
} }
assertEquals(0,config.getManagedRepositories().size());
// add internal repo
config.addManagedRepository(
createManagedRepository( REPOID_INTERNAL, "Internal Test Repo", repoRootInternal.getRoot() ) );
saveConfiguration( archivaConfiguration ); saveConfiguration( archivaConfiguration );
CacheManager.getInstance().clearAll(); CacheManager.getInstance().clearAll();
@ -175,27 +177,22 @@ public class RepositoryServletSecurityTest
return repo; return repo;
} }
protected void saveConfiguration() /*protected void saveConfiguration()
throws Exception throws Exception
{ {
saveConfiguration( archivaConfiguration ); saveConfiguration( archivaConfiguration );
} }*/
protected void saveConfiguration( ArchivaConfiguration archivaConfiguration ) protected void saveConfiguration( ArchivaConfiguration archivaConfiguration )
throws Exception throws Exception
{ {
archivaConfiguration.save( archivaConfiguration.getConfiguration() ); archivaConfiguration.save( archivaConfiguration.getConfiguration() );
} }
protected void setupCleanRepo( File repoRootDir ) /*protected void setupCleanRepo( File repoRootDir )
throws IOException throws IOException
{ {
FileUtils.deleteDirectory( repoRootDir ); }*/
if ( !repoRootDir.exists() )
{
repoRootDir.mkdirs();
}
}
@Override @Override
@After @After
@ -203,10 +200,10 @@ public class RepositoryServletSecurityTest
throws Exception throws Exception
{ {
if ( repoRootInternal.exists() ) /* if ( repoRootInternal.exists() )
{ {
FileUtils.deleteDirectory( repoRootInternal ); FileUtils.deleteDirectory( repoRootInternal );
} }*/
applicationContext.getBean( MavenIndexerCleaner.class ).cleanupIndex(); applicationContext.getBean( MavenIndexerCleaner.class ).cleanupIndex();
@ -221,8 +218,7 @@ public class RepositoryServletSecurityTest
public void testPutWithInvalidUserAndGuestHasNoWriteAccess() public void testPutWithInvalidUserAndGuestHasNoWriteAccess()
throws Exception throws Exception
{ {
setupCleanRepo( repoRootInternal );
InputStream is = getClass().getResourceAsStream( "/artifact.jar" ); InputStream is = getClass().getResourceAsStream( "/artifact.jar" );
assertNotNull( "artifact.jar inputstream", is ); assertNotNull( "artifact.jar inputstream", is );
@ -266,8 +262,7 @@ public class RepositoryServletSecurityTest
public void testPutWithInvalidUserAndGuestHasWriteAccess() public void testPutWithInvalidUserAndGuestHasWriteAccess()
throws Exception throws Exception
{ {
setupCleanRepo( repoRootInternal );
servlet.setDavSessionProvider( davSessionProvider ); servlet.setDavSessionProvider( davSessionProvider );
ArchivaDavResourceFactory archivaDavResourceFactory = (ArchivaDavResourceFactory) servlet.getResourceFactory(); ArchivaDavResourceFactory archivaDavResourceFactory = (ArchivaDavResourceFactory) servlet.getResourceFactory();
@ -337,8 +332,7 @@ public class RepositoryServletSecurityTest
public void testPutWithValidUserWithNoWriteAccess() public void testPutWithValidUserWithNoWriteAccess()
throws Exception throws Exception
{ {
setupCleanRepo( repoRootInternal );
servlet.setDavSessionProvider( davSessionProvider ); servlet.setDavSessionProvider( davSessionProvider );
ArchivaDavResourceFactory archivaDavResourceFactory = (ArchivaDavResourceFactory) servlet.getResourceFactory(); ArchivaDavResourceFactory archivaDavResourceFactory = (ArchivaDavResourceFactory) servlet.getResourceFactory();
@ -403,8 +397,7 @@ public class RepositoryServletSecurityTest
public void testPutWithValidUserWithWriteAccess() public void testPutWithValidUserWithWriteAccess()
throws Exception throws Exception
{ {
setupCleanRepo( repoRootInternal ); assertTrue( repoRootInternal.getRoot().exists() );
assertTrue( repoRootInternal.exists() );
MockHttpServletRequest mockHttpServletRequest = new MockHttpServletRequest(); MockHttpServletRequest mockHttpServletRequest = new MockHttpServletRequest();
String putUrl = "http://machine.com/repository/internal/path/to/artifact.jar"; String putUrl = "http://machine.com/repository/internal/path/to/artifact.jar";
@ -480,7 +473,7 @@ public class RepositoryServletSecurityTest
String commonsLangJar = "commons-lang/commons-lang/2.1/commons-lang-2.1.jar"; String commonsLangJar = "commons-lang/commons-lang/2.1/commons-lang-2.1.jar";
String expectedArtifactContents = "dummy-commons-lang-artifact"; String expectedArtifactContents = "dummy-commons-lang-artifact";
File artifactFile = new File( repoRootInternal, commonsLangJar ); File artifactFile = new File( repoRootInternal.getRoot(), commonsLangJar );
artifactFile.getParentFile().mkdirs(); artifactFile.getParentFile().mkdirs();
FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() ); FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() );
@ -532,7 +525,6 @@ public class RepositoryServletSecurityTest
mockHttpServletRequest.setMethod( "GET" ); mockHttpServletRequest.setMethod( "GET" );
mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar ); mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar );
MockHttpServletResponse mockHttpServletResponse = new MockHttpServletResponse(); MockHttpServletResponse mockHttpServletResponse = new MockHttpServletResponse();
servlet.service( mockHttpServletRequest, mockHttpServletResponse ); servlet.service( mockHttpServletRequest, mockHttpServletResponse );
@ -553,7 +545,7 @@ public class RepositoryServletSecurityTest
String commonsLangJar = "commons-lang/commons-lang/2.1/commons-lang-2.1.jar"; String commonsLangJar = "commons-lang/commons-lang/2.1/commons-lang-2.1.jar";
String expectedArtifactContents = "dummy-commons-lang-artifact"; String expectedArtifactContents = "dummy-commons-lang-artifact";
File artifactFile = new File( repoRootInternal, commonsLangJar ); File artifactFile = new File( repoRootInternal.getRoot(), commonsLangJar );
artifactFile.getParentFile().mkdirs(); artifactFile.getParentFile().mkdirs();
FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() ); FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() );
@ -581,7 +573,6 @@ public class RepositoryServletSecurityTest
mockHttpServletRequest.setMethod( "GET" ); mockHttpServletRequest.setMethod( "GET" );
mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar ); mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar );
MockHttpServletResponse mockHttpServletResponse = new MockHttpServletResponse(); MockHttpServletResponse mockHttpServletResponse = new MockHttpServletResponse();
servlet.service( mockHttpServletRequest, mockHttpServletResponse ); servlet.service( mockHttpServletRequest, mockHttpServletResponse );
@ -600,7 +591,7 @@ public class RepositoryServletSecurityTest
String commonsLangJar = "commons-lang/commons-lang/2.1/commons-lang-2.1.jar"; String commonsLangJar = "commons-lang/commons-lang/2.1/commons-lang-2.1.jar";
String expectedArtifactContents = "dummy-commons-lang-artifact"; String expectedArtifactContents = "dummy-commons-lang-artifact";
File artifactFile = new File( repoRootInternal, commonsLangJar ); File artifactFile = new File( repoRootInternal.getRoot(), commonsLangJar );
artifactFile.getParentFile().mkdirs(); artifactFile.getParentFile().mkdirs();
FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() ); FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() );
@ -647,7 +638,6 @@ public class RepositoryServletSecurityTest
mockHttpServletRequest.setMethod( "GET" ); mockHttpServletRequest.setMethod( "GET" );
mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar ); mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar );
MockHttpServletResponse mockHttpServletResponse = new MockHttpServletResponse(); MockHttpServletResponse mockHttpServletResponse = new MockHttpServletResponse();
servlet.service( mockHttpServletRequest, mockHttpServletResponse ); servlet.service( mockHttpServletRequest, mockHttpServletResponse );
@ -667,7 +657,7 @@ public class RepositoryServletSecurityTest
String commonsLangJar = "commons-lang/commons-lang/2.1/commons-lang-2.1.jar"; String commonsLangJar = "commons-lang/commons-lang/2.1/commons-lang-2.1.jar";
String expectedArtifactContents = "dummy-commons-lang-artifact"; String expectedArtifactContents = "dummy-commons-lang-artifact";
File artifactFile = new File( repoRootInternal, commonsLangJar ); File artifactFile = new File( repoRootInternal.getRoot(), commonsLangJar );
artifactFile.getParentFile().mkdirs(); artifactFile.getParentFile().mkdirs();
FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() ); FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() );
@ -725,4 +715,5 @@ public class RepositoryServletSecurityTest
assertEquals( HttpServletResponse.SC_UNAUTHORIZED, mockHttpServletResponse.getStatus() ); assertEquals( HttpServletResponse.SC_UNAUTHORIZED, mockHttpServletResponse.getStatus() );
} }
} }