MagicMirror/tests/e2e/helpers/global-setup.js

94 lines
2.3 KiB
JavaScript
Raw Normal View History

2021-09-23 22:52:32 +02:00
const jsdom = require("jsdom");
exports.startApplication = async (configFilename, exec) => {
2021-09-16 22:36:18 +02:00
jest.resetModules();
if (global.app) {
await this.stopApplication();
}
2021-09-16 22:36:18 +02:00
// Set config sample for use in test
2021-10-16 00:05:12 +02:00
if (configFilename === "") {
process.env.MM_CONFIG_FILE = "config/config.js";
} else {
process.env.MM_CONFIG_FILE = configFilename;
}
2021-09-16 22:36:18 +02:00
if (exec) exec;
global.app = require("../../../js/app");
return global.app.start();
2021-09-16 22:36:18 +02:00
};
exports.stopApplication = async () => {
if (!global.app) {
return Promise.resolve();
2021-09-16 22:36:18 +02:00
}
await global.app.stop();
delete global.app;
2021-09-16 22:36:18 +02:00
};
exports.getDocument = () => {
return new Promise((resolve) => {
const url = `http://${config.address || "localhost"}:${config.port || "8080"}`;
jsdom.JSDOM.fromURL(url, { resources: "usable", runScripts: "dangerously" }).then((dom) => {
dom.window.name = "jsdom";
global.window = dom.window;
// Following fixes `navigator is not defined` errors in e2e tests, found here
// https://www.appsloveworld.com/reactjs/100/37/mocha-react-navigator-is-not-defined
global.navigator = {
useragent: "node.js"
};
dom.window.fetch = fetch;
dom.window.onload = () => {
global.document = dom.window.document;
resolve();
};
});
});
};
2022-01-13 00:13:29 +01:00
exports.waitForElement = (selector, ignoreValue = "") => {
2022-01-13 21:12:15 +01:00
return new Promise((resolve) => {
let oldVal = "dummy12345";
const interval = setInterval(() => {
const element = document.querySelector(selector);
if (element) {
let newVal = element.textContent;
if (newVal === oldVal) {
clearInterval(interval);
resolve(element);
} else {
if (ignoreValue === "") {
oldVal = newVal;
} else {
if (!newVal.includes(ignoreValue)) oldVal = newVal;
}
}
2022-01-13 21:12:15 +01:00
}
}, 100);
});
};
2022-01-13 00:13:29 +01:00
exports.waitForAllElements = (selector) => {
return new Promise((resolve) => {
let oldVal = 999999;
const interval = setInterval(() => {
const element = document.querySelectorAll(selector);
if (element) {
let newVal = element.length;
if (newVal === oldVal) {
clearInterval(interval);
resolve(element);
} else {
if (newVal !== 0) oldVal = newVal;
}
}
}, 100);
2022-01-13 00:13:29 +01:00
});
};
exports.testMatch = async (element, regex) => {
const elem = await this.waitForElement(element);
expect(elem).not.toBeNull();
expect(elem.textContent).toMatch(regex);
return true;
};