mirror of
https://github.com/ManchildProductions/UXP-Fixed.git
synced 2026-05-27 23:08:36 +00:00
88 lines
2.8 KiB
JavaScript
88 lines
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.
|
|
let 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 (let { desc, animation, props, expectedName } of TEST_DATA) {
|
|
do_print(desc);
|
|
for (let key in props) {
|
|
animation[key] = props[key];
|
|
}
|
|
let actor = AnimationPlayerActor({}, animation);
|
|
do_check_eq(actor.getName(), expectedName);
|
|
}
|
|
}
|