/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
// Tests that cubic-bezier pickers appear when clicking on cubic-bezier
// swatches.
const TEST_URI = `
Testing the cubic-bezier tooltip!
`;
add_task(function* () {
yield addTab("data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI));
let {inspector, view} = yield openRuleView();
yield selectNode("div", inspector);
let swatches = [];
swatches.push(
getRuleViewProperty(view, "div", "animation").valueSpan
.querySelector(".ruleview-bezierswatch")
);
swatches.push(
getRuleViewProperty(view, "div", "transition").valueSpan
.querySelector(".ruleview-bezierswatch")
);
swatches.push(
getRuleViewProperty(view, ".test", "animation-timing-function").valueSpan
.querySelector(".ruleview-bezierswatch")
);
swatches.push(
getRuleViewProperty(view, ".test", "transition-timing-function").valueSpan
.querySelector(".ruleview-bezierswatch")
);
for (let swatch of swatches) {
info("Testing that the cubic-bezier appears on cubicswatch click");
yield testAppears(view, swatch);
}
});
function* testAppears(view, swatch) {
ok(swatch, "The cubic-swatch exists");
let bezier = view.tooltips.cubicBezier;
ok(bezier, "The rule-view has the expected cubicBezier property");
let bezierPanel = bezier.tooltip.panel;
ok(bezierPanel, "The XUL panel for the cubic-bezier tooltip exists");
let onBezierWidgetReady = bezier.once("ready");
swatch.click();
yield onBezierWidgetReady;
ok(true, "The cubic-bezier tooltip was shown on click of the cibuc swatch");
ok(!inplaceEditor(swatch.parentNode),
"The inplace editor wasn't shown as a result of the cibuc swatch click");
yield hideTooltipAndWaitForRuleViewChanged(bezier, view);
}