File: responsetext-decoding.htm

package info (click to toggle)
thunderbird 1%3A52.8.0-1~deb8u1
  • links: PTS, VCS
  • area: main
  • in suites: jessie
  • size: 1,710,120 kB
  • sloc: cpp: 5,081,109; ansic: 2,051,982; python: 458,727; java: 241,615; xml: 193,367; asm: 178,649; sh: 81,881; makefile: 24,703; perl: 16,874; objc: 4,389; yacc: 1,816; ada: 1,697; lex: 1,257; pascal: 1,251; cs: 879; exp: 499; php: 436; lisp: 258; awk: 152; sed: 51; ruby: 47; csh: 27
file content (52 lines) | stat: -rw-r--r-- 2,841 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
<!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>