[Fetch API] Allow used body replacement in Request constructor
authorcdumez@apple.com <cdumez@apple.com@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Tue, 2 Apr 2019 20:48:19 +0000 (20:48 +0000)
committercdumez@apple.com <cdumez@apple.com@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Tue, 2 Apr 2019 20:48:19 +0000 (20:48 +0000)
https://bugs.webkit.org/show_bug.cgi?id=183703
<rdar://problem/49425609>

Reviewed by Youenn Fablet.

LayoutTests/imported/w3c:

Rebaseline WPT test now that one more check is passing.

* web-platform-tests/fetch/api/request/request-disturbed-expected.txt:

Source/WebCore:

Allow used body replacement in Request constructor as per:
- https://github.com/whatwg/fetch/pull/675

No new tests, rebaseline existing test.

* Modules/fetch/FetchRequest.cpp:
(WebCore::FetchRequest::initializeWith):

git-svn-id: https://svn.webkit.org/repository/webkit/trunk@243757 268f45cc-cd09-0410-ab3c-d52691b4dbfc

LayoutTests/imported/w3c/ChangeLog
LayoutTests/imported/w3c/web-platform-tests/fetch/api/request/request-disturbed-expected.txt
Source/WebCore/ChangeLog
Source/WebCore/Modules/fetch/FetchRequest.cpp

index 4ca6e7d..b2d8f45 100644 (file)
@@ -1,5 +1,17 @@
 2019-04-02  Chris Dumez  <cdumez@apple.com>
 
+        [Fetch API] Allow used body replacement in Request constructor
+        https://bugs.webkit.org/show_bug.cgi?id=183703
+        <rdar://problem/49425609>
+
+        Reviewed by Youenn Fablet.
+
+        Rebaseline WPT test now that one more check is passing.
+
+        * web-platform-tests/fetch/api/request/request-disturbed-expected.txt:
+
+2019-04-02  Chris Dumez  <cdumez@apple.com>
+
         Unreviewed, rolling out r243551.
 
         Seems to have broken file uploads to SoundCloud
index 5b57d0a..e32dcb5 100644 (file)
@@ -3,7 +3,7 @@ PASS Request's body: initial state
 PASS Request without body cannot be disturbed 
 PASS Check cloning a disturbed request 
 PASS Check creating a new request from a disturbed request 
-FAIL Check creating a new request with a new body from a disturbed request Request input is disturbed or locked.
+PASS Check creating a new request with a new body from a disturbed request 
 FAIL Input request used for creating new request became disturbed assert_equals: body should not change expected object "[object ReadableStream]" but got object "[object ReadableStream]"
 FAIL Input request used for creating new request became disturbed even if body is not used assert_true: bodyUsed is true when request is disturbed expected true got false
 PASS Check consuming a disturbed request 
index f66952b..f171a68 100644 (file)
@@ -1,5 +1,21 @@
 2019-04-02  Chris Dumez  <cdumez@apple.com>
 
+        [Fetch API] Allow used body replacement in Request constructor
+        https://bugs.webkit.org/show_bug.cgi?id=183703
+        <rdar://problem/49425609>
+
+        Reviewed by Youenn Fablet.
+
+        Allow used body replacement in Request constructor as per:
+        - https://github.com/whatwg/fetch/pull/675
+
+        No new tests, rebaseline existing test.
+
+        * Modules/fetch/FetchRequest.cpp:
+        (WebCore::FetchRequest::initializeWith):
+
+2019-04-02  Chris Dumez  <cdumez@apple.com>
+
         Unreviewed, rolling out r243551.
 
         Seems to have broken file uploads to SoundCloud
index 9f2eb36..c37def3 100644 (file)
@@ -203,9 +203,6 @@ ExceptionOr<void> FetchRequest::initializeWith(const String& url, Init&& init)
 
 ExceptionOr<void> FetchRequest::initializeWith(FetchRequest& input, Init&& init)
 {
-    if (input.isDisturbedOrLocked())
-        return Exception {TypeError, "Request input is disturbed or locked."_s };
-
     m_request = input.m_request;
     m_options = input.m_options;
     m_referrer = input.m_referrer;
@@ -240,6 +237,9 @@ ExceptionOr<void> FetchRequest::initializeWith(FetchRequest& input, Init&& init)
         if (setBodyResult.hasException())
             return setBodyResult.releaseException();
     } else {
+        if (input.isDisturbedOrLocked())
+            return Exception { TypeError, "Request input is disturbed or locked."_s };
+
         auto setBodyResult = setBody(input);
         if (setBodyResult.hasException())
             return setBodyResult.releaseException();