When test failure occurs, give more details
This commit is contained in:
parent
0dbf684298
commit
971e1f0aaa
|
@ -43,14 +43,15 @@ import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import javax.management.RuntimeErrorException;
|
|
||||||
|
|
||||||
import org.eclipse.jetty.toolchain.test.FS;
|
import org.eclipse.jetty.toolchain.test.FS;
|
||||||
import org.eclipse.jetty.toolchain.test.IO;
|
import org.eclipse.jetty.toolchain.test.IO;
|
||||||
import org.eclipse.jetty.toolchain.test.OS;
|
import org.eclipse.jetty.toolchain.test.OS;
|
||||||
import org.eclipse.jetty.toolchain.test.TestingDir;
|
import org.eclipse.jetty.toolchain.test.TestingDir;
|
||||||
import org.eclipse.jetty.util.BufferUtil;
|
import org.eclipse.jetty.util.BufferUtil;
|
||||||
import org.eclipse.jetty.util.CollectionAssert;
|
import org.eclipse.jetty.util.CollectionAssert;
|
||||||
|
import org.hamcrest.BaseMatcher;
|
||||||
|
import org.hamcrest.Description;
|
||||||
|
import org.hamcrest.Matcher;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
@ -65,7 +66,7 @@ public class FileSystemResourceTest
|
||||||
|
|
||||||
private final Class<? extends Resource> _class;
|
private final Class<? extends Resource> _class;
|
||||||
|
|
||||||
@Parameters
|
@Parameters(name="{0}")
|
||||||
public static Collection<Object[]> data()
|
public static Collection<Object[]> data()
|
||||||
{
|
{
|
||||||
List<Object[]> data = new ArrayList<>();
|
List<Object[]> data = new ArrayList<>();
|
||||||
|
@ -126,6 +127,56 @@ public class FileSystemResourceTest
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Matcher<Resource> hasNoAlias()
|
||||||
|
{
|
||||||
|
return new BaseMatcher<Resource>()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public boolean matches(Object item)
|
||||||
|
{
|
||||||
|
final Resource res = (Resource)item;
|
||||||
|
return res.getAlias() == null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void describeTo(Description description)
|
||||||
|
{
|
||||||
|
description.appendText("getAlias should return null");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void describeMismatch(Object item, Description description)
|
||||||
|
{
|
||||||
|
description.appendText("was").appendValue(((Resource)item).getAlias());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
private Matcher<Resource> isAliasFor(final Resource resource)
|
||||||
|
{
|
||||||
|
return new BaseMatcher<Resource>()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public boolean matches(Object item)
|
||||||
|
{
|
||||||
|
final Resource alias = (Resource)item;
|
||||||
|
return alias.getAlias().equals(resource.getURI());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void describeTo(Description description)
|
||||||
|
{
|
||||||
|
description.appendText("getAlias should return ").appendValue(resource.getURI());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void describeMismatch(Object item, Description description)
|
||||||
|
{
|
||||||
|
description.appendText("was").appendValue(((Resource)item).getAlias());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
private URI createEmptyFile(String name) throws IOException
|
private URI createEmptyFile(String name) throws IOException
|
||||||
{
|
{
|
||||||
File file = testdir.getFile(name);
|
File file = testdir.getFile(name);
|
||||||
|
@ -425,16 +476,18 @@ public class FileSystemResourceTest
|
||||||
Resource resFoo = base.addPath("foo");
|
Resource resFoo = base.addPath("foo");
|
||||||
Resource resBar = base.addPath("bar");
|
Resource resBar = base.addPath("bar");
|
||||||
|
|
||||||
|
assertThat("resFoo.uri", resFoo.getURI(), is(foo.toUri()));
|
||||||
|
|
||||||
// Access to the same resource, but via a symlink means that they are not equivalent
|
// Access to the same resource, but via a symlink means that they are not equivalent
|
||||||
assertThat("foo.equals(bar)", resFoo.equals(resBar), is(false));
|
assertThat("foo.equals(bar)", resFoo.equals(resBar), is(false));
|
||||||
|
|
||||||
assertThat("foo !alias", resFoo.getAlias(), nullValue());
|
assertThat("resource.alias", resFoo, hasNoAlias());
|
||||||
assertThat(newResource(resFoo.getURI()).getAlias(), nullValue());
|
assertThat("resource.uri.alias", newResource(resFoo.getURI()), hasNoAlias());
|
||||||
assertThat(newResource(resFoo.getFile()).getAlias(), nullValue());
|
assertThat("resource.file.alias", newResource(resFoo.getFile()), hasNoAlias());
|
||||||
|
|
||||||
assertThat("bar alias", resBar.getAlias(), is(foo.toUri()));
|
assertThat("alias", resBar, isAliasFor(resFoo));
|
||||||
assertThat(newResource(resBar.getURI()).getAlias(), is(foo.toUri()));
|
assertThat("uri.alias", newResource(resBar.getURI()), isAliasFor(resFoo));
|
||||||
assertThat(newResource(resBar.getFile()).getAlias(), is(foo.toUri()));
|
assertThat("file.alias", newResource(resBar.getFile()), isAliasFor(resFoo));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -450,17 +503,17 @@ public class FileSystemResourceTest
|
||||||
{
|
{
|
||||||
Resource resource = base.addPath("file");
|
Resource resource = base.addPath("file");
|
||||||
|
|
||||||
assertThat("!alias", resource.getAlias(), nullValue());
|
assertThat("resource.alias", resource, hasNoAlias());
|
||||||
assertThat(newResource(resource.getURI()).getAlias(), nullValue());
|
assertThat("resource.uri.alias", newResource(resource.getURI()), hasNoAlias());
|
||||||
assertThat(newResource(resource.getFile()).getAlias(), nullValue());
|
assertThat("resource.file.alias", newResource(resource.getFile()), hasNoAlias());
|
||||||
|
|
||||||
Resource alias = base.addPath("FILE");
|
Resource alias = base.addPath("FILE");
|
||||||
if (alias.exists())
|
if (alias.exists())
|
||||||
{
|
{
|
||||||
// If it exists, it must be an alias
|
// If it exists, it must be an alias
|
||||||
assertThat(alias.getAlias(), is(path.toUri()));
|
assertThat("alias", alias, isAliasFor(resource));
|
||||||
assertThat(newResource(alias.getURI()).getAlias(), is(path.toUri()));
|
assertThat("alias.uri", newResource(alias.getURI()), isAliasFor(resource));
|
||||||
assertThat(newResource(alias.getFile()).getAlias(), is(path.toUri()));
|
assertThat("alias.file", newResource(alias.getFile()), isAliasFor(resource));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -476,17 +529,17 @@ public class FileSystemResourceTest
|
||||||
{
|
{
|
||||||
Resource resource = base.addPath("TextFile.Long.txt");
|
Resource resource = base.addPath("TextFile.Long.txt");
|
||||||
|
|
||||||
assertThat("!alias", resource.getAlias(), nullValue());
|
assertThat("resource.alias", resource, hasNoAlias());
|
||||||
assertThat(newResource(resource.getURI()).getAlias(), nullValue());
|
assertThat("resource.uri.alias", newResource(resource.getURI()), hasNoAlias());
|
||||||
assertThat(newResource(resource.getFile()).getAlias(), nullValue());
|
assertThat("resource.file.alias", newResource(resource.getFile()), hasNoAlias());
|
||||||
|
|
||||||
Resource alias = base.addPath("TEXTFI~1.TXT");
|
Resource alias = base.addPath("TEXTFI~1.TXT");
|
||||||
if (alias.exists())
|
if (alias.exists())
|
||||||
{
|
{
|
||||||
// If it exists, it must be an alias
|
// If it exists, it must be an alias
|
||||||
assertThat(alias.getAlias(), is(path.toUri()));
|
assertThat("alias", alias, isAliasFor(resource));
|
||||||
assertThat(newResource(alias.getURI()).getAlias(), is(path.toUri()));
|
assertThat("alias.uri", newResource(alias.getURI()), isAliasFor(resource));
|
||||||
assertThat(newResource(alias.getFile()).getAlias(), is(path.toUri()));
|
assertThat("alias.file", newResource(alias.getFile()), isAliasFor(resource));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -502,22 +555,21 @@ public class FileSystemResourceTest
|
||||||
{
|
{
|
||||||
Resource resource = base.addPath("file");
|
Resource resource = base.addPath("file");
|
||||||
|
|
||||||
assertThat("!alias", resource.getAlias(), nullValue());
|
assertThat("resource.alias", resource, hasNoAlias());
|
||||||
assertThat(newResource(resource.getURI()).getAlias(), nullValue());
|
assertThat("resource.uri.alias", newResource(resource.getURI()), hasNoAlias());
|
||||||
assertThat(newResource(resource.getFile()).getAlias(), nullValue());
|
assertThat("resource.file.alias", newResource(resource.getFile()), hasNoAlias());
|
||||||
|
|
||||||
Resource alias = base.addPath("file::$DATA");
|
Resource alias = base.addPath("file::$DATA");
|
||||||
if (alias.exists())
|
if (alias.exists())
|
||||||
{
|
{
|
||||||
// If it exists, it must be an alias
|
// If it exists, it must be an alias
|
||||||
assertThat(alias.getAlias(), is(path.toUri()));
|
assertThat("resource.alias", alias, isAliasFor(resource));
|
||||||
assertThat(newResource(alias.getURI()).getAlias(), is(path.toUri()));
|
assertThat("resource.uri.alias", newResource(alias.getURI()), isAliasFor(resource));
|
||||||
assertThat(newResource(alias.getFile()).getAlias(), is(path.toUri()));
|
assertThat("resource.file.alias", newResource(alias.getFile()), isAliasFor(resource));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSemicolon() throws Exception
|
public void testSemicolon() throws Exception
|
||||||
{
|
{
|
||||||
|
@ -566,7 +618,7 @@ public class FileSystemResourceTest
|
||||||
try (Resource fileres = newResource(refQuoted))
|
try (Resource fileres = newResource(refQuoted))
|
||||||
{
|
{
|
||||||
assertThat("Exists: " + refQuoted,fileres.exists(),is(true));
|
assertThat("Exists: " + refQuoted,fileres.exists(),is(true));
|
||||||
assertThat("Alias: " + refQuoted,fileres.getAlias(),nullValue());
|
assertThat("Alias: " + refQuoted,fileres,hasNoAlias());
|
||||||
}
|
}
|
||||||
|
|
||||||
URI refEncoded = testdir.getDir().toURI().resolve("foo%27s.txt");
|
URI refEncoded = testdir.getDir().toURI().resolve("foo%27s.txt");
|
||||||
|
@ -574,7 +626,7 @@ public class FileSystemResourceTest
|
||||||
try (Resource fileres = newResource(refEncoded))
|
try (Resource fileres = newResource(refEncoded))
|
||||||
{
|
{
|
||||||
assertThat("Exists: " + refEncoded,fileres.exists(),is(true));
|
assertThat("Exists: " + refEncoded,fileres.exists(),is(true));
|
||||||
assertThat("Alias: " + refEncoded,fileres.getAlias(),nullValue());
|
assertThat("Alias: " + refEncoded,fileres,hasNoAlias());
|
||||||
}
|
}
|
||||||
|
|
||||||
URI refQuoteSpace = testdir.getDir().toURI().resolve("f%20o's.txt");
|
URI refQuoteSpace = testdir.getDir().toURI().resolve("f%20o's.txt");
|
||||||
|
@ -582,7 +634,7 @@ public class FileSystemResourceTest
|
||||||
try (Resource fileres = newResource(refQuoteSpace))
|
try (Resource fileres = newResource(refQuoteSpace))
|
||||||
{
|
{
|
||||||
assertThat("Exists: " + refQuoteSpace,fileres.exists(),is(true));
|
assertThat("Exists: " + refQuoteSpace,fileres.exists(),is(true));
|
||||||
assertThat("Alias: " + refQuoteSpace,fileres.getAlias(),nullValue());
|
assertThat("Alias: " + refQuoteSpace,fileres,hasNoAlias());
|
||||||
}
|
}
|
||||||
|
|
||||||
URI refEncodedSpace = testdir.getDir().toURI().resolve("f%20o%27s.txt");
|
URI refEncodedSpace = testdir.getDir().toURI().resolve("f%20o%27s.txt");
|
||||||
|
@ -590,7 +642,7 @@ public class FileSystemResourceTest
|
||||||
try (Resource fileres = newResource(refEncodedSpace))
|
try (Resource fileres = newResource(refEncodedSpace))
|
||||||
{
|
{
|
||||||
assertThat("Exists: " + refEncodedSpace,fileres.exists(),is(true));
|
assertThat("Exists: " + refEncodedSpace,fileres.exists(),is(true));
|
||||||
assertThat("Alias: " + refEncodedSpace,fileres.getAlias(),nullValue());
|
assertThat("Alias: " + refEncodedSpace,fileres,hasNoAlias());
|
||||||
}
|
}
|
||||||
|
|
||||||
URI refA = testdir.getDir().toURI().resolve("foo's.txt");
|
URI refA = testdir.getDir().toURI().resolve("foo's.txt");
|
||||||
|
|
Loading…
Reference in New Issue