Minor bug fixes; more test coverage
git-svn-id: https://svn.apache.org/repos/asf/jakarta/httpcomponents/httpclient/trunk@409996 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
7d7da3d68b
commit
cd657a4939
|
@ -68,9 +68,6 @@ public class BasicPathHandler implements CookieAttributeHandler {
|
||||||
throw new IllegalArgumentException("Cookie origin may not be null");
|
throw new IllegalArgumentException("Cookie origin may not be null");
|
||||||
}
|
}
|
||||||
String targetpath = origin.getPath();
|
String targetpath = origin.getPath();
|
||||||
if (targetpath == null) {
|
|
||||||
targetpath = "/";
|
|
||||||
}
|
|
||||||
String topmostPath = cookie.getPath();
|
String topmostPath = cookie.getPath();
|
||||||
if (topmostPath == null) {
|
if (topmostPath == null) {
|
||||||
topmostPath = "/";
|
topmostPath = "/";
|
||||||
|
|
|
@ -83,7 +83,7 @@ public class BrowserCompatSpec extends CookieSpecBase {
|
||||||
if (header == null) {
|
if (header == null) {
|
||||||
throw new IllegalArgumentException("Header may not be null");
|
throw new IllegalArgumentException("Header may not be null");
|
||||||
}
|
}
|
||||||
if (header == null) {
|
if (origin == null) {
|
||||||
throw new IllegalArgumentException("Cookie origin may not be null");
|
throw new IllegalArgumentException("Cookie origin may not be null");
|
||||||
}
|
}
|
||||||
String headervalue = header.getValue();
|
String headervalue = header.getValue();
|
||||||
|
|
|
@ -103,9 +103,6 @@ public abstract class CookieSpecBase extends AbstractCookieSpec {
|
||||||
if (origin == null) {
|
if (origin == null) {
|
||||||
throw new IllegalArgumentException("Cookie origin may not be null");
|
throw new IllegalArgumentException("Cookie origin may not be null");
|
||||||
}
|
}
|
||||||
if (cookie.getName() == null || cookie.getName().trim().equals("")) {
|
|
||||||
throw new MalformedCookieException("Cookie name may not be blank");
|
|
||||||
}
|
|
||||||
for (Iterator i = getAttribHandlerIterator(); i.hasNext();) {
|
for (Iterator i = getAttribHandlerIterator(); i.hasNext();) {
|
||||||
CookieAttributeHandler handler = (CookieAttributeHandler) i.next();
|
CookieAttributeHandler handler = (CookieAttributeHandler) i.next();
|
||||||
handler.validate(cookie, origin);
|
handler.validate(cookie, origin);
|
||||||
|
|
|
@ -553,6 +553,23 @@ public class TestBrowserCompatSpec extends TestCase {
|
||||||
assertEquals(1, parsed.length);
|
assertEquals(1, parsed.length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests if cookie constructor rejects cookie name containing blanks.
|
||||||
|
*/
|
||||||
|
public void testCookieNameBlank() throws Exception {
|
||||||
|
Header header = new Header("Set-Cookie", "=stuff");
|
||||||
|
CookieSpec cookiespec = new BrowserCompatSpec();
|
||||||
|
CookieOrigin origin = new CookieOrigin("127.0.0.1", 80, "/", false);
|
||||||
|
try {
|
||||||
|
Cookie[] parsed = cookiespec.parse(header, origin);
|
||||||
|
for (int i = 0; i < parsed.length; i++) {
|
||||||
|
cookiespec.validate(parsed[i], origin);
|
||||||
|
}
|
||||||
|
fail("MalformedCookieException should have been thrown");
|
||||||
|
} catch (MalformedCookieException expected) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests if cookie constructor rejects cookie name starting with $.
|
* Tests if cookie constructor rejects cookie name starting with $.
|
||||||
*/
|
*/
|
||||||
|
@ -885,5 +902,56 @@ public class TestBrowserCompatSpec extends TestCase {
|
||||||
new MalformedCookieException("whatever", null);
|
new MalformedCookieException("whatever", null);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
public void testInvalidInput() throws Exception {
|
||||||
|
CookieSpec cookiespec = new BrowserCompatSpec();
|
||||||
|
try {
|
||||||
|
cookiespec.parse(null, null);
|
||||||
|
fail("IllegalArgumentException must have been thrown");
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
cookiespec.parse(new Header("Set-Cookie", "name=value"), null);
|
||||||
|
fail("IllegalArgumentException must have been thrown");
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
cookiespec.validate(null, null);
|
||||||
|
fail("IllegalArgumentException must have been thrown");
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
cookiespec.validate(new Cookie("name", null), null);
|
||||||
|
fail("IllegalArgumentException must have been thrown");
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
cookiespec.match(null, null);
|
||||||
|
fail("IllegalArgumentException must have been thrown");
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
cookiespec.match(new Cookie("name", null), null);
|
||||||
|
fail("IllegalArgumentException must have been thrown");
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
cookiespec.formatCookies(null);
|
||||||
|
fail("IllegalArgumentException must have been thrown");
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
cookiespec.formatCookies(new Cookie[] {});
|
||||||
|
fail("IllegalArgumentException must have been thrown");
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue