diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/xhr/send-data-es-object.any.js | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/xhr/send-data-es-object.any.js')
-rw-r--r-- | testing/web-platform/tests/xhr/send-data-es-object.any.js | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/testing/web-platform/tests/xhr/send-data-es-object.any.js b/testing/web-platform/tests/xhr/send-data-es-object.any.js new file mode 100644 index 0000000000..92286bca6d --- /dev/null +++ b/testing/web-platform/tests/xhr/send-data-es-object.any.js @@ -0,0 +1,58 @@ +// META: title=XMLHttpRequest.send(ES object) + +function do_test(obj, expected, name) { + var test = async_test(name) + test.step(function() { + var client = new XMLHttpRequest() + client.onload = test.step_func(function () { + assert_equals(client.responseText, expected) + test.done() + }); + client.open('POST', 'resources/content.py') + if (expected.exception) { + if (expected.exception.identity) { + assert_throws_exactly(expected.exception.identity, + function(){client.send(obj)}) + } else { + assert_throws_js(expected.exception.ctor, + function(){client.send(obj)}) + } + test.done() + } else { + client.send(obj) + } + }); +} + +do_test({}, '[object Object]', 'sending a plain empty object') +do_test(Math, '[object Math]', 'sending the ES Math object') +do_test(new XMLHttpRequest, '[object XMLHttpRequest]', 'sending a new XHR instance') +do_test(new ReadableStream, '[object ReadableStream]', 'sending a new ReadableStream instance') +do_test({toString:function(){}}, 'undefined', 'sending object that stringifies to undefined') +do_test({toString:function(){return null}}, 'null', 'sending object that stringifies to null') +var ancestor = {toString: function(){ + var ar=[] + for (var prop in this) { + if (this.hasOwnProperty(prop)) { + ar.push(prop+'='+this[prop]) + } + }; + return ar.join('&') +}}; + +var myObj = Object.create(ancestor, {foo:{value:1, enumerable: true}, bar:{value:'foo', enumerable:true}}) +do_test(myObj, 'foo=1&bar=foo', 'object that stringifies to query string') + +var myFakeJSON = {a:'a', b:'b', toString:function(){ return JSON.stringify(this, function(key, val){ return key ==='toString'?undefined:val; }) }} +do_test(myFakeJSON, '{"a":"a","b":"b"}', 'object that stringifies to JSON string') + +var myFakeDoc1 = {valueOf:function(){return document}} +do_test(myFakeDoc1, '[object Object]', 'object whose valueOf() returns a document - ignore valueOf(), stringify') + +var myFakeDoc2 = {toString:function(){return document}} +var expectedError = self.GLOBAL.isWorker() ? ReferenceError : TypeError; +do_test(myFakeDoc2, {exception: { ctor: expectedError } }, 'object whose toString() returns a document, expected to throw') + +var err = {name:'FooError', message:'bar'}; +var myThrower = {toString:function(){throw err;}}; +do_test(myThrower, {exception: { identity: err }}, 'object whose toString() throws, expected to throw') |