diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
commit | 43a97878ce14b72f0981164f87f2e35e14151312 (patch) | |
tree | 620249daf56c0258faa40cbdcf9cfba06de2a846 /testing/web-platform/tests/css/css-properties-values-api/unit-cycles.html | |
parent | Initial commit. (diff) | |
download | firefox-43a97878ce14b72f0981164f87f2e35e14151312.tar.xz firefox-43a97878ce14b72f0981164f87f2e35e14151312.zip |
Adding upstream version 110.0.1.upstream/110.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/css/css-properties-values-api/unit-cycles.html')
-rw-r--r-- | testing/web-platform/tests/css/css-properties-values-api/unit-cycles.html | 248 |
1 files changed, 248 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/css-properties-values-api/unit-cycles.html b/testing/web-platform/tests/css/css-properties-values-api/unit-cycles.html new file mode 100644 index 0000000000..9454c95ac3 --- /dev/null +++ b/testing/web-platform/tests/css/css-properties-values-api/unit-cycles.html @@ -0,0 +1,248 @@ +<!DOCTYPE html> +<link rel="help" href="https://drafts.css-houdini.org/css-properties-values-api-1/#dependency-cycles-via-relative-units" /> +<meta name="assert" content="This test verifies that reference cycles via units are detected" /> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> + function register_length(name, inherits=false) { + CSS.registerProperty({ + name: name, + syntax: '<length>', + initialValue: '0px', + inherits: inherits + }); + } + + register_length('--font-size-em'); + register_length('--font-size-rem'); + register_length('--font-size-ex'); + register_length('--font-size-ch'); + register_length('--font-size-px'); + register_length('--font-size-lh'); + register_length('--font-size-em-via-var'); + register_length('--font-size-rem-via-var'); + register_length('--font-size-ex-via-var'); + register_length('--font-size-ch-via-var'); + register_length('--font-size-em-inherited', true); + register_length('--font-size-ex-inherited', true); + register_length('--font-size-ch-inherited', true); + register_length('--line-height-lh'); + register_length('--line-height-lh-via-var'); + register_length('--line-height-lh-inherited', true); +</script> +<style> + :root { + --unregistered-em: 10em; + --unregistered-rem: 10rem; + --unregistered-ex: 10ex; + --unregistered-ch: 10ch; + --unregistered-lh: 10lh; + } + + :root, #target { + --font-size-em: 2em; + --font-size-rem: 2rem; + --font-size-ex: 2ex; + --font-size-ch: 2ch; + --font-size-px: 42px; + --font-size-lh: 2lh; + --line-height-lh: 2lh; + --font-size-em-via-var: var(--unregistered-em); + --font-size-rem-via-var: var(--unregistered-rem); + --font-size-ex-via-var: var(--unregistered-ex); + --font-size-ch-via-var: var(--unregistered-ch); + --line-height-lh-via-var: var(--unregistered-lh); + } + + #parent { + --font-size-em-inherited: 4em; + --font-size-ex-inherited: 4ex; + --font-size-ch-inherited: 4ch; + --line-height-lh-inherited: 4lh; + } + + #target { + font-size: 11px; + line-height: 13px; + } +</style> + +<div id=parent> + <div id=target></div> +</div> +<div id=ref></div> + +<script> + + // Compute a dimension (e.g. 1em) given a certain fontSize. + function compute_dimension(dimension, fontSize, element = ref) { + try { + element.attributeStyleMap.set('font-size', fontSize); + element.attributeStyleMap.set('margin-bottom', dimension); + return getComputedStyle(element).marginBottom; + } finally { + element.attributeStyleMap.clear(); + } + } + + function assert_property_equals(name, value, element = target) { + var computedStyle = getComputedStyle(element); + assert_equals(computedStyle.getPropertyValue(name), value); + } + + let unsetFontSize = compute_dimension('1em', 'unset'); + const unsetLineHeight = "normal"; + + add_result_callback(function(){ + target.attributeStyleMap.clear(); + document.documentElement.attributeStyleMap.clear(); + }); + + test(function() { + target.style = 'font-size: var(--font-size-px);'; + assert_property_equals('font-size', '42px'); + assert_property_equals('--font-size-px', '42px'); + }, 'Non-font-dependent variables can be used in font-size'); + + test(function() { + target.style = 'font-size: var(--font-size-em);'; + assert_property_equals('font-size', unsetFontSize); + assert_property_equals('--font-size-em', '0px'); + }, 'Lengths with em units may not be referenced from font-size'); + + test(function() { + target.style = 'font-size: var(--font-size-ex);'; + assert_property_equals('font-size', unsetFontSize); + assert_property_equals('--font-size-ex', '0px'); + }, 'Lengths with ex units may not be referenced from font-size'); + + test(function() { + target.style = 'font-size: var(--font-size-ch);'; + assert_property_equals('font-size', unsetFontSize); + assert_property_equals('--font-size-ch', '0px'); + }, 'Lengths with ch units may not be referenced from font-size'); + + test(function() { + target.style = 'font-size: var(--font-size-lh);'; + assert_property_equals('font-size', unsetFontSize); + assert_property_equals('--font-size-lh', '0px'); + }, 'Lengths with lh units may not be referenced from font-size'); + + test(function() { + target.style = 'font-size: var(--font-size-rem);'; + let expected = compute_dimension('2rem', 'unset', document.documentElement); + assert_property_equals('--font-size-rem', expected); + assert_property_equals('font-size', expected); + }, 'Lengths with rem units may be referenced from font-size on non-root element'); + + test(function() { + let root = document.documentElement; + root.style = 'font-size: var(--font-size-rem);'; + assert_property_equals('font-size', unsetFontSize, root); + assert_property_equals('--font-size-rem', '0px', root); + }, 'Lengths with rem units may not be referenced from font-size on root element'); + + test(function() { + target.style = 'line-height: var(--line-height-lh);'; + assert_property_equals('line-height', unsetLineHeight); + assert_property_equals('--line-height-lh', '0px'); + }, 'Lengths with lh units may not be referenced from line-height'); + + test(function() { + target.style = 'font-size: var(--noexist, var(--font-size-em));'; + assert_property_equals('font-size', unsetFontSize); + }, 'Fallback may not use font-relative units'); + + test(function() { + target.style = 'line-height: var(--noexist, var(--line-height-lh));'; + assert_property_equals('line-height', unsetLineHeight); + }, 'Fallback may not use line-height-relative units'); + + test(function() { + target.style = 'font-size: var(--font-size-em, 42px);'; + assert_property_equals('font-size', unsetFontSize); + }, 'Fallback not triggered while inside em unit cycle'); + + test(function() { + target.style = 'font-size: var(--font-size-ex, 42px);'; + assert_property_equals('font-size', unsetFontSize); + }, 'Fallback not triggered while inside ex unit cycle'); + + test(function() { + target.style = 'font-size: var(--font-size-ch, 42px);'; + assert_property_equals('font-size', unsetFontSize); + }, 'Fallback not triggered while inside ch unit cycle'); + + test(function() { + let root = document.documentElement; + root.style = 'font-size: var(--font-size-rem, 42px);'; + assert_property_equals('font-size', unsetFontSize, root); + root.style = 'font-size: unset;'; + }, 'Fallback not triggered while inside rem unit cycle on root element'); + + test(function() { + target.style = 'line-height: var(--line-height-lh, 42px);'; + assert_property_equals('line-height', unsetLineHeight); + }, 'Fallback not triggered while inside lh unit cycle'); + + test(function() { + target.style = 'font-size: var(--font-size-em-via-var);'; + assert_property_equals('font-size', unsetFontSize); + assert_property_equals('--font-size-em-via-var', '0px'); + }, 'Lengths with em units are detected via var references'); + + test(function() { + target.style = 'font-size: var(--font-size-ex-via-var);'; + assert_property_equals('font-size', unsetFontSize); + assert_property_equals('--font-size-ex-via-var', '0px'); + }, 'Lengths with ex units are detected via var references'); + + test(function() { + target.style = 'font-size: var(--font-size-ch-via-var);'; + assert_property_equals('font-size', unsetFontSize); + assert_property_equals('--font-size-ch-via-var', '0px'); + }, 'Lengths with ch units are detected via var references'); + + test(function() { + let root = document.documentElement; + root.style = 'font-size: var(--font-size-rem-via-var);'; + assert_property_equals('font-size', unsetFontSize, root); + assert_property_equals('--font-size-rem-via-var', '0px', root); + root.style = 'font-size: unset'; + }, 'Lengths with rem units are detected via var references'); + + test(function() { + target.style = 'line-height: var(--line-height-lh-via-var);'; + assert_property_equals('line-height', unsetLineHeight); + assert_property_equals('--line-height-lh-via-var', '0px'); + }, 'Lengths with lh units are detected via var references'); + + test(function() { + let expected4em = compute_dimension('4em', 'unset'); + target.style = 'font-size: var(--font-size-em-inherited);'; + assert_property_equals('font-size', expected4em); + assert_property_equals('--font-size-em-inherited', expected4em); + }, 'Inherited lengths with em units may be used'); + + test(function() { + let expected4ex = compute_dimension('4ex', 'unset'); + target.style = 'font-size: var(--font-size-ex-inherited);'; + assert_property_equals('font-size', expected4ex); + assert_property_equals('--font-size-ex-inherited', expected4ex); + }, 'Inherited lengths with ex units may be used'); + + test(function() { + let expected4ch = compute_dimension('4ch', 'unset'); + target.style = 'font-size: var(--font-size-ch-inherited);'; + assert_property_equals('font-size', expected4ch); + assert_property_equals('--font-size-ch-inherited', expected4ch); + }, 'Inherited lengths with ch units may be used'); + + test(function() { + let expected4lh = compute_dimension('4lh', 'unset'); + target.style = 'line-height: var(--line-height-lh-inherited);'; + assert_property_equals('line-height', expected4lh); + assert_property_equals('--line-height-lh-inherited', expected4lh); + }, 'Inherited lengths with lh units may be used'); + +</script> |