summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/css-properties-values-api/self-utils.html
blob: b770c86c38269656d77c3e382d3fe0391cdd8cd0 (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
<!DOCTYPE html>
<title>Self-test for utils.js</title>
<link rel="help" href="https://drafts.css-houdini.org/css-properties-values-api-1/">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="./resources/utils.js"></script>
<div id=outer><div id=inner></div></div>
<script>

test(function(){
  let syntaxes = all_syntaxes().concat([
    'foo',
    'bar | <length>',
    '<angle> | <length>'
  ]);
  // Don't throw:
  syntaxes.forEach(generate_property);
}, 'Default initial values of generated properties are valid (self-test).');

test(function(){
  try {
    let inherited = generate_property({ syntax: '<length>', inherits: true });
    let non_inherited = generate_property({ syntax: '<length>', inherits: false, initialValue: '5px' });
    outer.style = `${inherited}: 10px; ${non_inherited}: 11px;`;
    assert_equals(getComputedStyle(outer).getPropertyValue(inherited), '10px');
    assert_equals(getComputedStyle(outer).getPropertyValue(non_inherited), '11px');
    assert_equals(getComputedStyle(inner).getPropertyValue(inherited), '10px');
    assert_equals(getComputedStyle(inner).getPropertyValue(non_inherited), '5px');
  } finally {
    outer.style = '';
    inner.style = '';
  }
}, 'Generated properties respect inherits flag');

test(function(){
  assert_throws_js(Error, () => generate_property({syntax: '<length>', foo: 1}));
  assert_throws_js(Error, () => generate_property({syntax: '<length>', inherited: false}));
  assert_throws_js(Error, () => generate_property({syntax: '<length>', initial: '10px'}));
}, 'Can\'t generate property with unknown fields');

</script>