Browse Source

Update MockCookie to use Servlet 6.0 APIs and semantics for "attributes"

Closes gh-30263
pull/30283/head
Justin Tay 3 years ago committed by Sam Brannen
parent
commit
281736f14e
  1. 31
      spring-test/src/main/java/org/springframework/mock/web/MockCookie.java
  2. 65
      spring-test/src/test/java/org/springframework/mock/web/MockCookieTests.java

31
spring-test/src/main/java/org/springframework/mock/web/MockCookie.java

@ -39,16 +39,14 @@ import org.springframework.util.StringUtils; @@ -39,16 +39,14 @@ import org.springframework.util.StringUtils;
@SuppressWarnings("removal")
public class MockCookie extends Cookie {
private static final long serialVersionUID = 4312531139502726325L;
private static final long serialVersionUID = 1198809317225300389L;
private static final String SAME_SITE = "SameSite";
private static final String EXPIRES = "Expires";
@Nullable
private ZonedDateTime expires;
@Nullable
private String sameSite;
/**
* Construct a new {@link MockCookie} with the supplied name and value.
* @param name the name
@ -64,7 +62,7 @@ public class MockCookie extends Cookie { @@ -64,7 +62,7 @@ public class MockCookie extends Cookie {
* @since 5.1.11
*/
public void setExpires(@Nullable ZonedDateTime expires) {
this.expires = expires;
setAttribute(EXPIRES, expires != null ? expires.format(DateTimeFormatter.RFC_1123_DATE_TIME) : null);
}
/**
@ -85,7 +83,7 @@ public class MockCookie extends Cookie { @@ -85,7 +83,7 @@ public class MockCookie extends Cookie {
* @see <a href="https://tools.ietf.org/html/draft-ietf-httpbis-rfc6265bis#section-4.1.2.7">RFC6265 bis</a>
*/
public void setSameSite(@Nullable String sameSite) {
this.sameSite = sameSite;
setAttribute(SAME_SITE, sameSite);
}
/**
@ -94,10 +92,9 @@ public class MockCookie extends Cookie { @@ -94,10 +92,9 @@ public class MockCookie extends Cookie {
*/
@Nullable
public String getSameSite() {
return this.sameSite;
return getAttribute(SAME_SITE);
}
/**
* Factory method that parses the value of the supplied "Set-Cookie" header.
* @param setCookieHeader the "Set-Cookie" value; never {@code null} or empty
@ -122,7 +119,7 @@ public class MockCookie extends Cookie { @@ -122,7 +119,7 @@ public class MockCookie extends Cookie {
else if (StringUtils.startsWithIgnoreCase(attribute, "Max-Age")) {
cookie.setMaxAge(Integer.parseInt(extractAttributeValue(attribute, setCookieHeader)));
}
else if (StringUtils.startsWithIgnoreCase(attribute, "Expires")) {
else if (StringUtils.startsWithIgnoreCase(attribute, EXPIRES)) {
try {
cookie.setExpires(ZonedDateTime.parse(extractAttributeValue(attribute, setCookieHeader),
DateTimeFormatter.RFC_1123_DATE_TIME));
@ -140,7 +137,7 @@ public class MockCookie extends Cookie { @@ -140,7 +137,7 @@ public class MockCookie extends Cookie {
else if (StringUtils.startsWithIgnoreCase(attribute, "HttpOnly")) {
cookie.setHttpOnly(true);
}
else if (StringUtils.startsWithIgnoreCase(attribute, "SameSite")) {
else if (StringUtils.startsWithIgnoreCase(attribute, SAME_SITE)) {
cookie.setSameSite(extractAttributeValue(attribute, setCookieHeader));
}
else if (StringUtils.startsWithIgnoreCase(attribute, "Comment")) {
@ -157,6 +154,14 @@ public class MockCookie extends Cookie { @@ -157,6 +154,14 @@ public class MockCookie extends Cookie {
return nameAndValue[1];
}
@Override
public void setAttribute(String name, @Nullable String value) {
if(EXPIRES.equalsIgnoreCase(name)) {
this.expires = value != null ? ZonedDateTime.parse(value, DateTimeFormatter.RFC_1123_DATE_TIME) : null;
}
super.setAttribute(name, value);
}
@Override
public String toString() {
return new ToStringCreator(this)
@ -168,9 +173,9 @@ public class MockCookie extends Cookie { @@ -168,9 +173,9 @@ public class MockCookie extends Cookie {
.append("Comment", getComment())
.append("Secure", getSecure())
.append("HttpOnly", isHttpOnly())
.append("SameSite", this.sameSite)
.append(SAME_SITE, getSameSite())
.append("Max-Age", getMaxAge())
.append("Expires", (this.expires != null ?
.append(EXPIRES, (this.expires != null ?
DateTimeFormatter.RFC_1123_DATE_TIME.format(this.expires) : null))
.toString();
}

65
spring-test/src/test/java/org/springframework/mock/web/MockCookieTests.java

@ -18,6 +18,7 @@ package org.springframework.mock.web; @@ -18,6 +18,7 @@ package org.springframework.mock.web;
import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;
import java.time.format.DateTimeParseException;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.params.ParameterizedTest;
@ -25,6 +26,7 @@ import org.junit.jupiter.params.provider.ValueSource; @@ -25,6 +26,7 @@ import org.junit.jupiter.params.provider.ValueSource;
import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatIllegalArgumentException;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
/**
* Unit tests for {@link MockCookie}.
@ -136,4 +138,67 @@ class MockCookieTests { @@ -136,4 +138,67 @@ class MockCookieTests {
assertThat(cookie.getSameSite()).isEqualTo("Lax");
}
@Test
void setSameSiteShouldSetAttribute() {
MockCookie cookie = new MockCookie("SESSION", "123");
cookie.setSameSite("Strict");
assertThat(cookie.getAttribute("samesite")).isEqualTo("Strict");
}
@Test
void setExpiresShouldSetAttribute() {
MockCookie cookie = new MockCookie("SESSION", "123");
cookie.setExpires(ZonedDateTime.parse("Tue, 8 Oct 2019 19:50:00 GMT",
DateTimeFormatter.RFC_1123_DATE_TIME));
assertThat(cookie.getAttribute("expires")).isEqualTo("Tue, 8 Oct 2019 19:50:00 GMT");
}
@Test
void setSameSiteNullShouldClear() {
MockCookie cookie = new MockCookie("SESSION", "123");
cookie.setSameSite("Strict");
assertThat(cookie.getSameSite()).isEqualTo("Strict");
cookie.setSameSite(null);
assertThat(cookie.getSameSite()).isNull();
assertThat(cookie.getAttribute("samesite")).isNull();
}
@Test
void setExpiresNullShouldClear() {
MockCookie cookie = new MockCookie("SESSION", "123");
cookie.setExpires(ZonedDateTime.parse("Tue, 8 Oct 2019 19:50:00 GMT",
DateTimeFormatter.RFC_1123_DATE_TIME));
assertThat(cookie.getExpires()).isEqualTo(ZonedDateTime.parse("Tue, 8 Oct 2019 19:50:00 GMT",
DateTimeFormatter.RFC_1123_DATE_TIME));
cookie.setExpires(null);
assertThat(cookie.getExpires()).isNull();
assertThat(cookie.getAttribute("expires")).isNull();
}
@Test
void setAttributeSameSiteShouldSetSameSite() {
MockCookie cookie = new MockCookie("SESSION", "123");
cookie.setAttribute("samesite", "Lax");
assertThat(cookie.getSameSite()).isEqualTo("Lax");
}
@Test
void setAttributeExpiresShouldSetExpires() {
MockCookie cookie = new MockCookie("SESSION", "123");
cookie.setAttribute("expires", "Tue, 8 Oct 2019 19:50:00 GMT");
assertThat(cookie.getExpires()).isEqualTo(ZonedDateTime.parse("Tue, 8 Oct 2019 19:50:00 GMT",
DateTimeFormatter.RFC_1123_DATE_TIME));
}
@Test
void setInvalidAttributeExpiresShouldThrow() {
MockCookie cookie = new MockCookie("SESSION", "123");
assertThatThrownBy(() -> cookie.setAttribute("expires", "12345")).isInstanceOf(DateTimeParseException.class);
}
}

Loading…
Cancel
Save