LCOV - code coverage report
Current view: top level - test/wpt/xhr - setrequestheader-header-allowed.js (source / functions) Hit Total Coverage
Test: lcov.info Lines: 72 72 100.0 %
Date: 2024-12-07 00:20:21 Functions: 2 2 100.0 %
Branches: 3 3 100.0 %

           Branch data     Line data    Source code
       1            [ + ]:          2 : import assert from 'node:assert/strict';
       2                 :          2 : import { XMLHttpRequest } from '../../../lib/whatwg-xhr.js';
       3                 :          2 : 
       4            [ + ]:          2 : export default (activeURL) => {
       5                 :          1 : 
       6                 :          1 :         request('Authorization');
       7                 :          1 :         request('Pragma');
       8                 :          1 :         request('User-Agent');
       9                 :          1 :         request('Content-Transfer-Encoding');
      10                 :          1 :         request('Content-Type');
      11                 :          1 :         request('Overwrite');
      12                 :          1 :         request('If');
      13                 :          1 :         request('Status-URI');
      14                 :          1 :         request('X-Pink-Unicorn');
      15                 :          1 :         request("!#$%&'*+-.^_`|~0123456789abcdefghijklmnopqrstuvwxyz");
      16                 :          1 : 
      17            [ + ]:          1 :         function request(header){
      18                 :         10 : 
      19                 :         10 :                 const xhr = new XMLHttpRequest();
      20                 :         10 : 
      21                 :         10 :                 xhr.open('POST', `${activeURL}/inspect-headers.py?filter_value=t1, t2`, false);
      22                 :         10 : 
      23                 :         10 :                 xhr.setRequestHeader(header, 't1');
      24                 :         10 :                 xhr.setRequestHeader(header, 't2');
      25                 :         10 :                 xhr.send();
      26                 :         10 : 
      27                 :         10 :                 assert.strictEqual(xhr.responseText, header + ',');
      28                 :         10 :         }
      29                 :          1 : }
      30                 :          2 : 
      31                 :          2 : /*
      32                 :          2 :  * setrequestheader-header-allowed.htm
      33                 :          2 :  *
      34                 :          2 : 
      35                 :          2 : <!doctype html>
      36                 :          2 : <html>
      37                 :          2 :   <head>
      38                 :          2 :     <title>XMLHttpRequest: setRequestHeader() - headers that are allowed</title>
      39                 :          2 :     <script src="/resources/testharness.js"></script>
      40                 :          2 :     <script src="/resources/testharnessreport.js"></script>
      41                 :          2 :     <link rel="help" href="https://xhr.spec.whatwg.org/#the-setrequestheader()-method">
      42                 :          2 :   </head>
      43                 :          2 :   <body>
      44                 :          2 :     <div id="log"></div>
      45                 :          2 :     <script>
      46                 :          2 :       function request(header) {
      47                 :          2 :         test(function() {
      48                 :          2 :           var client = new XMLHttpRequest()
      49                 :          2 :           client.open("POST", "resources/inspect-headers.py?filter_value=t1, t2", false)
      50                 :          2 :           client.setRequestHeader(header, "t1")
      51                 :          2 :           client.setRequestHeader(header, "t2")
      52                 :          2 :           client.send(null)
      53                 :          2 :           assert_equals(client.responseText, header + ",")
      54                 :          2 :         }, document.title + " (" + header + ")")
      55                 :          2 :       }
      56                 :          2 :       request("Authorization")
      57                 :          2 :       request("Pragma")
      58                 :          2 :       request("User-Agent")
      59                 :          2 :       request("Content-Transfer-Encoding")
      60                 :          2 :       request("Content-Type")
      61                 :          2 :       request("Overwrite")
      62                 :          2 :       request("If")
      63                 :          2 :       request("Status-URI")
      64                 :          2 :       request("X-Pink-Unicorn")
      65                 :          2 :       request("!#$%&'*+-.^_`|~0123456789abcdefghijklmnopqrstuvwxyz")
      66                 :          2 :     </script>
      67                 :          2 :   </body>
      68                 :          2 : </html>
      69                 :          2 : 
      70                 :          2 :  *
      71                 :          2 :  * setrequestheader-header-allowed.htm
      72                 :          2 :  */

Generated by: LCOV version 1.14