提交 6b8b490c 编写于 作者: C chegar

Merge

...@@ -353,7 +353,7 @@ public final class URLPermission extends Permission { ...@@ -353,7 +353,7 @@ public final class URLPermission extends Permission {
return getActions().hashCode() return getActions().hashCode()
+ scheme.hashCode() + scheme.hashCode()
+ authority.hashCode() + authority.hashCode()
+ path == null ? 0 : path.hashCode(); + (path == null ? 0 : path.hashCode());
} }
......
...@@ -26,7 +26,7 @@ import java.io.*; ...@@ -26,7 +26,7 @@ import java.io.*;
/** /**
* @test * @test
* @bug 8010464 * @bug 8010464 8027570
*/ */
public class URLPermissionTest { public class URLPermissionTest {
...@@ -110,6 +110,28 @@ public class URLPermissionTest { ...@@ -110,6 +110,28 @@ public class URLPermissionTest {
return new ActionImpliesTest(arg1, arg2, expected); return new ActionImpliesTest(arg1, arg2, expected);
} }
static class HashCodeTest extends Test {
String arg1, arg2;
int hash;
HashCodeTest(String arg1, String arg2, int hash) {
this.arg1 = arg1;
this.arg2 = arg2;
this.hash = hash;
}
@Override
boolean execute() {
URLPermission p = new URLPermission(arg1, arg2);
int h = p.hashCode();
return h == hash;
}
}
static HashCodeTest hashtest(String arg1, String arg2, int expected) {
return new HashCodeTest(arg1, arg2, expected);
}
static class URLEqualityTest extends Test { static class URLEqualityTest extends Test {
String arg1, arg2; String arg1, arg2;
...@@ -178,6 +200,11 @@ public class URLPermissionTest { ...@@ -178,6 +200,11 @@ public class URLPermissionTest {
extest("http:") extest("http:")
}; };
static Test[] hashTests = {
hashtest("http://www.foo.com/path", "GET:X-Foo", 388644203),
hashtest("http:*", "*:*", 3255810)
};
static Test[] pathImplies2 = { static Test[] pathImplies2 = {
imtest("http://[FE80::]:99", "http://[fe80:0::]:99", true), imtest("http://[FE80::]:99", "http://[fe80:0::]:99", true),
...@@ -326,6 +353,17 @@ public class URLPermissionTest { ...@@ -326,6 +353,17 @@ public class URLPermissionTest {
} }
for (int i=0; i<hashTests.length; i++) {
HashCodeTest test = (HashCodeTest)hashTests[i];
boolean result = test.execute();
if (!result) {
System.out.printf ("test failed: %s %s %d\n", test.arg1, test.arg2, test.hash);
failed = true;
} else {
System.out.println ("hash test " + i + " OK");
}
}
for (int i=0; i<exceptionTests.length; i++) { for (int i=0; i<exceptionTests.length; i++) {
ExTest test = (ExTest)exceptionTests[i]; ExTest test = (ExTest)exceptionTests[i];
boolean result = test.execute(); boolean result = test.execute();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册