When test failure occurs, give more details

This commit is contained in:
Joakim Erdfelt 2014-07-31 08:41:35 -07:00
parent 0dbf684298
commit 971e1f0aaa
1 changed files with 84 additions and 32 deletions

View File

@ -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");