gecko-dev/testing/web-platform/tests/XMLHttpRequest/responsetext-decoding.htm
James Graham 200c3bd68c Bug 1097230 - Update web-platform-tests to revision 9840b559b10e05f659932a835c11832db9e01c42, a=testonly
--HG--
rename : testing/web-platform/meta/websockets/interfaces/WebSocket/events/011.html.ini => testing/web-platform/meta/IndexedDB/idbcursor_update_index5.htm.ini
rename : testing/web-platform/meta/websockets/interfaces/WebSocket/events/011.html.ini => testing/web-platform/meta/IndexedDB/idbindex_get7.htm.ini
rename : testing/web-platform/meta/websockets/interfaces/WebSocket/events/011.html.ini => testing/web-platform/meta/IndexedDB/idbindex_openCursor2.htm.ini
rename : testing/web-platform/meta/websockets/interfaces/WebSocket/events/011.html.ini => testing/web-platform/meta/IndexedDB/idbindex_openKeyCursor3.htm.ini
rename : testing/web-platform/moz.build => testing/web-platform/mozilla/tests/placeholder
rename : testing/web-platform/moz.build => testing/web-platform/outbound/tests/placeholder
rename : testing/web-platform/tests/dom/nodes/Document-createProcessingInstruction-literal-1.xhtml => testing/web-platform/tests/dom/nodes/ProcessingInstruction-literal-1.xhtml
rename : testing/web-platform/tests/dom/nodes/Document-createProcessingInstruction-literal-2.xhtml => testing/web-platform/tests/dom/nodes/ProcessingInstruction-literal-2.xhtml
rename : testing/web-platform/tests/pointerevents/pointerevent_lostpointercapture_for_disconnected_node.html => testing/web-platform/tests/pointerevents/pointerevent_lostpointercapture_for_disconnected_node-manual.html
rename : testing/web-platform/tests/pointerevents/pointerevent_pointerleave_after_pointercancel_touch.html => testing/web-platform/tests/pointerevents/pointerevent_pointerleave_after_pointercancel_touch-manual.html
rename : testing/web-platform/tests/pointerevents/pointerevent_pointerleave_after_pointerup_nohover.html => testing/web-platform/tests/pointerevents/pointerevent_pointerleave_after_pointerup_nohover-manual.html
rename : testing/web-platform/tests/pointerevents/pointerevent_pointerout_after_pointercancel_touch.html => testing/web-platform/tests/pointerevents/pointerevent_pointerout_after_pointercancel_touch-manual.html
rename : testing/web-platform/tests/pointerevents/pointerevent_pointerout_after_pointerup_nohover.html => testing/web-platform/tests/pointerevents/pointerevent_pointerout_after_pointerup_nohover-manual.html
rename : testing/web-platform/tests/pointerevents/pointerevent_pointerout_pen.html => testing/web-platform/tests/pointerevents/pointerevent_pointerout_pen-manual.html
rename : testing/web-platform/tests/pointerevents/pointerevent_setpointercapture_disconnected.html => testing/web-platform/tests/pointerevents/pointerevent_setpointercapture_disconnected-manual.html
rename : testing/web-platform/tests/workers/interfaces/DedicatedWorkerGlobalScope/postMessage/second-argument-null.html => testing/web-platform/tests/workers/interfaces/DedicatedWorkerGlobalScope/postMessage/second-argument-undefined.html
extra : rebase_source : 1fb6206eb45537037d28bebf5bc9de02791c4a17
2014-11-20 16:30:01 +00:00

52 lines
2.8 KiB
HTML

<!doctype html>
<html>
<head>
<title>XMLHttpRequest: responseText decoding</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<link rel="help" href="https://xhr.spec.whatwg.org/#the-responsetext-attribute" data-tested-assertations="following::ol[1]/li[4]" />
<link rel="help" href="https://xhr.spec.whatwg.org/#text-response-entity-body" data-tested-assertations="following::ol[1]/li[2] following::ol[1]/li[3] following::ol[1]/li[4] following::ol[1]/li[5]" />
</head>
<body>
<div id="log"></div>
<script>
function request(type, input, output, responseType) {
var test = async_test(document.title + " (" + type + " " + input + ")");
test.step(function() {
var client = new XMLHttpRequest()
if (responseType !== undefined) {
client.responseType = responseType
}
client.open("GET", "resources/status.py?content=" + input + "&type=" + encodeURIComponent(type), true)
client.onload = function(){
test.step(function(){
assert_equals(client.responseText, output)
test.done()
})
}
client.send(null)
})
}
request("application/xml", encodeURIComponent("<?xml version='1.0' encoding='windows-1252'?><x>")+'%FF'+encodeURIComponent("<\/x>"), "<?xml version='1.0' encoding='windows-1252'?><x>\u00FF<\/x>")
request("text/html", encodeURIComponent("<!doctype html><meta charset=windows-1252>")+"%FF", "<!doctype html><meta charset=windows-1252>\u00FF")
request("text/plain;charset=windows-1252", "%FF", "\u00FF")
request("text/plain", "%FF", "\uFFFD")
request("text/plain", "%FE%FF", "")
request("text/plain", "%FE%FF%FE%FF", "\uFEFF")
request("text/plain", "%EF%BB%BF", "")
request("text/plain", "%EF%BB%BF%EF%BB%BF", "\uFEFF")
request("text/plain", "%C2", "\uFFFD")
// XXX might need fixing
request("text/xml", "%FE%FF", "")
request("text/xml", "%FE%FF%FE%FF", "\uFEFF")
request("text/xml", "%EF%BB%BF", "")
request("text/xml", "%EF%BB%BF%EF%BB%BF", "\uFEFF")
request("text/plain", "%E3%81%B2", "\u3072", 'text')
// the point of the following test: setting responseType=text should (per spec #text-response-entity-body point 3)
// skip some of the charset detection even for XML resources. The test uses a wilfully mislabelled XMLish response
// and the pass condition is that the responseType = text makes the decoder fall back to UTF-8
request("text/xml", encodeURIComponent("<?xml version='1.0' encoding='windows-1252'?><x>")+"%E3%81%B2"+encodeURIComponent("<\/x>"), "<?xml version='1.0' encoding='windows-1252'?><x>\u3072<\/x>", 'text')
</script>
</body>
</html>