Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

/* Any copyright is dedicated to the Public Domain.
"use strict";
// Tests that a color change in the color picker is committed when ENTER is
// pressed.
const TEST_URI = `
<style type="text/css">
body {
border: 2em solid rgba(120, 120, 120, .5);
}
</style>
Testing the color picker tooltip!
`;
add_task(async function () {
await addTab("data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI));
const { view } = await openRuleView();
const swatch = getRuleViewProperty(
view,
"body",
"border"
).valueSpan.querySelector(".ruleview-colorswatch");
await testPressingEnterCommitsChanges(swatch, view);
});
async function testPressingEnterCommitsChanges(swatch, ruleView) {
const cPicker = ruleView.tooltips.getTooltip("colorPicker");
const onColorPickerReady = cPicker.once("ready");
swatch.click();
await onColorPickerReady;
await simulateColorPickerChange(ruleView, cPicker, [0, 255, 0, 0.5], {
selector: "body",
name: "border-left-color",
value: "rgba(0, 255, 0, 0.5)",
});
is(
swatch.style.backgroundColor,
"rgba(0, 255, 0, 0.5)",
"The color swatch's background was updated"
);
is(
getRuleViewProperty(ruleView, "body", "border").valueSpan.textContent,
"2em solid rgba(0, 255, 0, 0.5)",
"The text of the border css property was updated"
);
const onModified = ruleView.once("ruleview-changed");
const spectrum = cPicker.spectrum;
const onHidden = cPicker.tooltip.once("hidden");
focusAndSendKey(spectrum.element.ownerDocument.defaultView, "RETURN");
await onHidden;
await onModified;
is(
await getComputedStyleProperty("body", null, "border-left-color"),
"rgba(0, 255, 0, 0.5)",
"The element's border was kept after RETURN"
);
is(
swatch.style.backgroundColor,
"rgba(0, 255, 0, 0.5)",
"The color swatch's background was kept after RETURN"
);
is(
getRuleViewProperty(ruleView, "body", "border").valueSpan.textContent,
"2em solid rgba(0, 255, 0, 0.5)",
"The text of the border css property was kept after RETURN"
);
}