Merge branch '6.1.x'

This commit is contained in:
rstoyanchev 2024-08-13 16:59:32 +03:00
commit 5fee796659
2 changed files with 9 additions and 4 deletions

View File

@ -1073,9 +1073,8 @@ public class HttpHeaders implements MultiValueMap<String, String>, Serializable
*/ */
public void setETag(@Nullable String etag) { public void setETag(@Nullable String etag) {
if (etag != null) { if (etag != null) {
Assert.isTrue(etag.startsWith("\"") || etag.startsWith("W/"), Assert.isTrue(etag.startsWith("\"") || etag.startsWith("W/\""), "ETag does not start with W/\" or \"");
"Invalid ETag: does not start with W/ or \""); Assert.isTrue(etag.endsWith("\""), "ETag does not end with \"");
Assert.isTrue(etag.endsWith("\""), "Invalid ETag: does not end with \"");
set(ETAG, etag); set(ETAG, etag);
} }
else { else {

View File

@ -214,11 +214,17 @@ class HttpHeadersTests {
} }
@Test @Test
void illegalETag() { void illegalETagWithoutQuotes() {
String eTag = "v2.6"; String eTag = "v2.6";
assertThatIllegalArgumentException().isThrownBy(() -> headers.setETag(eTag)); assertThatIllegalArgumentException().isThrownBy(() -> headers.setETag(eTag));
} }
@Test
void illegalWeakETagWithoutLeadingQuote() {
String etag = "W/v2.6\"";
assertThatIllegalArgumentException().isThrownBy(() -> headers.setETag(etag));
}
@Test @Test
void ifMatch() { void ifMatch() {
String ifMatch = "\"v2.6\""; String ifMatch = "\"v2.6\"";