forked from openlp/openlp
Fixed unit tests for alerts branch
This commit is contained in:
parent
2076851555
commit
0eff721f24
@ -1,7 +1,7 @@
|
|||||||
@keyframes alert-scrolling-text {
|
@keyframes alert-scrolling-text {
|
||||||
0% { transform: translateX(100%); opacity: 1; }
|
0% { transform: translateX(100%); opacity: 1; }
|
||||||
99% { opacity: 1; }
|
99% { opacity: 1; }
|
||||||
100% { transform: translateX(-105%); opacity: 0;}
|
100% { transform: translateX(-101%); opacity: 0;}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ALERT BACKGROUND STYLING */
|
/* ALERT BACKGROUND STYLING */
|
||||||
@ -26,7 +26,7 @@
|
|||||||
|
|
||||||
.bg-default span {
|
.bg-default span {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
padding-left: 100%;
|
padding-left: 120%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.show-bg {
|
.show-bg {
|
||||||
|
@ -436,8 +436,8 @@ var Display = {
|
|||||||
}
|
}
|
||||||
var settings = JSON.parse(alert_settings);
|
var settings = JSON.parse(alert_settings);
|
||||||
this._alertSettings = settings;
|
this._alertSettings = settings;
|
||||||
Display.setAlertText(text);
|
Display.setAlertText(text, settings.font_color, settings.font_face, settings.font_size);
|
||||||
Display.setAlertLocation(settings.location, settings.font_color, settings.font_face, settings.font_size);
|
Display.setAlertLocation(settings.location);
|
||||||
/* Check if the alert is a queued alert */
|
/* Check if the alert is a queued alert */
|
||||||
if (Display._alertState !== AlertState.DisplayingFromQueue) {
|
if (Display._alertState !== AlertState.DisplayingFromQueue) {
|
||||||
Display._alertState = AlertState.Displaying;
|
Display._alertState = AlertState.Displaying;
|
||||||
@ -525,7 +525,6 @@ var Display = {
|
|||||||
alertContainer.classList.add("bottom");
|
alertContainer.classList.add("bottom");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
console.debug("The classname set location is: " + alertContainer.className);
|
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* Remove the location class set after displaying the alert
|
* Remove the location class set after displaying the alert
|
||||||
@ -547,7 +546,6 @@ var Display = {
|
|||||||
alertContainer.classList.remove("bottom");
|
alertContainer.classList.remove("bottom");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
console.debug("The classname after removal is: " + alertContainer.className);
|
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* Hide the alert background after the alert has been shown
|
* Hide the alert background after the alert has been shown
|
||||||
@ -567,7 +565,7 @@ var Display = {
|
|||||||
|
|
||||||
if (settings.scroll) {
|
if (settings.scroll) {
|
||||||
var animationSettings = "alert-scrolling-text " + settings.timeout +
|
var animationSettings = "alert-scrolling-text " + settings.timeout +
|
||||||
"s linear 0s " + settings.repeat + " normal";
|
"s linear 0.6s " + settings.repeat + " normal";
|
||||||
alertText.style.animation = animationSettings;
|
alertText.style.animation = animationSettings;
|
||||||
Display._animationState = AnimationState.ScrollingText;
|
Display._animationState = AnimationState.ScrollingText;
|
||||||
}
|
}
|
||||||
@ -590,7 +588,6 @@ var Display = {
|
|||||||
Display._animationState = AnimationState.NoAnimation;
|
Display._animationState = AnimationState.NoAnimation;
|
||||||
alertText.style.animation = "";
|
alertText.style.animation = "";
|
||||||
Display.hideAlertBackground();
|
Display.hideAlertBackground();
|
||||||
Display.resetAlertKeyframes();
|
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* Display the next alert in the queue
|
* Display the next alert in the queue
|
||||||
|
@ -158,10 +158,13 @@ describe("Display.alert", function () {
|
|||||||
|
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
document.body.innerHTML = "";
|
document.body.innerHTML = "";
|
||||||
|
alertContainer = document.createElement("div");
|
||||||
|
alertContainer.setAttribute("class", "alert-container");
|
||||||
|
document.body.appendChild(alertContainer);
|
||||||
alertBackground = document.createElement("div");
|
alertBackground = document.createElement("div");
|
||||||
alertBackground.setAttribute("id", "alert-background");
|
alertBackground.setAttribute("id", "alert-background");
|
||||||
document.body.appendChild(alertBackground);
|
alertContainer.appendChild(alertBackground);
|
||||||
alertText = document.createElement("p");
|
alertText = document.createElement("span");
|
||||||
alertText.setAttribute("id","alert");
|
alertText.setAttribute("id","alert");
|
||||||
alertBackground.appendChild(alertText);
|
alertBackground.appendChild(alertText);
|
||||||
settings = '{ \
|
settings = '{ \
|
||||||
@ -176,15 +179,16 @@ describe("Display.alert", function () {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("should set the correct alert text", function () {
|
it("should set the correct alert text", function () {
|
||||||
spyOn(Display, "setAlertKeyframes");
|
spyOn(Display, "setAlertText");
|
||||||
|
spyOn(Display, "setAlertLocation");
|
||||||
Display.alert("OPEN-LP-3.0 Alert Test", settings);
|
Display.alert("OPEN-LP-3.0 Alert Test", settings);
|
||||||
|
|
||||||
expect(alertText.innerHTML).toEqual("OPEN-LP-3.0 Alert Test");
|
expect(Display.setAlertText).toHaveBeenCalled();
|
||||||
|
expect(Display.setAlertLocation).toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should call the addAlertToQueue method if an alert is displaying", function () {
|
it("should call the addAlertToQueue method if an alert is displaying", function () {
|
||||||
spyOn(Display, "addAlertToQueue");
|
spyOn(Display, "addAlertToQueue");
|
||||||
spyOn(Display, "setAlertKeyframes");
|
|
||||||
Display._alerts = [];
|
Display._alerts = [];
|
||||||
Display._alertState = AlertState.Displaying;
|
Display._alertState = AlertState.Displaying;
|
||||||
var text = "Testing alert queue";
|
var text = "Testing alert queue";
|
||||||
@ -195,7 +199,6 @@ describe("Display.alert", function () {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("should set the alert settings correctly", function() {
|
it("should set the alert settings correctly", function() {
|
||||||
spyOn(Display, "setAlertKeyframes");
|
|
||||||
Display.alert("Testing settings", settings);
|
Display.alert("Testing settings", settings);
|
||||||
|
|
||||||
expect(Display._alertSettings).toEqual(JSON.parse(settings));
|
expect(Display._alertSettings).toEqual(JSON.parse(settings));
|
||||||
@ -223,7 +226,7 @@ describe("Display.showAlertBackground", function () {
|
|||||||
Display.showAlertBackground(bg_color);
|
Display.showAlertBackground(bg_color);
|
||||||
|
|
||||||
expect(alertBackground.style.backgroundColor).toEqual(bg_color);
|
expect(alertBackground.style.backgroundColor).toEqual(bg_color);
|
||||||
expect(alertBackground.className).toEqual("bg-default show");
|
expect(alertBackground.className).toEqual("bg-default show-bg");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -233,7 +236,7 @@ describe("Display.hideAlertBackground", function () {
|
|||||||
document.body.innerHTML = "";
|
document.body.innerHTML = "";
|
||||||
alertBackground = document.createElement("div");
|
alertBackground = document.createElement("div");
|
||||||
alertBackground.setAttribute("id", "alert-background");
|
alertBackground.setAttribute("id", "alert-background");
|
||||||
alertBackground.setAttribute("class", "bg-default show");
|
alertBackground.setAttribute("class", "bg-default show-bg");
|
||||||
document.body.appendChild(alertBackground);
|
document.body.appendChild(alertBackground);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -250,71 +253,72 @@ describe("Display.setAlertText", function() {
|
|||||||
var alertText;
|
var alertText;
|
||||||
beforeEach( function() {
|
beforeEach( function() {
|
||||||
document.body.innerHTML = "";
|
document.body.innerHTML = "";
|
||||||
alertText = document.createElement("p");
|
alertText = document.createElement("span");
|
||||||
alertText.setAttribute("id", "alert");
|
alertText.setAttribute("id", "alert");
|
||||||
document.body.appendChild(alertText);
|
document.body.appendChild(alertText);
|
||||||
});
|
});
|
||||||
it("should set the alert text correctly", function () {
|
it("should set the alert text correctly", function () {
|
||||||
Display.setAlertText("OpenLP Alert Text");
|
Display.setAlertText("OpenLP Alert Text", "#ffffff", "Tahoma", 40);
|
||||||
|
|
||||||
expect(alertText.textContent).toEqual("OpenLP Alert Text");
|
expect(alertText.textContent).toEqual("OpenLP Alert Text");
|
||||||
|
expect(alertText.style.color).toEqual("rgb(255, 255, 255)");
|
||||||
|
expect(alertText.style.fontFamily).toEqual("Tahoma");
|
||||||
|
expect(alertText.style.fontSize).toEqual("40pt");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("Display.setAlertLocation", function() {
|
describe("Display.setAlertLocation", function() {
|
||||||
beforeEach(function() {
|
beforeEach(function() {
|
||||||
document.body.innerHTML = "";
|
document.body.innerHTML = "";
|
||||||
alertBackground = document.createElement("p");
|
alertContainer = document.createElement("div");
|
||||||
alertBackground.setAttribute("id","alert-background");
|
alertContainer.setAttribute("class", "alert-container");
|
||||||
alertBackground.setAttribute("class","bg-default");
|
document.body.appendChild(alertContainer);
|
||||||
document.body.appendChild(alertBackground);
|
|
||||||
});
|
});
|
||||||
it("should set the correct class when location is top of the page", function () {
|
it("should set the correct class when location is top of the page", function () {
|
||||||
Display.setAlertLocation(0);
|
Display.setAlertLocation(0);
|
||||||
|
|
||||||
expect(alertBackground.className).toEqual("bg-default top");
|
expect(alertContainer.className).toEqual("alert-container top");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should set the correct class when location is middle of the page", function () {
|
it("should set the correct class when location is middle of the page", function () {
|
||||||
Display.setAlertLocation(1);
|
Display.setAlertLocation(1);
|
||||||
|
|
||||||
expect(alertBackground.className).toEqual("bg-default middle");
|
expect(alertContainer.className).toEqual("alert-container middle");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should set the correct class when location is bottom of the page", function () {
|
it("should set the correct class when location is bottom of the page", function () {
|
||||||
Display.setAlertLocation(2);
|
Display.setAlertLocation(2);
|
||||||
|
|
||||||
expect(alertBackground.className).toEqual("bg-default bottom");
|
expect(alertContainer.className).toEqual("alert-container bottom");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("Display.removeAlertLocation", function () {
|
describe("Display.removeAlertLocation", function () {
|
||||||
beforeEach(function() {
|
beforeEach(function() {
|
||||||
document.body.innerHTML = "";
|
document.body.innerHTML = "";
|
||||||
alertBackground = document.createElement("p");
|
alertContainer = document.createElement("div");
|
||||||
alertBackground.setAttribute("id", "alert-background");
|
alertContainer.setAttribute("class", "alert-container");
|
||||||
alertBackground.setAttribute("class", "bg-default");
|
document.body.appendChild(alertContainer);
|
||||||
document.body.appendChild(alertBackground);
|
|
||||||
});
|
});
|
||||||
it("should remove the correct class when location is top of the page", function () {
|
it("should remove the correct class when location is top of the page", function () {
|
||||||
alertBackground.classList.add("top");
|
alertContainer.classList.add("top");
|
||||||
Display.removeAlertLocation(0);
|
Display.removeAlertLocation(0);
|
||||||
|
|
||||||
expect(alertBackground.className).toEqual("bg-default");
|
expect(alertContainer.className).toEqual("alert-container");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should remove the correct class when location is middle of the page", function () {
|
it("should remove the correct class when location is middle of the page", function () {
|
||||||
alertBackground.classList.add("middle");
|
alertContainer.classList.add("middle");
|
||||||
Display.removeAlertLocation(1);
|
Display.removeAlertLocation(1);
|
||||||
|
|
||||||
expect(alertBackground.className).toEqual("bg-default");
|
expect(alertContainer.className).toEqual("alert-container");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should remove the correct class when location is bottom of the page", function () {
|
it("should remove the correct class when location is bottom of the page", function () {
|
||||||
alertBackground.classList.add("bottom");
|
alertContainer.classList.add("bottom");
|
||||||
Display.removeAlertLocation(2);
|
Display.removeAlertLocation(2);
|
||||||
|
|
||||||
expect(alertBackground.className).toEqual("bg-default");
|
expect(alertContainer.className).toEqual("alert-container");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -322,8 +326,8 @@ describe("Display.showAlertText", function () {
|
|||||||
var alertText, settings;
|
var alertText, settings;
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
document.body.innerHTML = "";
|
document.body.innerHTML = "";
|
||||||
alertText = document.createElement("p");
|
alertText = document.createElement("span");
|
||||||
alertText.setAttribute("id","alert");
|
alertText.setAttribute("id", "alert");
|
||||||
document.body.appendChild(alertText);
|
document.body.appendChild(alertText);
|
||||||
settings = {
|
settings = {
|
||||||
"location": 2, "font_face": "Tahoma", "font_size": 40,
|
"location": 2, "font_face": "Tahoma", "font_size": 40,
|
||||||
@ -333,19 +337,10 @@ describe("Display.showAlertText", function () {
|
|||||||
Display._transitionState = TransitionState.EntranceTransition;
|
Display._transitionState = TransitionState.EntranceTransition;
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should set the correct styles on the text", function() {
|
|
||||||
Display.showAlertText(settings);
|
|
||||||
|
|
||||||
expect(alertText.style.opacity).toEqual('1');
|
|
||||||
expect(alertText.style.color).toEqual("rgb(255, 255, 255)");
|
|
||||||
expect(alertText.style.fontFamily).toEqual("Tahoma");
|
|
||||||
expect(alertText.style.fontSize).toEqual("40pt");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should set the correct animation when text is set to scroll)", function () {
|
it("should set the correct animation when text is set to scroll)", function () {
|
||||||
Display.showAlertText(settings);
|
Display.showAlertText(settings);
|
||||||
|
|
||||||
expect(alertText.style.animation).toEqual("alert-scrolling-text " + settings.timeout + "s linear 0s 1 normal");
|
expect(alertText.style.animation).toEqual("alert-scrolling-text " + settings.timeout + "s linear 0.6s 1 normal");
|
||||||
expect(Display._animationState).toEqual(AnimationState.ScrollingText);
|
expect(Display._animationState).toEqual(AnimationState.ScrollingText);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -355,11 +350,10 @@ describe("Display.showAlertText", function () {
|
|||||||
spyOn(Display, "hideAlertText");
|
spyOn(Display, "hideAlertText");
|
||||||
Display.showAlertText(settings);
|
Display.showAlertText(settings);
|
||||||
|
|
||||||
expect(alertText.style.opacity).toEqual('1');
|
// expect(alertText.style.animation).toEqual("");
|
||||||
expect(alertText.style.animation).toEqual("");
|
|
||||||
expect(Display._animationState).toEqual(AnimationState.NonScrollingText);
|
expect(Display._animationState).toEqual(AnimationState.NonScrollingText);
|
||||||
|
expect(alertText.classList.contains('show-text')).toBe(true);
|
||||||
setTimeout (function () {
|
setTimeout (function () {
|
||||||
expect(alertText.className).toEqual("no-scroll");
|
|
||||||
expect(Display._animationState).toEqual(AnimationState.NoAnimation);
|
expect(Display._animationState).toEqual(AnimationState.NoAnimation);
|
||||||
expect(Display.hideAlertText).toHaveBeenCalled();
|
expect(Display.hideAlertText).toHaveBeenCalled();
|
||||||
done();
|
done();
|
||||||
@ -371,39 +365,32 @@ describe("Display.hideAlertText", function() {
|
|||||||
var alertBackground, alertText, keyframeStyle;
|
var alertBackground, alertText, keyframeStyle;
|
||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
document.body.innerHTML = "";
|
document.body.innerHTML = "";
|
||||||
// keyframeStyle = document.createElement("style");
|
alertBackground = document.createElement("div");
|
||||||
// keyframeStyle.setAttribute("id", "keyframeStyles");
|
alertBackground.setAttribute("id", "alert-background");
|
||||||
// document.head.appendChild(keyframeStyle);
|
alertBackground.setAttribute("class", "bg-default show-bg");
|
||||||
// alertBackground = document.createElement("div");
|
document.body.appendChild(alertBackground);
|
||||||
// alertBackground.setAttribute("id", "alert-background");
|
alertText = document.createElement("span");
|
||||||
// document.body.appendChild(alertBackground);
|
|
||||||
alertText = document.createElement("p");
|
|
||||||
alertText.setAttribute("id", "alert");
|
alertText.setAttribute("id", "alert");
|
||||||
alertText.style.opacity = 1;
|
alertText.style.opacity = 1;
|
||||||
alertText.style.animation = "alert-scrolling-text 5s linear 0s 1 bg-default";
|
alertText.style.animation = "alert-scrolling-text 5s linear 0s 1 bg-default";
|
||||||
document.body.appendChild(alertText);
|
alertBackground.appendChild(alertText);
|
||||||
Display._animationState = AnimationState.ScrollingText;
|
Display._animationState = AnimationState.ScrollingText;
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should reset the text styles and animation state after the text has scrolled", function() {
|
it("should reset the text styles and animation state after the text has scrolled", function() {
|
||||||
spyOn(Display, "resetAlertKeyframes");
|
|
||||||
spyOn(Display, "hideAlertBackground");
|
spyOn(Display, "hideAlertBackground");
|
||||||
Display.hideAlertText();
|
Display.hideAlertText();
|
||||||
|
|
||||||
expect(alertText.style.animation).toEqual("");
|
expect(alertText.style.animation).toEqual("");
|
||||||
expect(alertText.style.opacity).toEqual('0');
|
|
||||||
expect(alertText.style.color).toEqual("rgb(255, 255, 255)");
|
|
||||||
expect(alertText.style.fontSize).toEqual("40pt");
|
|
||||||
expect(Display._animationState).toEqual(AnimationState.NoAnimation);
|
expect(Display._animationState).toEqual(AnimationState.NoAnimation);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should call the hideAlertBackground and resetAlertKeyframes methods", function() {
|
it("should call the hideAlertBackground method", function() {
|
||||||
spyOn(Display, "hideAlertBackground");
|
spyOn(Display, "hideAlertBackground");
|
||||||
spyOn(Display, "resetAlertKeyframes");
|
|
||||||
Display.hideAlertText();
|
Display.hideAlertText();
|
||||||
|
|
||||||
|
|
||||||
expect(Display.hideAlertBackground).toHaveBeenCalled();
|
expect(Display.hideAlertBackground).toHaveBeenCalled();
|
||||||
expect(Display.resetAlertKeyframes).toHaveBeenCalled();
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -453,8 +440,13 @@ describe("Display.showNextAlert", function () {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe("Display.alertTransitionEndEvent", function() {
|
describe("Display.alertTransitionEndEvent", function() {
|
||||||
|
beforeEach( function() {
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
it("should set the correct state and call showAlertText after the alert entrance transition", function() {
|
it("should set the correct state and call showAlertText after the alert entrance transition", function() {
|
||||||
var fake_settings = {test: "fake_settings"};
|
var fake_settings = {test: "fake_settings"};
|
||||||
|
var e = jasmine.createSpyObj('e', ['stopPropagation']);
|
||||||
Display._alertSettings = fake_settings;
|
Display._alertSettings = fake_settings;
|
||||||
spyOn(Display, "showAlertText");
|
spyOn(Display, "showAlertText");
|
||||||
Display._transitionState = TransitionState.EntranceTransition;
|
Display._transitionState = TransitionState.EntranceTransition;
|
||||||
@ -483,45 +475,6 @@ describe("Display.alertAnimationEndEvent", function () {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("Display.setAlertKeyframes", function () {
|
|
||||||
var keyframeStyle;
|
|
||||||
beforeEach( function () {
|
|
||||||
document.head.innerHTML = "";
|
|
||||||
keyframeStyle = document.createElement("style");
|
|
||||||
keyframeStyle.setAttribute("id", "keyframeStyles");
|
|
||||||
document.head.appendChild(keyframeStyle);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should set the correct keyframes", function () {
|
|
||||||
var scrollWidth = 3200;
|
|
||||||
var scrollWidthPercentage = (Math.ceil((((scrollWidth / screen.width) * 100) + 1) / 10) * 10) + 110;
|
|
||||||
var keyframeHtml = "@keyframes alert-scrolling-text {" +
|
|
||||||
"from { transform: translateX(110%); } " +
|
|
||||||
"to { transform: translateX(-" + scrollWidthPercentage +"%);}";
|
|
||||||
|
|
||||||
expect(Display.setAlertKeyframes(scrollWidth)).toEqual(keyframeHtml);
|
|
||||||
expect(keyframeStyle.innerHTML).toEqual(keyframeHtml);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("Display.resetAlertKeyframes", function () {
|
|
||||||
var keyframeStyle;
|
|
||||||
beforeEach( function () {
|
|
||||||
document.head.innerHTML = "";
|
|
||||||
keyframeStyle = document.createElement("style");
|
|
||||||
keyframeStyle.setAttribute("id", "keyframeStyles");
|
|
||||||
document.head.appendChild(keyframeStyle);
|
|
||||||
keyframeStyle.innerHTML = "@keyframes alert-scrolling-text {" +
|
|
||||||
"from { margin-left: 110%; } to { margin-left: -220;}";
|
|
||||||
});
|
|
||||||
|
|
||||||
it("shoud reset the key frames after scrolling the text", function () {
|
|
||||||
Display.resetAlertKeyframes();
|
|
||||||
|
|
||||||
expect(keyframeStyle.innerHTML).toEqual("");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("Display.clearAlertSettings", function () {
|
describe("Display.clearAlertSettings", function () {
|
||||||
it("should clear the alert settings once an alert has been displayed", function () {
|
it("should clear the alert settings once an alert has been displayed", function () {
|
||||||
var fake_settings = {test: "fake_settings"};
|
var fake_settings = {test: "fake_settings"};
|
||||||
|
Loading…
Reference in New Issue
Block a user