mirror of
https://github.com/servo/servo.git
synced 2025-08-06 14:10:11 +01:00
Auto merge of #9049 - KiChjang:form-data-refactor, r=eefriedman
Refactor FormData code to match updated spec <!-- Reviewable:start --> [<img src="https://reviewable.io/review_button.png" height=40 alt="Review on Reviewable"/>](https://reviewable.io/reviews/servo/servo/9049) <!-- Reviewable:end -->
This commit is contained in:
commit
7a5522a263
14 changed files with 469 additions and 89 deletions
|
@ -5,32 +5,33 @@
|
||||||
use dom::bindings::cell::DOMRefCell;
|
use dom::bindings::cell::DOMRefCell;
|
||||||
use dom::bindings::codegen::Bindings::FormDataBinding;
|
use dom::bindings::codegen::Bindings::FormDataBinding;
|
||||||
use dom::bindings::codegen::Bindings::FormDataBinding::FormDataMethods;
|
use dom::bindings::codegen::Bindings::FormDataBinding::FormDataMethods;
|
||||||
use dom::bindings::codegen::UnionTypes::FileOrString;
|
use dom::bindings::codegen::UnionTypes::BlobOrUSVString::{self, eBlob, eUSVString};
|
||||||
use dom::bindings::codegen::UnionTypes::FileOrString::{eFile, eString};
|
|
||||||
use dom::bindings::error::{Fallible};
|
use dom::bindings::error::{Fallible};
|
||||||
use dom::bindings::global::{GlobalField, GlobalRef};
|
use dom::bindings::global::{GlobalField, GlobalRef};
|
||||||
use dom::bindings::inheritance::Castable;
|
use dom::bindings::inheritance::Castable;
|
||||||
use dom::bindings::js::{JS, Root};
|
use dom::bindings::js::{JS, Root};
|
||||||
use dom::bindings::reflector::{Reflector, reflect_dom_object};
|
use dom::bindings::reflector::{Reflector, reflect_dom_object};
|
||||||
|
use dom::bindings::str::USVString;
|
||||||
use dom::blob::Blob;
|
use dom::blob::Blob;
|
||||||
use dom::file::File;
|
use dom::file::File;
|
||||||
use dom::htmlformelement::HTMLFormElement;
|
use dom::htmlformelement::HTMLFormElement;
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use std::collections::hash_map::Entry::{Occupied, Vacant};
|
use std::collections::hash_map::Entry::{Occupied, Vacant};
|
||||||
|
use string_cache::Atom;
|
||||||
use util::str::DOMString;
|
use util::str::DOMString;
|
||||||
|
|
||||||
#[derive(JSTraceable, Clone)]
|
#[derive(JSTraceable, Clone)]
|
||||||
#[must_root]
|
#[must_root]
|
||||||
#[derive(HeapSizeOf)]
|
#[derive(HeapSizeOf)]
|
||||||
pub enum FormDatum {
|
pub enum FormDatum {
|
||||||
StringData(DOMString),
|
StringData(String),
|
||||||
FileData(JS<File>)
|
BlobData(JS<Blob>)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[dom_struct]
|
#[dom_struct]
|
||||||
pub struct FormData {
|
pub struct FormData {
|
||||||
reflector_: Reflector,
|
reflector_: Reflector,
|
||||||
data: DOMRefCell<HashMap<DOMString, Vec<FormDatum>>>,
|
data: DOMRefCell<HashMap<Atom, Vec<FormDatum>>>,
|
||||||
global: GlobalField,
|
global: GlobalField,
|
||||||
form: Option<JS<HTMLFormElement>>
|
form: Option<JS<HTMLFormElement>>
|
||||||
}
|
}
|
||||||
|
@ -51,72 +52,87 @@ impl FormData {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn Constructor(global: GlobalRef, form: Option<&HTMLFormElement>) -> Fallible<Root<FormData>> {
|
pub fn Constructor(global: GlobalRef, form: Option<&HTMLFormElement>) -> Fallible<Root<FormData>> {
|
||||||
|
// TODO: Construct form data set for form if it is supplied
|
||||||
Ok(FormData::new(form, global))
|
Ok(FormData::new(form, global))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FormDataMethods for FormData {
|
impl FormDataMethods for FormData {
|
||||||
|
// https://xhr.spec.whatwg.org/#dom-formdata-append
|
||||||
|
fn Append(&self, name: USVString, value: USVString) {
|
||||||
|
let mut data = self.data.borrow_mut();
|
||||||
|
match data.entry(Atom::from(&*name.0)) {
|
||||||
|
Occupied(entry) => entry.into_mut().push(FormDatum::StringData(value.0)),
|
||||||
|
Vacant (entry) => { entry.insert(vec!(FormDatum::StringData(value.0))); }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[allow(unrooted_must_root)]
|
#[allow(unrooted_must_root)]
|
||||||
// https://xhr.spec.whatwg.org/#dom-formdata-append
|
// https://xhr.spec.whatwg.org/#dom-formdata-append
|
||||||
fn Append(&self, name: DOMString, value: &Blob, filename: Option<DOMString>) {
|
fn Append_(&self, name: USVString, value: &Blob, filename: Option<USVString>) {
|
||||||
let file = FormDatum::FileData(JS::from_rooted(&self.get_file_from_blob(value, filename)));
|
let blob = FormDatum::BlobData(JS::from_rooted(&self.get_file_or_blob(value, filename)));
|
||||||
let mut data = self.data.borrow_mut();
|
let mut data = self.data.borrow_mut();
|
||||||
match data.entry(name) {
|
match data.entry(Atom::from(&*name.0)) {
|
||||||
Occupied(entry) => entry.into_mut().push(file),
|
Occupied(entry) => entry.into_mut().push(blob),
|
||||||
Vacant(entry) => {
|
Vacant(entry) => {
|
||||||
entry.insert(vec!(file));
|
entry.insert(vec!(blob));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://xhr.spec.whatwg.org/#dom-formdata-append
|
|
||||||
fn Append_(&self, name: DOMString, value: DOMString) {
|
|
||||||
let mut data = self.data.borrow_mut();
|
|
||||||
match data.entry(name) {
|
|
||||||
Occupied(entry) => entry.into_mut().push(FormDatum::StringData(value)),
|
|
||||||
Vacant (entry) => { entry.insert(vec!(FormDatum::StringData(value))); },
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// https://xhr.spec.whatwg.org/#dom-formdata-delete
|
// https://xhr.spec.whatwg.org/#dom-formdata-delete
|
||||||
fn Delete(&self, name: DOMString) {
|
fn Delete(&self, name: USVString) {
|
||||||
self.data.borrow_mut().remove(&name);
|
self.data.borrow_mut().remove(&Atom::from(&*name.0));
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://xhr.spec.whatwg.org/#dom-formdata-get
|
// https://xhr.spec.whatwg.org/#dom-formdata-get
|
||||||
fn Get(&self, name: DOMString) -> Option<FileOrString> {
|
fn Get(&self, name: USVString) -> Option<BlobOrUSVString> {
|
||||||
self.data.borrow()
|
self.data.borrow()
|
||||||
.get(&name)
|
.get(&Atom::from(&*name.0))
|
||||||
.map(|entry| match entry[0] {
|
.map(|entry| match entry[0] {
|
||||||
FormDatum::StringData(ref s) => eString(s.clone()),
|
FormDatum::StringData(ref s) => eUSVString(USVString(s.clone())),
|
||||||
FormDatum::FileData(ref f) => eFile(Root::from_ref(&*f)),
|
FormDatum::BlobData(ref b) => eBlob(Root::from_ref(&*b)),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://xhr.spec.whatwg.org/#dom-formdata-has
|
// https://xhr.spec.whatwg.org/#dom-formdata-getall
|
||||||
fn Has(&self, name: DOMString) -> bool {
|
fn GetAll(&self, name: USVString) -> Vec<BlobOrUSVString> {
|
||||||
self.data.borrow().contains_key(&name)
|
self.data.borrow()
|
||||||
|
.get(&Atom::from(&*name.0))
|
||||||
|
.map_or(vec![], |data|
|
||||||
|
data.iter().map(|item| match *item {
|
||||||
|
FormDatum::StringData(ref s) => eUSVString(USVString(s.clone())),
|
||||||
|
FormDatum::BlobData(ref b) => eBlob(Root::from_ref(&*b)),
|
||||||
|
}).collect()
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://xhr.spec.whatwg.org/#dom-formdata-set
|
// https://xhr.spec.whatwg.org/#dom-formdata-has
|
||||||
fn Set_(&self, name: DOMString, value: DOMString) {
|
fn Has(&self, name: USVString) -> bool {
|
||||||
self.data.borrow_mut().insert(name, vec!(FormDatum::StringData(value)));
|
self.data.borrow().contains_key(&Atom::from(&*name.0))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(unrooted_must_root)]
|
#[allow(unrooted_must_root)]
|
||||||
// https://xhr.spec.whatwg.org/#dom-formdata-set
|
// https://xhr.spec.whatwg.org/#dom-formdata-set
|
||||||
fn Set(&self, name: DOMString, value: &Blob, filename: Option<DOMString>) {
|
fn Set(&self, name: USVString, value: BlobOrUSVString) {
|
||||||
let file = FormDatum::FileData(JS::from_rooted(&self.get_file_from_blob(value, filename)));
|
let val = match value {
|
||||||
self.data.borrow_mut().insert(name, vec!(file));
|
eUSVString(s) => FormDatum::StringData(s.0),
|
||||||
|
eBlob(b) => FormDatum::BlobData(JS::from_rooted(&b))
|
||||||
|
};
|
||||||
|
self.data.borrow_mut().insert(Atom::from(&*name.0), vec!(val));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
impl FormData {
|
impl FormData {
|
||||||
fn get_file_from_blob(&self, value: &Blob, filename: Option<DOMString>) -> Root<File> {
|
fn get_file_or_blob(&self, value: &Blob, filename: Option<USVString>) -> Root<Blob> {
|
||||||
let global = self.global.root();
|
match filename {
|
||||||
let f = value.downcast::<File>();
|
Some(fname) => {
|
||||||
let name = filename.unwrap_or(f.map(|inner| inner.name().clone()).unwrap_or(DOMString::from("blob")));
|
let global = self.global.root();
|
||||||
File::new(global.r(), value, name)
|
let name = DOMString::from(fname.0);
|
||||||
|
Root::upcast(File::new(global.r(), value, name))
|
||||||
|
}
|
||||||
|
None => Root::from_ref(value)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,19 +4,20 @@
|
||||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
/*
|
/*
|
||||||
* The origin of this IDL file is
|
* The origin of this IDL file is
|
||||||
* https://xhr.spec.whatwg.org
|
* https://xhr.spec.whatwg.org/#interface-formdata
|
||||||
*/
|
*/
|
||||||
|
|
||||||
typedef (File or DOMString) FormDataEntryValue;
|
typedef (Blob or USVString) FormDataEntryValue;
|
||||||
|
|
||||||
[Constructor(optional HTMLFormElement form)]
|
[Constructor(optional HTMLFormElement form),
|
||||||
|
/*Exposed=(Window,Worker)*/]
|
||||||
interface FormData {
|
interface FormData {
|
||||||
void append(DOMString name, Blob value, optional DOMString filename);
|
void append(USVString name, USVString value);
|
||||||
void append(DOMString name, DOMString value);
|
void append(USVString name, Blob value, optional USVString filename);
|
||||||
void delete(DOMString name);
|
void delete(USVString name);
|
||||||
FormDataEntryValue? get(DOMString name);
|
FormDataEntryValue? get(USVString name);
|
||||||
// sequence<FormDataEntryValue> getAll(DOMString name);
|
sequence<FormDataEntryValue> getAll(USVString name);
|
||||||
boolean has(DOMString name);
|
boolean has(USVString name);
|
||||||
void set(DOMString name, Blob value, optional DOMString filename);
|
void set(USVString name, FormDataEntryValue value);
|
||||||
void set(DOMString name, DOMString value);
|
// iterable<USVString, FormDataEntryValue>;
|
||||||
};
|
};
|
||||||
|
|
|
@ -30174,6 +30174,30 @@
|
||||||
"deleted": [],
|
"deleted": [],
|
||||||
"items": {
|
"items": {
|
||||||
"testharness": {
|
"testharness": {
|
||||||
|
"XMLHttpRequest/formdata-delete.htm": [
|
||||||
|
{
|
||||||
|
"path": "XMLHttpRequest/formdata-delete.htm",
|
||||||
|
"url": "/XMLHttpRequest/formdata-delete.htm"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"XMLHttpRequest/formdata-get.htm": [
|
||||||
|
{
|
||||||
|
"path": "XMLHttpRequest/formdata-get.htm",
|
||||||
|
"url": "/XMLHttpRequest/formdata-get.htm"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"XMLHttpRequest/formdata-has.htm": [
|
||||||
|
{
|
||||||
|
"path": "XMLHttpRequest/formdata-has.htm",
|
||||||
|
"url": "/XMLHttpRequest/formdata-has.htm"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"XMLHttpRequest/formdata-set.htm": [
|
||||||
|
{
|
||||||
|
"path": "XMLHttpRequest/formdata-set.htm",
|
||||||
|
"url": "/XMLHttpRequest/formdata-set.htm"
|
||||||
|
}
|
||||||
|
],
|
||||||
"html/semantics/forms/the-button-element/button-activate.html": [
|
"html/semantics/forms/the-button-element/button-activate.html": [
|
||||||
{
|
{
|
||||||
"path": "html/semantics/forms/the-button-element/button-activate.html",
|
"path": "html/semantics/forms/the-button-element/button-activate.html",
|
||||||
|
|
|
@ -2,4 +2,6 @@
|
||||||
type: testharness
|
type: testharness
|
||||||
[Passing a String object to FormData.append should work.]
|
[Passing a String object to FormData.append should work.]
|
||||||
expected: FAIL
|
expected: FAIL
|
||||||
|
[testFormDataAppendEmptyBlob]
|
||||||
|
expected: FAIL
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
[formdata-delete.htm]
|
||||||
|
type:testharness
|
||||||
|
[testFormDataDeleteFromFormNonExistentKey]
|
||||||
|
expected: FAIL
|
||||||
|
[testFormDataDeleteFromFormOtherKey]
|
||||||
|
expected: FAIL
|
||||||
|
|
6
tests/wpt/metadata/XMLHttpRequest/formdata-get.htm.ini
Normal file
6
tests/wpt/metadata/XMLHttpRequest/formdata-get.htm.ini
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
[formdata-get.htm]
|
||||||
|
type: testharness
|
||||||
|
[testFormDataGetFromForm]
|
||||||
|
expected: FAIL
|
||||||
|
[testFormDataGetAllFromForm]
|
||||||
|
expected: FAIL
|
5
tests/wpt/metadata/XMLHttpRequest/formdata-has.htm.ini
Normal file
5
tests/wpt/metadata/XMLHttpRequest/formdata-has.htm.ini
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
[formdata-has.htm]
|
||||||
|
type: testharness
|
||||||
|
[testFormDataHasFromForm]
|
||||||
|
expected: FAIL
|
||||||
|
|
7
tests/wpt/metadata/XMLHttpRequest/formdata-set.htm.ini
Normal file
7
tests/wpt/metadata/XMLHttpRequest/formdata-set.htm.ini
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
[formdata-set.htm]
|
||||||
|
type: testharness
|
||||||
|
[Passing a String object to FormData.set should work]
|
||||||
|
expected: FAIL
|
||||||
|
[testFormDataSetEmptyBlob]
|
||||||
|
expected: FAIL
|
||||||
|
|
|
@ -1,20 +1,5 @@
|
||||||
[interfaces.html]
|
[interfaces.html]
|
||||||
type: testharness
|
type: testharness
|
||||||
[FormData interface: new FormData() must inherit property "getAll" with the proper type (4)]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[FormData interface: new FormData(form) must inherit property "getAll" with the proper type (4)]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[FormData interface: operation getAll(USVString)]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[FormData interface: calling getAll(USVString) on new FormData() with too few arguments must throw TypeError]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[FormData interface: calling getAll(USVString) on new FormData(form) with too few arguments must throw TypeError]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
||||||
[ProgressEvent interface: existence and properties of interface object]
|
[ProgressEvent interface: existence and properties of interface object]
|
||||||
expected: FAIL
|
expected: FAIL
|
||||||
|
|
||||||
|
|
|
@ -1,28 +1,94 @@
|
||||||
<!doctype html>
|
<!doctype html>
|
||||||
<meta charset=utf-8>
|
<meta charset="utf-8">
|
||||||
<title>FormData.append</title>
|
<title>FormData.append</title>
|
||||||
<link rel=help href=https://xhr.spec.whatwg.org/#dom-formdata-append>
|
<link rel="help" href="https://xhr.spec.whatwg.org/#dom-formdata-append">
|
||||||
<script src=/resources/testharness.js></script>
|
<script src="/resources/testharness.js"></script>
|
||||||
<script src=/resources/testharnessreport.js></script>
|
<script src="/resources/testharnessreport.js"></script>
|
||||||
<div id=log></div>
|
<div id="log"></div>
|
||||||
|
<form id="form" />
|
||||||
<script>
|
<script>
|
||||||
function test_formdata(creator, verifier, description) {
|
function test_formdata(creator, verifier, description) {
|
||||||
async_test(description).step(function() {
|
async_test(description).step(function() {
|
||||||
var fd = creator();
|
var fd = creator();
|
||||||
var xhr = new XMLHttpRequest();
|
var xhr = new XMLHttpRequest();
|
||||||
xhr.onload = this.step_func(function() {
|
xhr.onload = this.step_func(function() {
|
||||||
verifier(xhr.responseText);
|
verifier(xhr.responseText);
|
||||||
this.done();
|
this.done();
|
||||||
});
|
});
|
||||||
xhr.open("POST", "resources/upload.py");
|
xhr.open("POST", "resources/upload.py");
|
||||||
xhr.send(fd);
|
xhr.send(fd);
|
||||||
})
|
});
|
||||||
}
|
}
|
||||||
test_formdata(function() {
|
|
||||||
var fd = new FormData();
|
test_formdata(function() {
|
||||||
fd.append("name", new String("value"));
|
var fd = new FormData();
|
||||||
return fd;
|
fd.append("name", new String("value"));
|
||||||
}, function(data) {
|
return fd;
|
||||||
assert_equals(data, "name=value,\n");
|
}, function(data) {
|
||||||
}, "Passing a String object to FormData.append should work.");
|
assert_equals(data, "name=value,\n");
|
||||||
|
}, "Passing a String object to FormData.append should work.");
|
||||||
|
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', 'value1']).get('key'), "value1");
|
||||||
|
}, 'testFormDataAppend1');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', 'value2'], ['key', 'value1']).get('key'), "value2");
|
||||||
|
}, 'testFormDataAppend2');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', undefined]).get('key'), "undefined");
|
||||||
|
}, 'testFormDataAppendUndefined1');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', undefined], ['key', 'value1']).get('key'), "undefined");
|
||||||
|
}, 'testFormDataAppendUndefined2');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', null]).get('key'), "null");
|
||||||
|
}, 'testFormDataAppendNull1');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', null], ['key', 'value1']).get('key'), "null");
|
||||||
|
}, 'testFormDataAppendNull2');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.append('key', 'value1');
|
||||||
|
assert_equals(fd.get('key'), "value1");
|
||||||
|
}, 'testFormDataAppendToForm1');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.append('key', 'value2');
|
||||||
|
fd.append('key', 'value1');
|
||||||
|
assert_equals(fd.get('key'), "value2");
|
||||||
|
}, 'testFormDataAppendToForm2');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.append('key', undefined);
|
||||||
|
assert_equals(fd.get('key'), "undefined");
|
||||||
|
}, 'testFormDataAppendToFormUndefined1');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.append('key', undefined);
|
||||||
|
fd.append('key', 'value1');
|
||||||
|
assert_equals(fd.get('key'), "undefined");
|
||||||
|
}, 'testFormDataAppendToFormUndefined2');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.append('key', null);
|
||||||
|
assert_equals(fd.get('key'), "null");
|
||||||
|
}, 'testFormDataAppendToFormNull1');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.append('key', null);
|
||||||
|
fd.append('key', 'value1');
|
||||||
|
assert_equals(fd.get('key'), "null");
|
||||||
|
}, 'testFormDataAppendToFormNull2');
|
||||||
|
test(function() {
|
||||||
|
assert_object_equals(create_formdata(['key', new Blob(), 'blank.txt']).get('key'),
|
||||||
|
new File(new Blob(), 'blank.txt'));
|
||||||
|
}, 'testFormDataAppendEmptyBlob');
|
||||||
|
|
||||||
|
function create_formdata() {
|
||||||
|
var fd = new FormData();
|
||||||
|
for (var i = 0; i < arguments.length; i++) {
|
||||||
|
fd.append.apply(fd, arguments[i]);
|
||||||
|
};
|
||||||
|
return fd;
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -0,0 +1,65 @@
|
||||||
|
<!doctype html>
|
||||||
|
<html lang=en>
|
||||||
|
<meta charset=utf-8>
|
||||||
|
<title>FormData: delete</title>
|
||||||
|
<script src="/resources/testharness.js"></script>
|
||||||
|
<script src="/resources/testharnessreport.js"></script>
|
||||||
|
<link rel="help" href="https://xhr.spec.whatwg.org/#dom-formdata-get" />
|
||||||
|
<link rel="help" href="https://xhr.spec.whatwg.org/#dom-formdata-getall" />
|
||||||
|
<div id="log"></div>
|
||||||
|
<form id="form1">
|
||||||
|
<input type="hidden" name="key" value="value1">
|
||||||
|
<input type="hidden" name="key" value="value2">
|
||||||
|
</form>
|
||||||
|
<form id="form2">
|
||||||
|
<input type="hidden" name="key1" value="value1">
|
||||||
|
<input type="hidden" name="key2" value="value2">
|
||||||
|
</form>
|
||||||
|
<form id="empty-form" />
|
||||||
|
<script>
|
||||||
|
test(function() {
|
||||||
|
var fd = create_formdata(['key', 'value1'], ['key', 'value2']);
|
||||||
|
fd.delete('key');
|
||||||
|
assert_equals(fd.get('key'), null);
|
||||||
|
}, 'testFormDataDelete');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById('form1'));
|
||||||
|
fd.delete('key');
|
||||||
|
assert_equals(fd.get('key'), null);
|
||||||
|
}, 'testFormDataDeleteFromForm');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById('form1'));
|
||||||
|
fd.delete('nil');
|
||||||
|
assert_equals(fd.get('key'), 'value1');
|
||||||
|
}, 'testFormDataDeleteFromFormNonExistentKey');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById('form2'));
|
||||||
|
fd.delete('key1');
|
||||||
|
assert_equals(fd.get('key1'), null);
|
||||||
|
assert_equals(fd.get('key2'), 'value2');
|
||||||
|
}, 'testFormDataDeleteFromFormOtherKey');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById('empty-form'));
|
||||||
|
fd.delete('key');
|
||||||
|
assert_equals(fd.get('key'), null);
|
||||||
|
}, 'testFormDataDeleteFromEmptyForm');
|
||||||
|
test(function() {
|
||||||
|
var fd = create_formdata(['key', 'value1'], ['key', 'value2']);
|
||||||
|
fd.delete('nil');
|
||||||
|
assert_equals(fd.get('key'), 'value1');
|
||||||
|
}, 'testFormDataDeleteNonExistentKey');
|
||||||
|
test(function() {
|
||||||
|
var fd = create_formdata(['key1', 'value1'], ['key2', 'value2']);
|
||||||
|
fd.delete('key1');
|
||||||
|
assert_equals(fd.get('key1'), null);
|
||||||
|
assert_equals(fd.get('key2'), 'value2');
|
||||||
|
}, 'testFormDataDeleteOtherKey');
|
||||||
|
|
||||||
|
function create_formdata() {
|
||||||
|
var fd = new FormData();
|
||||||
|
for (var i = 0; i < arguments.length; i++) {
|
||||||
|
fd.append.apply(fd, arguments[i]);
|
||||||
|
};
|
||||||
|
return fd;
|
||||||
|
}
|
||||||
|
</script>
|
60
tests/wpt/web-platform-tests/XMLHttpRequest/formdata-get.htm
Normal file
60
tests/wpt/web-platform-tests/XMLHttpRequest/formdata-get.htm
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
<!doctype html>
|
||||||
|
<html lang=en>
|
||||||
|
<meta charset=utf-8>
|
||||||
|
<title>FormData: get and getAll</title>
|
||||||
|
<script src="/resources/testharness.js"></script>
|
||||||
|
<script src="/resources/testharnessreport.js"></script>
|
||||||
|
<link rel="help" href="https://xhr.spec.whatwg.org/#dom-formdata-get" />
|
||||||
|
<link rel="help" href="https://xhr.spec.whatwg.org/#dom-formdata-getall" />
|
||||||
|
<div id="log"></div>
|
||||||
|
<form id="form">
|
||||||
|
<input type="hidden" name="key" value="value1">
|
||||||
|
<input type="hidden" name="key" value="value2">
|
||||||
|
</form>
|
||||||
|
<form id="empty-form" />
|
||||||
|
<script>
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', 'value1'], ['key', 'value2']).get('key'), "value1");
|
||||||
|
}, 'testFormDataGet');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(new FormData(document.getElementById('form')).get('key'), "value1");
|
||||||
|
}, 'testFormDataGetFromForm');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(new FormData(document.getElementById('form')).get('nil'), null);
|
||||||
|
}, 'testFormDataGetFromFormNull');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(new FormData(document.getElementById('empty-form')).get('key'), null);
|
||||||
|
}, 'testFormDataGetFromEmptyForm');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', 'value1'], ['key', 'value2']).get('nil'), null);
|
||||||
|
}, 'testFormDataGetNull1');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata().get('key'), null);
|
||||||
|
}, 'testFormDataGetNull2');
|
||||||
|
test(function() {
|
||||||
|
assert_array_equals(create_formdata(['key', 'value1'], ['key', 'value2']).getAll('key'), ["value1", "value2"]);
|
||||||
|
}, 'testFormDataGetAll');
|
||||||
|
test(function() {
|
||||||
|
assert_array_equals(create_formdata(['key', 'value1'], ['key', 'value2']).getAll('nil'), []);
|
||||||
|
}, 'testFormDataGetAllEmpty1');
|
||||||
|
test(function() {
|
||||||
|
assert_array_equals(create_formdata().getAll('key'), []);
|
||||||
|
}, 'testFormDataGetAllEmpty2');
|
||||||
|
test(function() {
|
||||||
|
assert_array_equals(new FormData(document.getElementById('form')).getAll('key'), ["value1", "value2"]);
|
||||||
|
}, 'testFormDataGetAllFromForm');
|
||||||
|
test(function() {
|
||||||
|
assert_array_equals(new FormData(document.getElementById('form')).getAll('nil'), []);
|
||||||
|
}, 'testFormDataGetAllFromFormNull');
|
||||||
|
test(function() {
|
||||||
|
assert_array_equals(new FormData(document.getElementById('empty-form')).getAll('key'), []);
|
||||||
|
}, 'testFormDataGetAllFromEmptyForm');
|
||||||
|
|
||||||
|
function create_formdata() {
|
||||||
|
var fd = new FormData();
|
||||||
|
for (var i = 0; i < arguments.length; i++) {
|
||||||
|
fd.append.apply(fd, arguments[i]);
|
||||||
|
};
|
||||||
|
return fd;
|
||||||
|
}
|
||||||
|
</script>
|
42
tests/wpt/web-platform-tests/XMLHttpRequest/formdata-has.htm
Normal file
42
tests/wpt/web-platform-tests/XMLHttpRequest/formdata-has.htm
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
<!doctype html>
|
||||||
|
<html lang=en>
|
||||||
|
<meta charset=utf-8>
|
||||||
|
<title>FormData: has</title>
|
||||||
|
<script src="/resources/testharness.js"></script>
|
||||||
|
<script src="/resources/testharnessreport.js"></script>
|
||||||
|
<link rel="help" href="https://xhr.spec.whatwg.org/#dom-formdata-get" />
|
||||||
|
<link rel="help" href="https://xhr.spec.whatwg.org/#dom-formdata-getall" />
|
||||||
|
<div id="log"></div>
|
||||||
|
<form id="form">
|
||||||
|
<input type="hidden" name="key" value="value1">
|
||||||
|
<input type="hidden" name="key" value="value2">
|
||||||
|
</form>
|
||||||
|
<form id="empty-form" />
|
||||||
|
<script>
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', 'value1'], ['key', 'value2']).has('key'), true);
|
||||||
|
}, 'testFormDataHas');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(new FormData(document.getElementById('form')).has('key'), true);
|
||||||
|
}, 'testFormDataHasFromForm');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(new FormData(document.getElementById('form')).has('nil'), false);
|
||||||
|
}, 'testFormDataHasFromFormNull');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(new FormData(document.getElementById('empty-form')).has('key'), false);
|
||||||
|
}, 'testFormDataHasFromEmptyForm');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', 'value1'], ['key', 'value2']).has('nil'), false);
|
||||||
|
}, 'testFormDataHasEmpty1');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata().has('key'), false);
|
||||||
|
}, 'testFormDataHasEmpty2');
|
||||||
|
|
||||||
|
function create_formdata() {
|
||||||
|
var fd = new FormData();
|
||||||
|
for (var i = 0; i < arguments.length; i++) {
|
||||||
|
fd.append.apply(fd, arguments[i]);
|
||||||
|
};
|
||||||
|
return fd;
|
||||||
|
}
|
||||||
|
</script>
|
94
tests/wpt/web-platform-tests/XMLHttpRequest/formdata-set.htm
Normal file
94
tests/wpt/web-platform-tests/XMLHttpRequest/formdata-set.htm
Normal file
|
@ -0,0 +1,94 @@
|
||||||
|
<!doctype html>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<title>FormData: set</title>
|
||||||
|
<link rel="help" href="https://xhr.spec.whatwg.org/#dom-formdata-set">
|
||||||
|
<script src="/resources/testharness.js"></script>
|
||||||
|
<script src="/resources/testharnessreport.js"></script>
|
||||||
|
<div id="log"></div>
|
||||||
|
<form id="form" />
|
||||||
|
<script>
|
||||||
|
function test_formdata(creator, verifier, description) {
|
||||||
|
async_test(description).step(function() {
|
||||||
|
var fd = creator();
|
||||||
|
var xhr = new XMLHttpRequest();
|
||||||
|
xhr.onload = this.step_func(function() {
|
||||||
|
verifier(xhr.responseText);
|
||||||
|
this.done();
|
||||||
|
});
|
||||||
|
xhr.open("POST", "resources/upload.py");
|
||||||
|
xhr.send(fd);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
test_formdata(function() {
|
||||||
|
var fd = new FormData();
|
||||||
|
fd.set("name", new String("value"));
|
||||||
|
return fd;
|
||||||
|
}, function(data) {
|
||||||
|
assert_equals(data, "name=value,\n");
|
||||||
|
}, "Passing a String object to FormData.set should work");
|
||||||
|
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', 'value1']).get('key'), "value1");
|
||||||
|
}, 'testFormDataSet1');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', 'value2'], ['key', 'value1']).get('key'), "value1");
|
||||||
|
}, 'testFormDataSet2');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', undefined]).get('key'), "undefined");
|
||||||
|
}, 'testFormDataSetUndefined1');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', undefined], ['key', 'value1']).get('key'), "value1");
|
||||||
|
}, 'testFormDataSetUndefined2');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', null]).get('key'), "null");
|
||||||
|
}, 'testFormDataSetNull1');
|
||||||
|
test(function() {
|
||||||
|
assert_equals(create_formdata(['key', null], ['key', 'value1']).get('key'), "value1");
|
||||||
|
}, 'testFormDataSetNull2');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.set('key', 'value1');
|
||||||
|
assert_equals(fd.get('key'), "value1");
|
||||||
|
}, 'testFormDataSetToForm1');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.set('key', 'value2');
|
||||||
|
fd.set('key', 'value1');
|
||||||
|
assert_equals(fd.get('key'), "value1");
|
||||||
|
}, 'testFormDataSetToForm2');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.set('key', undefined);
|
||||||
|
assert_equals(fd.get('key'), "undefined");
|
||||||
|
}, 'testFormDataSetToFormUndefined1');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.set('key', undefined);
|
||||||
|
fd.set('key', 'value1');
|
||||||
|
assert_equals(fd.get('key'), "value1");
|
||||||
|
}, 'testFormDataSetToFormUndefined2');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.set('key', null);
|
||||||
|
assert_equals(fd.get('key'), "null");
|
||||||
|
}, 'testFormDataSetToFormNull1');
|
||||||
|
test(function() {
|
||||||
|
var fd = new FormData(document.getElementById("form"));
|
||||||
|
fd.set('key', null);
|
||||||
|
fd.set('key', 'value1');
|
||||||
|
assert_equals(fd.get('key'), "value1");
|
||||||
|
}, 'testFormDataSetToFormNull2');
|
||||||
|
test(function() {
|
||||||
|
assert_object_equals(create_formdata(['key', new Blob(), 'blank.txt']).get('key'),
|
||||||
|
new File(new Blob(), 'blank.txt'));
|
||||||
|
}, 'testFormDataSetEmptyBlob');
|
||||||
|
|
||||||
|
function create_formdata() {
|
||||||
|
var fd = new FormData();
|
||||||
|
for (var i = 0; i < arguments.length; i++) {
|
||||||
|
fd.set.apply(fd, arguments[i]);
|
||||||
|
};
|
||||||
|
return fd;
|
||||||
|
}
|
||||||
|
</script>
|
Loading…
Add table
Add a link
Reference in a new issue