WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
36678
Support using FormData to send a sliced file via XHR.
https://bugs.webkit.org/show_bug.cgi?id=36678
Summary
Support using FormData to send a sliced file via XHR.
Jian Li
Reported
2010-03-26 14:52:02 PDT
Add the support to allow FormData.append() to take a Blob and send it correctly via XHR.
Attachments
Proposed Patch
(24.14 KB, patch)
2010-03-26 15:35 PDT
,
Jian Li
jianli
: commit-queue-
Details
Formatted Diff
Diff
Proposed Patch
(21.17 KB, application/octet-stream)
2010-03-26 15:39 PDT
,
Jian Li
jianli
: commit-queue-
Details
Proposed Patch
(21.17 KB, patch)
2010-03-26 15:40 PDT
,
Jian Li
jianli
: commit-queue-
Details
Formatted Diff
Diff
Patch
(80.32 KB, patch)
2010-03-31 13:16 PDT
,
Kinuko Yasuda
no flags
Details
Formatted Diff
Diff
Proposed Patch
(21.03 KB, patch)
2010-03-31 14:35 PDT
,
Jian Li
dimich
: review-
jianli
: commit-queue-
Details
Formatted Diff
Diff
Proposed Patch
(28.79 KB, patch)
2010-04-14 11:27 PDT
,
Jian Li
dimich
: review+
jianli
: commit-queue-
Details
Formatted Diff
Diff
Show Obsolete
(5)
View All
Add attachment
proposed patch, testcase, etc.
Jian Li
Comment 1
2010-03-26 15:35:19 PDT
Created
attachment 51787
[details]
Proposed Patch This depends on 36472. Before it is landed, the compiling queues will show errors for now.
Jian Li
Comment 2
2010-03-26 15:39:22 PDT
Created
attachment 51788
[details]
Proposed Patch Removed the change to project.pbxproj accidentally added into the patch.
WebKit Review Bot
Comment 3
2010-03-26 15:40:20 PDT
Attachment 51788
[details]
did not pass style-queue: Failed to run "WebKitTools/Scripts/check-webkit-style" exit_code: 1 WebCore/html/FormDataList.h:41: More than one command on the same line [whitespace/newline] [4] Total errors found: 1 in 18 files If any of these errors are false positives, please file a bug against check-webkit-style.
Jian Li
Comment 4
2010-03-26 15:40:24 PDT
Created
attachment 51789
[details]
Proposed Patch Sorry, forgot to add it as patch. Try again.
WebKit Review Bot
Comment 5
2010-03-26 15:46:24 PDT
Attachment 51789
[details]
did not pass style-queue: Failed to run "WebKitTools/Scripts/check-webkit-style" exit_code: 1 WebCore/html/FormDataList.h:41: More than one command on the same line [whitespace/newline] [4] Total errors found: 1 in 18 files If any of these errors are false positives, please file a bug against check-webkit-style.
Early Warning System Bot
Comment 6
2010-03-26 15:47:03 PDT
Attachment 51789
[details]
did not build on qt: Build output:
http://webkit-commit-queue.appspot.com/results/1494001
WebKit Review Bot
Comment 7
2010-03-26 15:53:22 PDT
Attachment 51789
[details]
did not build on chromium: Build output:
http://webkit-commit-queue.appspot.com/results/1495001
WebKit Review Bot
Comment 8
2010-03-26 16:08:53 PDT
Attachment 51789
[details]
did not build on gtk: Build output:
http://webkit-commit-queue.appspot.com/results/1487004
Eric Seidel (no email)
Comment 9
2010-03-26 21:02:09 PDT
Attachment 51789
[details]
did not build on mac: Build output:
http://webkit-commit-queue.appspot.com/results/1570007
Kinuko Yasuda
Comment 10
2010-03-31 13:16:38 PDT
Created
attachment 52204
[details]
Patch
Kinuko Yasuda
Comment 11
2010-03-31 13:19:50 PDT
Comment on
attachment 52204
[details]
Patch Sorry I submitted a patch to a wrong bug...
Early Warning System Bot
Comment 12
2010-03-31 13:23:58 PDT
Attachment 52204
[details]
did not build on qt: Build output:
http://webkit-commit-queue.appspot.com/results/1640071
Jian Li
Comment 13
2010-03-31 14:35:00 PDT
Created
attachment 52211
[details]
Proposed Patch Updated the patch based on the latest sync so that commit-queue check should function now.
WebKit Review Bot
Comment 14
2010-03-31 14:40:51 PDT
Attachment 52211
[details]
did not pass style-queue: Failed to run "WebKitTools/Scripts/check-webkit-style" exit_code: 1 WebCore/html/FormDataList.h:41: More than one command on the same line [whitespace/newline] [4] Total errors found: 1 in 18 files If any of these errors are false positives, please file a bug against check-webkit-style.
Dmitry Titov
Comment 15
2010-04-09 15:15:54 PDT
Comment on
attachment 52211
[details]
Proposed Patch Look good, couple of small things:
> diff --git a/LayoutTests/http/tests/local/send-form-data-with-sliced-file.html b/LayoutTests/http/tests/local/send-form-data-with-sliced-file.html
This looks like a typical script-test. Most (if not all) other script tests have their .js files in a subdirectory named 'script-tests' and they also have TEMPLATE.html file there. There is a script in WebKitTools/Script/make-script-test-erappers which then generates the .html files using the template. For the consistency, please consider following the same pattern. If necessary (because of specific template), a http/tests/local/formdata subdirectory can be created to keep FormData-related tests.
> diff --git a/WebCore/platform/network/FormData.cpp b/WebCore/platform/network/FormData.cpp
> @@ -186,9 +188,20 @@ void FormData::appendDOMFormData(const DOMFormData& domFormData, bool isMultiPar > +#if ENABLE(BLOB_SLICE) > + String fileName; > + if (value.blob()->isFile()) > + fileName = static_cast<File*>(value.blob())->fileName(); > + else { > + // If a blob is sliced from a file, it does not have the filename. In this case, let's produce a unique filename. > + fileName = "Blob" + createCanonicalUUIDString(); > + fileName.replace("-", ""); // For safe, remove '-' in case that certain server does not like it to be in the filename.
May be "// For safety, remove '-' from the filename since some servers may not like it." ?
> + } > +#else > + String fileName = static_cast<File*>(value.blob())->fileName();
It seems like a good place to have ASSERT(value.blob()->IsFile()); Doing r- since moving files to script-test might benefit from another look.
Jian Li
Comment 16
2010-04-14 11:27:59 PDT
Created
attachment 53347
[details]
Proposed Patch All fixed.
WebKit Review Bot
Comment 17
2010-04-14 11:29:18 PDT
Attachment 53347
[details]
did not pass style-queue: Failed to run "WebKitTools/Scripts/check-webkit-style" exit_code: 1 WARNING: Skipping non-existent file: LayoutTests/http/tests/local/resources/send-form-data.js WARNING: Skipping non-existent file: LayoutTests/http/tests/local/send-form-data-expected.txt WebCore/html/FormDataList.h:41: More than one command on the same line [whitespace/newline] [4] WARNING: Skipping non-existent file: LayoutTests/http/tests/local/send-form-data.html Total errors found: 1 in 20 files If any of these errors are false positives, please file a bug against check-webkit-style.
Dmitry Titov
Comment 18
2010-04-15 13:46:19 PDT
Comment on
attachment 53347
[details]
Proposed Patch r=me tiny nit:
> diff --git a/LayoutTests/ChangeLog b/LayoutTests/ChangeLog
> + Move common functionalities to test sending FormData into a helper file
s/functionalities/functionality/ Also, the style bot complained because the change happens around old code with style violation in it. Perhaps it would be nice to have a separate patch to fix the style of that code?
Jian Li
Comment 19
2010-04-15 18:00:15 PDT
Committed as
http://trac.webkit.org/changeset/57695
.
WebKit Review Bot
Comment 20
2010-04-15 18:08:05 PDT
http://trac.webkit.org/changeset/57695
might have broken Qt Linux Release
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug