tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

test-009.html (12418B)


      1 <!DOCTYPE html>
      2 <html>
      3 <head>
      4 <title>Shadow DOM Test: A_04_01_09</title>
      5 <link rel="author" title="Aleksei Yu. Semenov" href="mailto:a.semenov@unipro.ru">
      6 <link rel="author" title="Sergey G. Grekhov" href="mailto:sgrekhov@unipro.ru">
      7 <link rel="author" title="Mikhail Fursov" href="mailto:mfursov@unipro.ru">
      8 <link rel="help" href="http://www.w3.org/TR/2013/WD-shadow-dom-20130514/#upper-boundary-encapsulation">
      9 <meta name="assert" content="Upper-boundary encapsulation: no nodes other than shadow root descendants are accessible with shadow root DOM tree accessor methods">
     10 <script src="/resources/testharness.js"></script>
     11 <script src="/resources/testharnessreport.js"></script>
     12 <script src="../../../../html/resources/common.js"></script>
     13 </head>
     14 <body>
     15 <div id="log"></div>
     16 <script>
     17 var A_04_01_09 = new Object();
     18 
     19 A_04_01_09.setupBlock = function (ctx, prefix, root) {
     20    // create <div id='prefix+_id1' class='cls'><p class='cls'><div id='prefix+_id2' class='cls'></div></p></div> like structure
     21    // where <p> will be used as shadow host element
     22 
     23    ctx[prefix + '_div1'] = ctx.d.createElement('div');
     24    ctx[prefix + '_div1'].setAttribute('id', prefix + '_id1');
     25    ctx[prefix + '_div1'].setAttribute('class', 'cls');
     26 
     27    ctx[prefix + '_p1'] = ctx.d.createElement('p');
     28    ctx[prefix + '_p1'].setAttribute('class', 'cls');
     29    ctx[prefix + '_p1'].setAttribute('test', 'A_04_01_09');
     30 
     31    ctx[prefix + '_div2'] = ctx.d.createElement('div');
     32    ctx[prefix + '_div2'].setAttribute('id', prefix + '_id2');
     33    ctx[prefix + '_div2'].setAttribute('class', 'cls');
     34    ctx[prefix + '_div2'].setAttribute('test', 'A_04_01_09');
     35 
     36    root.appendChild(ctx[prefix + '_div1']);
     37    ctx[prefix + '_div1'].appendChild(ctx[prefix + '_p1']);
     38    ctx[prefix + '_p1'].appendChild(ctx[prefix + '_div2']);
     39 };
     40 
     41 A_04_01_09.setup = function () {
     42    var ctx = {};
     43 
     44    ctx.d = newHTMLDocument();
     45    A_04_01_09.setupBlock(ctx, 'd', ctx.d.body);
     46 
     47    ctx.s1 = ctx.d_p1.attachShadow({mode: 'open'});
     48    A_04_01_09.setupBlock(ctx, 's1', ctx.s1);
     49 
     50    ctx.s2 = ctx.s1_p1.attachShadow({mode: 'open'});
     51    A_04_01_09.setupBlock(ctx, 's2', ctx.s2);
     52 
     53    assert_true(ctx.d_div1 != null, 'setup:d_div1');
     54    assert_true(ctx.d_div2 != null, 'setup:d_div2');
     55    assert_true(ctx.s1_div1 != null, 'setup: s1_div1');
     56    assert_true(ctx.s1_div2 != null, 'setup: s1_div2');
     57    assert_true(ctx.s2_div1 != null, 'setup: s2_div1');
     58    assert_true(ctx.s2_div2 != null, 'setup: s2_div2');
     59 
     60    return ctx;
     61 };
     62 
     63 //check querySelectorAll
     64 test(function () {
     65    var ctx = A_04_01_09.setup();
     66 
     67    assert_nodelist_contents_equal_noorder(
     68        ctx.s1.querySelectorAll('div'), [ctx.s1_div1, ctx.s1_div2],
     69        'nodes, other than shadow root descendants, should not be accessible with ' +
     70            'ShadowRoot.getElementsByTagName (s1)');
     71 
     72    assert_nodelist_contents_equal_noorder(
     73        ctx.s2.querySelectorAll('div'), [ctx.s2_div1, ctx.s2_div2],
     74        'nodes, other than shadow root descendants, should not be accessible with ' +
     75            'ShadowRoot.getElementsByTagName (s2)');
     76 
     77 }, 'A_04_01_09_T01');
     78 
     79 //check querySelectorAll for class
     80 test(function () {
     81    var ctx = A_04_01_09.setup();
     82 
     83    assert_nodelist_contents_equal_noorder(
     84        ctx.s1.querySelectorAll('.cls'), [ctx.s1_div1, ctx.s1_p1, ctx.s1_div2],
     85        'nodes, other than shadow root descendants, should not be accessible with ' +
     86            'ShadowRoot.getElementsByClassName (s1)');
     87 
     88    assert_nodelist_contents_equal_noorder(
     89        ctx.s2.querySelectorAll('.cls'), [ctx.s2_div1, ctx.s2_p1, ctx.s2_div2],
     90        'nodes, other than shadow root descendants, should not be accessible with ' +
     91            'ShadowRoot.getElementsByClassName (s2)');
     92 
     93 }, 'A_04_01_09_T03');
     94 
     95 // check querySelector for id
     96 test(function () {
     97    var ctx = A_04_01_09.setup();
     98 
     99    assert_equals(ctx.d.querySelector('#s1_id1'), null, 'Expected no access to s1_div1 from d.querySelector()');
    100    assert_equals(ctx.d.querySelector('#s1_id2'), null, 'Expected no access to s1_div2 from d.querySelector()');
    101    assert_equals(ctx.d.querySelector('#s2_id1'), null, 'Expected no access to s2_div1 from d.querySelector()');
    102    assert_equals(ctx.d.querySelector('#s2_id2'), null, 'Expected no access to s2_div1 from d.querySelector()');
    103 
    104    assert_equals(ctx.s1.querySelector('#d_id1'), null, 'Expected no access to d_div1 from s1.querySelector()');
    105    assert_equals(ctx.s1.querySelector('#d_id2'), null, 'Expected no access to d_div2 from s1.querySelector()');
    106    assert_equals(ctx.s2.querySelector('#d_id1'), null, 'Expected no access to d_div1 from s2.querySelector()');
    107    assert_equals(ctx.s2.querySelector('#d_id2'), null, 'Expected no access to d_div1 from s2.querySelector()');
    108 
    109    assert_equals(ctx.d.querySelector('#d_id1'), ctx.d_div1, 'Expected access to d_div1 form d.querySelector()');
    110    assert_equals(ctx.d.querySelector('#d_id2'), ctx.d_div2, 'Expected access to d_div2 form d.querySelector()');
    111    assert_equals(ctx.s1.querySelector('#s1_id1'), ctx.s1_div1, 'Expected access to s1_div1 form s1.querySelector()');
    112    assert_equals(ctx.s1.querySelector('#s1_id2'), ctx.s1_div2, 'Expected access to s1_div2 form s1.querySelector()');
    113    assert_equals(ctx.s2.querySelector('#s2_id1'), ctx.s2_div1, 'Expected access to s2_div1 form s2.querySelector()');
    114    assert_equals(ctx.s2.querySelector('#s2_id2'), ctx.s2_div2, 'Expected access to s2_div2 form s2.querySelector()');
    115 
    116    assert_equals(ctx.s1.querySelector('#s2_id1'), null, 'Expected no access to s2_div1 form s1.querySelector()');
    117    assert_equals(ctx.s1.querySelector('#s2_id2'), null, 'Expected no access to s2_div2 form s1.querySelector()');
    118    assert_equals(ctx.s2.querySelector('#s1_id1'), null, 'Expected no access to s1_div1 form s2.querySelector()');
    119    assert_equals(ctx.s2.querySelector('#s1_id2'), null, 'Expected no access to s1_div2 form s2.querySelector()');
    120 
    121 }, 'A_04_01_09_T05');
    122 
    123 
    124 //check querySelector for element
    125 test(function () {
    126    var ctx = A_04_01_09.setup();
    127 
    128    assert_equals(ctx.d.querySelector('p'), ctx.d_p1, 'Expected access to d_p1 from d.querySelector()');
    129    assert_equals(ctx.s1.querySelector('p'), ctx.s1_p1, 'Expected access to s1_p1 from s1.querySelector()');
    130    assert_equals(ctx.s2.querySelector('p'), ctx.s2_p1, 'Expected access to s2_p1 from s2.querySelector()');
    131 
    132 }, 'A_04_01_09_T06');
    133 
    134 // check querySelectorAll for element
    135 test(function () {
    136    var ctx = A_04_01_09.setup();
    137 
    138    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('p'), [ctx.d_p1], 'Expected access to d_p1 from d.querySelectorAll()');
    139    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('p'), [ctx.s1_p1], 'Expected access to s1_p1 s1.querySelectorAll');
    140    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('p'), [ctx.s2_p1], 'Expected access to s2_p1 from s2.querySelectorAll');
    141 
    142 }, 'A_04_01_09_T07');
    143 
    144 // check querySelectorAll for class
    145 test(function () {
    146    var ctx = A_04_01_09.setup();
    147 
    148    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('.cls'), [ctx.d_div1, ctx.d_p1, ctx.d_div2], 'd.querySelectorAll() return wrong result');
    149    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('.cls'), [ctx.s1_div1, ctx.s1_p1, ctx.s1_div2], 's1.querySelectorAll() return wrong result');
    150    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('.cls'), [ctx.s2_div1, ctx.s2_p1, ctx.s2_div2], 's2.querySelectorAll() return wrong result');
    151 
    152 }, 'A_04_01_09_T08');
    153 
    154 //check querySelectorAll with whildcat
    155 test(function () {
    156    var ctx = A_04_01_09.setup();
    157 
    158    //assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('*'), [ctx.d_div1, ctx.d_p1, ctx.d_div2], 'd.querySelectorAll');
    159    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('*'), [ctx.s1_div1, ctx.s1_p1, ctx.s1_div2], 's1.querySelectorAll(\'*\') return wrong result');
    160    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('*'), [ctx.s2_div1, ctx.s2_p1, ctx.s2_div2], 's2.querySelectorAll(\'*\') return wrong result');
    161 
    162 }, 'A_04_01_09_T09');
    163 
    164 //check querySelectorAll with attribute value
    165 test(function () {
    166    var ctx = A_04_01_09.setup();
    167 
    168    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('[test=A_04_01_09]'), [ctx.d_p1, ctx.d_div2], 'd.querySelectorAll(\'[test=A_04_01_09]\') return wrong result');
    169    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('[test=A_04_01_09]'), [ctx.s1_p1, ctx.s1_div2], 's1.querySelectorAll(\'[test=A_04_01_09]\') return wrong result');
    170    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('[test=A_04_01_09]'), [ctx.s2_p1, ctx.s2_div2], 's2.querySelectorAll(\'[test=A_04_01_09]\') return wrong result');
    171 
    172 }, 'A_04_01_09_T10');
    173 
    174 //check querySelectorAll with parent-child selection
    175 test(function () {
    176    var ctx = A_04_01_09.setup();
    177 
    178    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('div:first-child'), [ctx.d_div1, ctx.d_div2], 'd.querySelectorAll(\'div:first-child\') return wrong result');
    179    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('div:first-child'), [ctx.s1_div1,ctx.s1_div2], 's1.querySelectorAll(\'div:first-child\') return wrong result');
    180    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('div:first-child'), [ctx.s2_div1,ctx.s2_div2], 's2.querySelectorAll(\'div:first-child\') return wrong result');
    181 
    182 }, 'A_04_01_09_T11');
    183 
    184 //check querySelectorAll with parent-child selection
    185 test(function () {
    186    var ctx = A_04_01_09.setup();
    187 
    188    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('div:last-child'), [ctx.d_div1, ctx.d_div2], 'd.querySelectorAll(\'div:last-child\') return wrong result');
    189    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('div:last-child'), [ctx.s1_div1, ctx.s1_div2], 's1.querySelectorAll(\'div:last-child\') return wrong result');
    190    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('div:last-child'), [ctx.s2_div1, ctx.s2_div2], 's2.querySelectorAll(\'div:last-child\') return wrong result');
    191 
    192 }, 'A_04_01_09_T12');
    193 
    194 //check querySelectorAll with parent-child selection
    195 test(function () {
    196    var ctx = A_04_01_09.setup();
    197 
    198    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('p:only-child'), [ctx.d_p1], 'd.querySelectorAll(\'p:only-child\') return wrong result');
    199    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('p:only-child'), [ctx.s1_p1], 's1.querySelectorAll(\'p:only-child\') return wrong result');
    200    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('p:only-child'), [ctx.s2_p1], 's2.querySelectorAll(\'p:only-child\') return wrong result');
    201 
    202 }, 'A_04_01_09_T13');
    203 
    204 //check querySelectorAll with parent-child selection
    205 test(function () {
    206    var ctx = A_04_01_09.setup();
    207 
    208    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('div:empty'), [ctx.d_div2], 'd.querySelectorAll(\'div:empty\') return wrong result');
    209    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('div:empty'), [ctx.s1_div2], 's1.querySelectorAll(\'div:empty\') return wrong result');
    210    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('div:empty'), [ctx.s2_div2], 's2.querySelectorAll(\'div:empty\') return wrong result');
    211 
    212 }, 'A_04_01_09_T14');
    213 
    214 //check querySelectorAll with parent-child selection
    215 test(function () {
    216    var ctx = A_04_01_09.setup();
    217 
    218    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('p div'), [ctx.d_div2], 'd.querySelectorAll(\'p div\') return wrong result');
    219    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('p div'), [ctx.s1_div2], 's1.querySelectorAll(\'p div\') return wrong result');
    220    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('p div'), [ctx.s2_div2], 's2.querySelectorAll(\'p div\') return wrong result');
    221 
    222 }, 'A_04_01_09_T15');
    223 
    224 //check querySelectorAll with parent-child selection
    225 test(function () {
    226    var ctx = A_04_01_09.setup();
    227 
    228    assert_nodelist_contents_equal_noorder(ctx.d.querySelectorAll('p > div'), [ctx.d_div2], 'd.querySelectorAll(\'p > div\') return wrong result');
    229    assert_nodelist_contents_equal_noorder(ctx.s1.querySelectorAll('p > div'), [ctx.s1_div2], 's1.querySelectorAll(\'p > div\') return wrong result');
    230    assert_nodelist_contents_equal_noorder(ctx.s2.querySelectorAll('p > div'), [ctx.s2_div2], 's2.querySelectorAll(\'p > div\') return wrong result');
    231 
    232 }, 'A_04_01_09_T16');
    233 </script>
    234 </body>
    235 </html>