gecko-dev/layout/style/test/test_position_sticky.html
Brian Grinstead ede8c44ef2 Bug 1544322 - Part 2.1 - Remove the [type] attribute for one-liner <script> tags loading files in /tests/SimpleTest/ in everything except for dom/ r=bzbarsky
This excludes dom/, otherwise the file size is too large for phabricator to handle.

This is an autogenerated commit to handle scripts loading mochitest harness files, in
the simple case where the script src is on the same line as the tag.

This was generated with https://bug1544322.bmoattachments.org/attachment.cgi?id=9058170
using the `--part 2` argument.

Differential Revision: https://phabricator.services.mozilla.com/D27456

--HG--
extra : moz-landing-system : lando
2019-04-16 03:50:44 +00:00

90 lines
2.2 KiB
HTML

<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=886646
-->
<head>
<meta charset="utf-8">
<title>Test for Bug 886646</title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
<style type="text/css">
#scroller {
width: 100px;
height: 100px;
padding: 10px;
border: 10px solid black;
margin: 10px;
overflow: hidden;
}
#container {
width: 50px;
height: 50px;
}
#sticky {
position: sticky;
width: 10px;
height: 10px;
overflow: hidden;
}
</style>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=886646">Mozilla Bug 886646</a>
<div id="display">
<div id="scroller">
<div id="container">
<div id="sticky"></div>
</div>
</div>
</div>
<pre id="test">
<script type="application/javascript">
/** Test for Bug 886646 - Offsets for sticky positioning, when accessed through
* getComputedStyle(), should be accurately computed. In particular,
* percentage offsets should be computed in terms of the scroll container's
* content box. */
// Test that percentage sticky offsets are computed in terms of the
// scroll container's content box
var offsets = {
"top": 10,
"left": 20,
"bottom": 30,
"right": 40,
};
var scroller = document.getElementById("scroller");
var container = document.getElementById("container");
var sticky = document.getElementById("sticky");
var cs = getComputedStyle(sticky, "");
for (var prop in offsets) {
sticky.style[prop] = offsets[prop] + "%";
is(cs[prop], offsets[prop] + "px");
}
// ... even in the presence of scrollbars
scroller.style.overflow = "scroll";
container.style.width = "100%";
container.style.height = "100%";
var ccs = getComputedStyle(container, "");
function isApproximatelyEqual(a, b) {
return Math.abs(a - b) < 0.001;
}
for (var prop in offsets) {
sticky.style[prop] = offsets[prop] + "%";
var basis = parseFloat(ccs[prop == "left" || prop == "right" ?
"width" : "height"]) / 100;
ok(isApproximatelyEqual(parseFloat(cs[prop]), offsets[prop] * basis));
}
</script>
</pre>
</body>
</html>