зеркало из https://github.com/mozilla/gecko-dev.git
95 строки
2.8 KiB
JavaScript
95 строки
2.8 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
"use strict";
|
|
|
|
// Test that AnimationPlayerActor.getName returns the right name depending on
|
|
// the type of an animation and the various properties available on it.
|
|
|
|
const { AnimationPlayerActor } = require("devtools/server/actors/animation");
|
|
|
|
function run_test() {
|
|
// Mock a window with just the properties the AnimationPlayerActor uses.
|
|
const window = {
|
|
MutationObserver: function() {
|
|
this.observe = () => {};
|
|
},
|
|
Animation: function() {
|
|
this.effect = { target: getMockNode() };
|
|
},
|
|
CSSAnimation: function() {
|
|
this.effect = { target: getMockNode() };
|
|
},
|
|
CSSTransition: function() {
|
|
this.effect = { target: getMockNode() };
|
|
},
|
|
};
|
|
|
|
window.CSSAnimation.prototype = Object.create(window.Animation.prototype);
|
|
window.CSSTransition.prototype = Object.create(window.Animation.prototype);
|
|
|
|
// Helper to get a mock DOM node.
|
|
function getMockNode() {
|
|
return {
|
|
ownerDocument: {
|
|
defaultView: window,
|
|
},
|
|
};
|
|
}
|
|
|
|
// Objects in this array should contain the following properties:
|
|
// - desc {String} For logging
|
|
// - animation {Object} An animation object instantiated from one of the mock
|
|
// window animation constructors.
|
|
// - props {Objet} Properties of this object will be added to the animation
|
|
// object.
|
|
// - expectedName {String} The expected name returned by
|
|
// AnimationPlayerActor.getName.
|
|
const TEST_DATA = [
|
|
{
|
|
desc: "Animation with an id",
|
|
animation: new window.Animation(),
|
|
props: { id: "animation-id" },
|
|
expectedName: "animation-id",
|
|
},
|
|
{
|
|
desc: "Animation without an id",
|
|
animation: new window.Animation(),
|
|
props: {},
|
|
expectedName: "",
|
|
},
|
|
{
|
|
desc: "CSSTransition with an id",
|
|
animation: new window.CSSTransition(),
|
|
props: { id: "transition-with-id", transitionProperty: "width" },
|
|
expectedName: "transition-with-id",
|
|
},
|
|
{
|
|
desc: "CSSAnimation with an id",
|
|
animation: new window.CSSAnimation(),
|
|
props: { id: "animation-with-id", animationName: "move" },
|
|
expectedName: "animation-with-id",
|
|
},
|
|
{
|
|
desc: "CSSTransition without an id",
|
|
animation: new window.CSSTransition(),
|
|
props: { transitionProperty: "width" },
|
|
expectedName: "width",
|
|
},
|
|
{
|
|
desc: "CSSAnimation without an id",
|
|
animation: new window.CSSAnimation(),
|
|
props: { animationName: "move" },
|
|
expectedName: "move",
|
|
},
|
|
];
|
|
|
|
for (const { desc, animation, props, expectedName } of TEST_DATA) {
|
|
info(desc);
|
|
for (const key in props) {
|
|
animation[key] = props[key];
|
|
}
|
|
const actor = AnimationPlayerActor({}, animation);
|
|
Assert.equal(actor.getName(), expectedName);
|
|
}
|
|
}
|