mirror of https://github.com/apache/archiva.git
create a testrule to get a temp folder with a predictible name
This commit is contained in:
parent
a2d62a3c0b
commit
705fbd95c4
|
@ -39,9 +39,9 @@ import org.junit.Before;
|
|||
import javax.servlet.http.HttpServletResponse;
|
||||
import java.io.File;
|
||||
import java.nio.charset.Charset;
|
||||
import java.nio.file.Files;
|
||||
|
||||
import static org.assertj.core.api.Assertions.assertThat;
|
||||
import org.junit.Rule;
|
||||
|
||||
/**
|
||||
* AbstractRepositoryServletProxiedTestCase
|
||||
|
@ -94,6 +94,9 @@ public abstract class AbstractRepositoryServletProxiedTestCase
|
|||
|
||||
protected RemoteRepoInfo remoteSnapshots;
|
||||
|
||||
@Rule
|
||||
public ArchivaTemporaryFolderRule repoRootInternali = new ArchivaTemporaryFolderRule();
|
||||
|
||||
@Before
|
||||
@Override
|
||||
public void setUp()
|
||||
|
@ -119,8 +122,8 @@ public abstract class AbstractRepositoryServletProxiedTestCase
|
|||
RemoteRepoInfo repo = new RemoteRepoInfo();
|
||||
repo.id = id;
|
||||
repo.context = "/" + id;
|
||||
repo.root = Files.createTempDirectory(
|
||||
"temp" ).toFile();// new File( System.getProperty( "basedir" ) + "target/remote-repos/" + id + "/" );
|
||||
repo.root = repoRootInternali.getRoot();/*Files.createTempDirectory(
|
||||
"temp" ).toFile();*/// new File( System.getProperty( "basedir" ) + "target/remote-repos/" + id + "/" );
|
||||
|
||||
// Remove exising root contents.
|
||||
if ( repo.root.exists() )
|
||||
|
|
|
@ -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();
|
||||
}
|
||||
|
||||
}
|
|
@ -20,8 +20,6 @@ package org.apache.archiva.webdav;
|
|||
*/
|
||||
|
||||
|
||||
import com.gargoylesoftware.htmlunit.WebRequest;
|
||||
import com.gargoylesoftware.htmlunit.WebResponse;
|
||||
import junit.framework.TestCase;
|
||||
import net.sf.ehcache.CacheManager;
|
||||
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.commons.io.FileUtils;
|
||||
import org.apache.commons.io.IOUtils;
|
||||
import org.apache.commons.lang.StringUtils;
|
||||
import org.apache.jackrabbit.webdav.DavSessionProvider;
|
||||
import org.easymock.EasyMock;
|
||||
import org.easymock.IMocksControl;
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.Ignore;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
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.MockServletContext;
|
||||
import org.springframework.test.context.ContextConfiguration;
|
||||
import org.springframework.web.context.ContextLoaderListener;
|
||||
import org.springframework.web.context.WebApplicationContext;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.servlet.Servlet;
|
||||
import javax.servlet.ServletContext;
|
||||
import javax.servlet.http.HttpServletRequest;
|
||||
import javax.servlet.http.HttpServletResponse;
|
||||
import javax.servlet.http.HttpSession;
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.nio.charset.Charset;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import static org.easymock.EasyMock.anyObject;
|
||||
import static org.easymock.EasyMock.eq;
|
||||
import org.junit.Rule;
|
||||
|
||||
/**
|
||||
* 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 File repoRootInternal;
|
||||
|
||||
@Inject
|
||||
protected ArchivaConfiguration archivaConfiguration;
|
||||
|
||||
|
@ -106,11 +99,16 @@ public class RepositoryServletSecurityTest
|
|||
@Inject
|
||||
ApplicationContext applicationContext;
|
||||
|
||||
|
||||
@Rule
|
||||
public ArchivaTemporaryFolderRule repoRootInternal = new ArchivaTemporaryFolderRule();
|
||||
|
||||
@Before
|
||||
@Override
|
||||
public void setUp()
|
||||
throws Exception
|
||||
{
|
||||
|
||||
super.setUp();
|
||||
|
||||
String appserverBase =
|
||||
|
@ -120,15 +118,19 @@ public class RepositoryServletSecurityTest
|
|||
File testConfDest = new File( appserverBase, "conf/archiva.xml" );
|
||||
FileUtils.copyFile( testConf, testConfDest );
|
||||
|
||||
repoRootInternal = new File( appserverBase, "data/repositories/internal" );
|
||||
|
||||
|
||||
Configuration config = archivaConfiguration.getConfiguration();
|
||||
|
||||
if ( !config.getManagedRepositoriesAsMap().containsKey( REPOID_INTERNAL ) )
|
||||
{
|
||||
config.addManagedRepository(
|
||||
createManagedRepository( REPOID_INTERNAL, "Internal Test Repo", repoRootInternal ) );
|
||||
// clear managed repository
|
||||
List<ManagedRepositoryConfiguration> f1 = new ArrayList<>(config.getManagedRepositories());
|
||||
for (ManagedRepositoryConfiguration f: f1 ) {
|
||||
config.removeManagedRepository(f);
|
||||
}
|
||||
assertEquals(0,config.getManagedRepositories().size());
|
||||
// add internal repo
|
||||
config.addManagedRepository(
|
||||
createManagedRepository( REPOID_INTERNAL, "Internal Test Repo", repoRootInternal.getRoot() ) );
|
||||
|
||||
saveConfiguration( archivaConfiguration );
|
||||
|
||||
CacheManager.getInstance().clearAll();
|
||||
|
@ -175,11 +177,11 @@ public class RepositoryServletSecurityTest
|
|||
return repo;
|
||||
}
|
||||
|
||||
protected void saveConfiguration()
|
||||
/*protected void saveConfiguration()
|
||||
throws Exception
|
||||
{
|
||||
saveConfiguration( archivaConfiguration );
|
||||
}
|
||||
}*/
|
||||
|
||||
protected void saveConfiguration( ArchivaConfiguration archivaConfiguration )
|
||||
throws Exception
|
||||
|
@ -187,15 +189,10 @@ public class RepositoryServletSecurityTest
|
|||
archivaConfiguration.save( archivaConfiguration.getConfiguration() );
|
||||
}
|
||||
|
||||
protected void setupCleanRepo( File repoRootDir )
|
||||
/*protected void setupCleanRepo( File repoRootDir )
|
||||
throws IOException
|
||||
{
|
||||
FileUtils.deleteDirectory( repoRootDir );
|
||||
if ( !repoRootDir.exists() )
|
||||
{
|
||||
repoRootDir.mkdirs();
|
||||
}
|
||||
}
|
||||
}*/
|
||||
|
||||
@Override
|
||||
@After
|
||||
|
@ -203,10 +200,10 @@ public class RepositoryServletSecurityTest
|
|||
throws Exception
|
||||
{
|
||||
|
||||
if ( repoRootInternal.exists() )
|
||||
/* if ( repoRootInternal.exists() )
|
||||
{
|
||||
FileUtils.deleteDirectory( repoRootInternal );
|
||||
}
|
||||
}*/
|
||||
|
||||
applicationContext.getBean( MavenIndexerCleaner.class ).cleanupIndex();
|
||||
|
||||
|
@ -221,7 +218,6 @@ public class RepositoryServletSecurityTest
|
|||
public void testPutWithInvalidUserAndGuestHasNoWriteAccess()
|
||||
throws Exception
|
||||
{
|
||||
setupCleanRepo( repoRootInternal );
|
||||
|
||||
InputStream is = getClass().getResourceAsStream( "/artifact.jar" );
|
||||
assertNotNull( "artifact.jar inputstream", is );
|
||||
|
@ -266,7 +262,6 @@ public class RepositoryServletSecurityTest
|
|||
public void testPutWithInvalidUserAndGuestHasWriteAccess()
|
||||
throws Exception
|
||||
{
|
||||
setupCleanRepo( repoRootInternal );
|
||||
|
||||
servlet.setDavSessionProvider( davSessionProvider );
|
||||
|
||||
|
@ -337,7 +332,6 @@ public class RepositoryServletSecurityTest
|
|||
public void testPutWithValidUserWithNoWriteAccess()
|
||||
throws Exception
|
||||
{
|
||||
setupCleanRepo( repoRootInternal );
|
||||
|
||||
servlet.setDavSessionProvider( davSessionProvider );
|
||||
|
||||
|
@ -403,8 +397,7 @@ public class RepositoryServletSecurityTest
|
|||
public void testPutWithValidUserWithWriteAccess()
|
||||
throws Exception
|
||||
{
|
||||
setupCleanRepo( repoRootInternal );
|
||||
assertTrue( repoRootInternal.exists() );
|
||||
assertTrue( repoRootInternal.getRoot().exists() );
|
||||
|
||||
MockHttpServletRequest mockHttpServletRequest = new MockHttpServletRequest();
|
||||
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 expectedArtifactContents = "dummy-commons-lang-artifact";
|
||||
|
||||
File artifactFile = new File( repoRootInternal, commonsLangJar );
|
||||
File artifactFile = new File( repoRootInternal.getRoot(), commonsLangJar );
|
||||
artifactFile.getParentFile().mkdirs();
|
||||
|
||||
FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() );
|
||||
|
@ -532,7 +525,6 @@ public class RepositoryServletSecurityTest
|
|||
mockHttpServletRequest.setMethod( "GET" );
|
||||
mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar );
|
||||
|
||||
|
||||
MockHttpServletResponse mockHttpServletResponse = new 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 expectedArtifactContents = "dummy-commons-lang-artifact";
|
||||
|
||||
File artifactFile = new File( repoRootInternal, commonsLangJar );
|
||||
File artifactFile = new File( repoRootInternal.getRoot(), commonsLangJar );
|
||||
artifactFile.getParentFile().mkdirs();
|
||||
|
||||
FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() );
|
||||
|
@ -581,7 +573,6 @@ public class RepositoryServletSecurityTest
|
|||
mockHttpServletRequest.setMethod( "GET" );
|
||||
mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar );
|
||||
|
||||
|
||||
MockHttpServletResponse mockHttpServletResponse = new 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 expectedArtifactContents = "dummy-commons-lang-artifact";
|
||||
|
||||
File artifactFile = new File( repoRootInternal, commonsLangJar );
|
||||
File artifactFile = new File( repoRootInternal.getRoot(), commonsLangJar );
|
||||
artifactFile.getParentFile().mkdirs();
|
||||
|
||||
FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() );
|
||||
|
@ -647,7 +638,6 @@ public class RepositoryServletSecurityTest
|
|||
mockHttpServletRequest.setMethod( "GET" );
|
||||
mockHttpServletRequest.setRequestURI( "/repository/internal/" + commonsLangJar );
|
||||
|
||||
|
||||
MockHttpServletResponse mockHttpServletResponse = new 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 expectedArtifactContents = "dummy-commons-lang-artifact";
|
||||
|
||||
File artifactFile = new File( repoRootInternal, commonsLangJar );
|
||||
File artifactFile = new File( repoRootInternal.getRoot(), commonsLangJar );
|
||||
artifactFile.getParentFile().mkdirs();
|
||||
|
||||
FileUtils.writeStringToFile( artifactFile, expectedArtifactContents, Charset.defaultCharset() );
|
||||
|
@ -725,4 +715,5 @@ public class RepositoryServletSecurityTest
|
|||
|
||||
assertEquals( HttpServletResponse.SC_UNAUTHORIZED, mockHttpServletResponse.getStatus() );
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue