2021-09-23 22:52:32 +02:00
|
|
|
const jsdom = require("jsdom");
|
|
|
|
|
2022-09-20 23:43:06 +02:00
|
|
|
exports.startApplication = (configFilename, exec) => {
|
2021-09-16 22:36:18 +02:00
|
|
|
jest.resetModules();
|
2022-05-27 21:49:29 +02:00
|
|
|
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;
|
2021-09-25 23:45:34 +02:00
|
|
|
global.app = require("app.js");
|
|
|
|
global.app.start();
|
2021-09-16 22:36:18 +02:00
|
|
|
};
|
|
|
|
|
2022-09-20 23:43:06 +02:00
|
|
|
exports.stopApplication = async () => {
|
2021-09-25 23:45:34 +02:00
|
|
|
if (global.app) {
|
|
|
|
global.app.stop();
|
2021-09-16 22:36:18 +02:00
|
|
|
}
|
2022-05-27 19:46:28 +02:00
|
|
|
await new Promise((resolve) => setTimeout(resolve, 100));
|
2021-09-16 22:36:18 +02:00
|
|
|
};
|
2021-09-24 23:39:12 +02:00
|
|
|
|
2022-09-20 23:43:06 +02:00
|
|
|
exports.getDocument = (callback) => {
|
2021-09-24 23:39:12 +02:00
|
|
|
const url = "http://" + (config.address || "localhost") + ":" + (config.port || "8080");
|
|
|
|
jsdom.JSDOM.fromURL(url, { resources: "usable", runScripts: "dangerously" }).then((dom) => {
|
2021-09-28 22:08:21 +02:00
|
|
|
dom.window.name = "jsdom";
|
2022-09-20 23:43:06 +02:00
|
|
|
dom.window.onload = () => {
|
2021-09-24 23:39:12 +02:00
|
|
|
global.document = dom.window.document;
|
2022-01-13 22:33:57 +01:00
|
|
|
callback();
|
2021-09-24 23:39:12 +02:00
|
|
|
};
|
|
|
|
});
|
|
|
|
};
|
2022-01-13 00:13:29 +01:00
|
|
|
|
2022-09-20 23:43:06 +02:00
|
|
|
exports.waitForElement = (selector, ignoreValue = "") => {
|
2022-01-13 21:12:15 +01:00
|
|
|
return new Promise((resolve) => {
|
2022-09-20 23:43:06 +02:00
|
|
|
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
|
|
|
}
|
2022-09-20 23:43:06 +02:00
|
|
|
}, 100);
|
|
|
|
});
|
|
|
|
};
|
2022-01-13 00:13:29 +01:00
|
|
|
|
2022-09-20 23:43:06 +02: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
|
|
|
});
|
|
|
|
};
|