summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/css-page/parsing/nested-rules-001.html
blob: 23c8eb0894c6a9d28f60e2afd4e4de5c4d0765b2 (plain)
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<!DOCTYPE html>
<link rel="author" title="Mozilla" href="https://mozilla.org">
<link rel="help" href="https://drafts.csswg.org/css-page-3/#syntax-page-selector">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<style>
@page p0{
  @page a{ size: letter; }
}
@page p1{
  @namespace svg url(http://www.w3.org/2000/svg);
}
@page p2{
  @font-face{}
}
@page p3{
  @font-feature-values font one{}
}
@page p4{
  @font-palette-values --alternate{}
}
@page p5{
  @counter-style x{}
}
@page p6{
  @keyframes y{}
}
@page p7{
  @property z{
    syntax: "<color>";
    inherits: false;
    initial-value: #c0ffee;
  }
}
@page p8{
  @import url("style.css") screen;
}
</style>

<script>
'use strict';
test(t => {
  assert_equals(document.styleSheets.length, 1);
  let styleSheet = document.styleSheets[0];
  const ruleTypes = [
    "page",
    "namespace",
    "font-face",
    "font-feature-values",
    "font-palette-values",
    "counter-style",
    "keyframes",
    "property",
    "import"
  ];
  assert_equals(styleSheet.rules.length, ruleTypes.length);
  for(let i = 0; i < styleSheet.rules.length; i++){
    // Just test that this is the right rule first.
    assert_equals(styleSheet.rules[i].selectorText, "p" + i,
        "@page p" + i + " was not parsed at all");
    // Test that the nested rule was not valid.
    assert_equals(styleSheet.rules[i].cssText, "@page p" + i + " { }",
        "@" + ruleTypes[i] + " rules should not be allowed in @page rules");
  }
}, "nested-rules-001");
</script>