mirror of
https://github.com/MichMich/MagicMirror.git
synced 2025-06-27 19:53:36 +00:00
Convert translator callbacks to async/await (#3048)
Co-authored-by: veeck <michael@veeck.de>
This commit is contained in:
parent
a23769156e
commit
2b792cdbb8
@ -37,6 +37,7 @@ _This release is scheduled to be released on 2023-04-01._
|
|||||||
- Update dates in Calendar widgets every minute
|
- Update dates in Calendar widgets every minute
|
||||||
- Cleanup jest coverage for patches
|
- Cleanup jest coverage for patches
|
||||||
- Update `stylelint` dependencies, switch to `stylelint-config-standard` and handle `stylelint` issues
|
- Update `stylelint` dependencies, switch to `stylelint-config-standard` and handle `stylelint` issues
|
||||||
|
- Convert translator callbacks to async/await
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
|
@ -160,7 +160,7 @@ const Loader = (function () {
|
|||||||
Log.log("Scripts loaded for: " + module.name);
|
Log.log("Scripts loaded for: " + module.name);
|
||||||
mObj.loadStyles(function () {
|
mObj.loadStyles(function () {
|
||||||
Log.log("Styles loaded for: " + module.name);
|
Log.log("Styles loaded for: " + module.name);
|
||||||
mObj.loadTranslations(function () {
|
mObj.loadTranslations().then(() => {
|
||||||
Log.log("Translations loaded for: " + module.name);
|
Log.log("Translations loaded for: " + module.name);
|
||||||
moduleObjects.push(mObj);
|
moduleObjects.push(mObj);
|
||||||
callback();
|
callback();
|
||||||
|
@ -485,8 +485,7 @@ const MM = (function () {
|
|||||||
|
|
||||||
Log.setLogLevel(config.logLevel);
|
Log.setLogLevel(config.logLevel);
|
||||||
|
|
||||||
Translator.loadCoreTranslations(config.language);
|
Translator.loadCoreTranslations(config.language).then(() => Loader.loadModules());
|
||||||
Loader.loadModules();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
16
js/module.js
16
js/module.js
@ -302,10 +302,8 @@ const Module = Class.extend({
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Load all translations.
|
* Load all translations.
|
||||||
*
|
|
||||||
* @param {Function} callback Function called when done.
|
|
||||||
*/
|
*/
|
||||||
loadTranslations(callback) {
|
async loadTranslations() {
|
||||||
const translations = this.getTranslations() || {};
|
const translations = this.getTranslations() || {};
|
||||||
const language = config.language.toLowerCase();
|
const language = config.language.toLowerCase();
|
||||||
|
|
||||||
@ -313,7 +311,6 @@ const Module = Class.extend({
|
|||||||
const fallbackLanguage = languages[0];
|
const fallbackLanguage = languages[0];
|
||||||
|
|
||||||
if (languages.length === 0) {
|
if (languages.length === 0) {
|
||||||
callback();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -321,17 +318,14 @@ const Module = Class.extend({
|
|||||||
const translationsFallbackFile = translations[fallbackLanguage];
|
const translationsFallbackFile = translations[fallbackLanguage];
|
||||||
|
|
||||||
if (!translationFile) {
|
if (!translationFile) {
|
||||||
Translator.load(this, translationsFallbackFile, true, callback);
|
return Translator.load(this, translationsFallbackFile, true);
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Translator.load(this, translationFile, false, () => {
|
await Translator.load(this, translationFile, false);
|
||||||
|
|
||||||
if (translationFile !== translationsFallbackFile) {
|
if (translationFile !== translationsFallbackFile) {
|
||||||
Translator.load(this, translationsFallbackFile, true, callback);
|
return Translator.load(this, translationsFallbackFile, true);
|
||||||
} else {
|
|
||||||
callback();
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -11,10 +11,11 @@ const Translator = (function () {
|
|||||||
* Load a JSON file via XHR.
|
* Load a JSON file via XHR.
|
||||||
*
|
*
|
||||||
* @param {string} file Path of the file we want to load.
|
* @param {string} file Path of the file we want to load.
|
||||||
* @param {Function} callback Function called when done.
|
* @returns {Promise<object>} the translations in the specified file
|
||||||
*/
|
*/
|
||||||
function loadJSON(file, callback) {
|
async function loadJSON(file) {
|
||||||
const xhr = new XMLHttpRequest();
|
const xhr = new XMLHttpRequest();
|
||||||
|
return new Promise(function (resolve, reject) {
|
||||||
xhr.overrideMimeType("application/json");
|
xhr.overrideMimeType("application/json");
|
||||||
xhr.open("GET", file, true);
|
xhr.open("GET", file, true);
|
||||||
xhr.onreadystatechange = function () {
|
xhr.onreadystatechange = function () {
|
||||||
@ -27,10 +28,11 @@ const Translator = (function () {
|
|||||||
// nothing here, but don't die
|
// nothing here, but don't die
|
||||||
Log.error(" loading json file =" + file + " failed");
|
Log.error(" loading json file =" + file + " failed");
|
||||||
}
|
}
|
||||||
callback(fileinfo);
|
resolve(fileinfo);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
xhr.send(null);
|
xhr.send(null);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
@ -48,7 +50,7 @@ const Translator = (function () {
|
|||||||
* @returns {string} the translated key
|
* @returns {string} the translated key
|
||||||
*/
|
*/
|
||||||
translate: function (module, key, variables) {
|
translate: function (module, key, variables) {
|
||||||
variables = variables || {}; //Empty object by default
|
variables = variables || {}; // Empty object by default
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Combines template and variables like:
|
* Combines template and variables like:
|
||||||
@ -101,21 +103,17 @@ const Translator = (function () {
|
|||||||
* @param {Module} module The module to load the translation file for.
|
* @param {Module} module The module to load the translation file for.
|
||||||
* @param {string} file Path of the file we want to load.
|
* @param {string} file Path of the file we want to load.
|
||||||
* @param {boolean} isFallback Flag to indicate fallback translations.
|
* @param {boolean} isFallback Flag to indicate fallback translations.
|
||||||
* @param {Function} callback Function called when done.
|
|
||||||
*/
|
*/
|
||||||
load(module, file, isFallback, callback) {
|
async load(module, file, isFallback) {
|
||||||
Log.log(`${module.name} - Load translation${isFallback ? " fallback" : ""}: ${file}`);
|
Log.log(`${module.name} - Load translation${isFallback ? " fallback" : ""}: ${file}`);
|
||||||
|
|
||||||
if (this.translationsFallback[module.name]) {
|
if (this.translationsFallback[module.name]) {
|
||||||
callback();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
loadJSON(module.file(file), (json) => {
|
const json = await loadJSON(module.file(file));
|
||||||
const property = isFallback ? "translationsFallback" : "translations";
|
const property = isFallback ? "translationsFallback" : "translations";
|
||||||
this[property][module.name] = json;
|
this[property][module.name] = json;
|
||||||
callback();
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -123,30 +121,26 @@ const Translator = (function () {
|
|||||||
*
|
*
|
||||||
* @param {string} lang The language identifier of the core language.
|
* @param {string} lang The language identifier of the core language.
|
||||||
*/
|
*/
|
||||||
loadCoreTranslations: function (lang) {
|
loadCoreTranslations: async function (lang) {
|
||||||
if (lang in translations) {
|
if (lang in translations) {
|
||||||
Log.log("Loading core translation file: " + translations[lang]);
|
Log.log("Loading core translation file: " + translations[lang]);
|
||||||
loadJSON(translations[lang], (translations) => {
|
this.coreTranslations = await loadJSON(translations[lang]);
|
||||||
this.coreTranslations = translations;
|
|
||||||
});
|
|
||||||
} else {
|
} else {
|
||||||
Log.log("Configured language not found in core translations.");
|
Log.log("Configured language not found in core translations.");
|
||||||
}
|
}
|
||||||
|
|
||||||
this.loadCoreTranslationsFallback();
|
await this.loadCoreTranslationsFallback();
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Load the core translations fallback.
|
* Load the core translations' fallback.
|
||||||
* The first language defined in translations.js will be used.
|
* The first language defined in translations.js will be used.
|
||||||
*/
|
*/
|
||||||
loadCoreTranslationsFallback: function () {
|
loadCoreTranslationsFallback: async function () {
|
||||||
let first = Object.keys(translations)[0];
|
let first = Object.keys(translations)[0];
|
||||||
if (first) {
|
if (first) {
|
||||||
Log.log("Loading core translation fallback file: " + translations[first]);
|
Log.log("Loading core translation fallback file: " + translations[first]);
|
||||||
loadJSON(translations[first], (translations) => {
|
this.coreTranslationsFallback = await loadJSON(translations[first]);
|
||||||
this.coreTranslationsFallback = translations;
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -21,8 +21,8 @@ describe("Translations", () => {
|
|||||||
server = app.listen(3000);
|
server = app.listen(3000);
|
||||||
});
|
});
|
||||||
|
|
||||||
afterAll(() => {
|
afterAll(async () => {
|
||||||
server.close();
|
await server.close();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should have a translation file in the specified path", () => {
|
it("should have a translation file in the specified path", () => {
|
||||||
@ -48,17 +48,15 @@ describe("Translations", () => {
|
|||||||
dom.window.onload = async () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator, Module, config } = dom.window;
|
const { Translator, Module, config } = dom.window;
|
||||||
config.language = "en";
|
config.language = "en";
|
||||||
Translator.load = sinon.stub().callsFake((_m, _f, _fb, callback) => callback());
|
Translator.load = sinon.stub().callsFake((_m, _f, _fb) => null);
|
||||||
|
|
||||||
Module.register("name", { getTranslations: () => translations });
|
Module.register("name", { getTranslations: () => translations });
|
||||||
const MMM = Module.create("name");
|
const MMM = Module.create("name");
|
||||||
|
|
||||||
const loaded = sinon.stub();
|
await MMM.loadTranslations();
|
||||||
MMM.loadTranslations(loaded);
|
|
||||||
|
|
||||||
expect(loaded.callCount).toBe(1);
|
|
||||||
expect(Translator.load.args.length).toBe(1);
|
expect(Translator.load.args.length).toBe(1);
|
||||||
expect(Translator.load.calledWith(MMM, "translations/en.json", false, sinon.match.func)).toBe(true);
|
expect(Translator.load.calledWith(MMM, "translations/en.json", false)).toBe(true);
|
||||||
|
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
@ -67,18 +65,16 @@ describe("Translations", () => {
|
|||||||
it("should load translation + fallback file", (done) => {
|
it("should load translation + fallback file", (done) => {
|
||||||
dom.window.onload = async () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator, Module } = dom.window;
|
const { Translator, Module } = dom.window;
|
||||||
Translator.load = sinon.stub().callsFake((_m, _f, _fb, callback) => callback());
|
Translator.load = sinon.stub().callsFake((_m, _f, _fb) => null);
|
||||||
|
|
||||||
Module.register("name", { getTranslations: () => translations });
|
Module.register("name", { getTranslations: () => translations });
|
||||||
const MMM = Module.create("name");
|
const MMM = Module.create("name");
|
||||||
|
|
||||||
const loaded = sinon.stub();
|
await MMM.loadTranslations();
|
||||||
MMM.loadTranslations(loaded);
|
|
||||||
|
|
||||||
expect(loaded.callCount).toBe(1);
|
|
||||||
expect(Translator.load.args.length).toBe(2);
|
expect(Translator.load.args.length).toBe(2);
|
||||||
expect(Translator.load.calledWith(MMM, "translations/de.json", false, sinon.match.func)).toBe(true);
|
expect(Translator.load.calledWith(MMM, "translations/de.json", false)).toBe(true);
|
||||||
expect(Translator.load.calledWith(MMM, "translations/en.json", true, sinon.match.func)).toBe(true);
|
expect(Translator.load.calledWith(MMM, "translations/en.json", true)).toBe(true);
|
||||||
|
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
@ -88,17 +84,15 @@ describe("Translations", () => {
|
|||||||
dom.window.onload = async () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator, Module, config } = dom.window;
|
const { Translator, Module, config } = dom.window;
|
||||||
config.language = "--";
|
config.language = "--";
|
||||||
Translator.load = sinon.stub().callsFake((_m, _f, _fb, callback) => callback());
|
Translator.load = sinon.stub().callsFake((_m, _f, _fb) => null);
|
||||||
|
|
||||||
Module.register("name", { getTranslations: () => translations });
|
Module.register("name", { getTranslations: () => translations });
|
||||||
const MMM = Module.create("name");
|
const MMM = Module.create("name");
|
||||||
|
|
||||||
const loaded = sinon.stub();
|
await MMM.loadTranslations();
|
||||||
MMM.loadTranslations(loaded);
|
|
||||||
|
|
||||||
expect(loaded.callCount).toBe(1);
|
|
||||||
expect(Translator.load.args.length).toBe(1);
|
expect(Translator.load.args.length).toBe(1);
|
||||||
expect(Translator.load.calledWith(MMM, "translations/en.json", true, sinon.match.func)).toBe(true);
|
expect(Translator.load.calledWith(MMM, "translations/en.json", true)).toBe(true);
|
||||||
|
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
@ -112,10 +106,8 @@ describe("Translations", () => {
|
|||||||
Module.register("name", {});
|
Module.register("name", {});
|
||||||
const MMM = Module.create("name");
|
const MMM = Module.create("name");
|
||||||
|
|
||||||
const loaded = sinon.stub();
|
await MMM.loadTranslations();
|
||||||
MMM.loadTranslations(loaded);
|
|
||||||
|
|
||||||
expect(loaded.callCount).toBe(1);
|
|
||||||
expect(Translator.load.callCount).toBe(0);
|
expect(Translator.load.callCount).toBe(0);
|
||||||
|
|
||||||
done();
|
done();
|
||||||
@ -138,14 +130,13 @@ describe("Translations", () => {
|
|||||||
<script src="file://${path.join(__dirname, "..", "..", "js", "translator.js")}">`,
|
<script src="file://${path.join(__dirname, "..", "..", "js", "translator.js")}">`,
|
||||||
{ runScripts: "dangerously", resources: "usable" }
|
{ runScripts: "dangerously", resources: "usable" }
|
||||||
);
|
);
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
|
|
||||||
Translator.load(mmm, translations[language], false, () => {
|
await Translator.load(mmm, translations[language], false);
|
||||||
expect(typeof Translator.translations[mmm.name]).toBe("object");
|
expect(typeof Translator.translations[mmm.name]).toBe("object");
|
||||||
expect(Object.keys(Translator.translations[mmm.name]).length).toBeGreaterThanOrEqual(1);
|
expect(Object.keys(Translator.translations[mmm.name]).length).toBeGreaterThanOrEqual(1);
|
||||||
done();
|
done();
|
||||||
});
|
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -161,13 +152,12 @@ describe("Translations", () => {
|
|||||||
<script src="file://${path.join(__dirname, "..", "..", "js", "translator.js")}">`,
|
<script src="file://${path.join(__dirname, "..", "..", "js", "translator.js")}">`,
|
||||||
{ runScripts: "dangerously", resources: "usable" }
|
{ runScripts: "dangerously", resources: "usable" }
|
||||||
);
|
);
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
|
|
||||||
Translator.load(mmm, translations.de, false, () => {
|
await Translator.load(mmm, translations.de, false);
|
||||||
base = Object.keys(Translator.translations[mmm.name]).sort();
|
base = Object.keys(Translator.translations[mmm.name]).sort();
|
||||||
done();
|
done();
|
||||||
});
|
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -191,13 +181,12 @@ describe("Translations", () => {
|
|||||||
<script src="file://${path.join(__dirname, "..", "..", "js", "translator.js")}">`,
|
<script src="file://${path.join(__dirname, "..", "..", "js", "translator.js")}">`,
|
||||||
{ runScripts: "dangerously", resources: "usable" }
|
{ runScripts: "dangerously", resources: "usable" }
|
||||||
);
|
);
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
|
|
||||||
Translator.load(mmm, translations[language], false, () => {
|
await Translator.load(mmm, translations[language], false);
|
||||||
keys = Object.keys(Translator.translations[mmm.name]).sort();
|
keys = Object.keys(Translator.translations[mmm.name]).sort();
|
||||||
done();
|
done();
|
||||||
});
|
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -23,14 +23,13 @@ describe("Translator", () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
afterAll(() => {
|
afterAll(async () => {
|
||||||
for (const socket of sockets) {
|
for (const socket of sockets) {
|
||||||
socket.destroy();
|
socket.destroy();
|
||||||
|
|
||||||
sockets.delete(socket);
|
sockets.delete(socket);
|
||||||
}
|
}
|
||||||
|
|
||||||
server.close();
|
await server.close();
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("translate", () => {
|
describe("translate", () => {
|
||||||
@ -158,35 +157,33 @@ describe("Translator", () => {
|
|||||||
|
|
||||||
it("should load translations", (done) => {
|
it("should load translations", (done) => {
|
||||||
const dom = new JSDOM(`<script>var Log = {log: () => {}};</script><script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`, { runScripts: "dangerously", resources: "usable" });
|
const dom = new JSDOM(`<script>var Log = {log: () => {}};</script><script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`, { runScripts: "dangerously", resources: "usable" });
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
const file = "translation_test.json";
|
const file = "translation_test.json";
|
||||||
|
|
||||||
Translator.load(mmm, file, false, () => {
|
await Translator.load(mmm, file, false);
|
||||||
const json = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", file));
|
const json = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", file));
|
||||||
expect(Translator.translations[mmm.name]).toEqual(json);
|
expect(Translator.translations[mmm.name]).toEqual(json);
|
||||||
done();
|
done();
|
||||||
});
|
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should load translation fallbacks", (done) => {
|
it("should load translation fallbacks", (done) => {
|
||||||
const dom = new JSDOM(`<script>var Log = {log: () => {}};</script><script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`, { runScripts: "dangerously", resources: "usable" });
|
const dom = new JSDOM(`<script>var Log = {log: () => {}};</script><script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`, { runScripts: "dangerously", resources: "usable" });
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
const file = "translation_test.json";
|
const file = "translation_test.json";
|
||||||
|
|
||||||
Translator.load(mmm, file, true, () => {
|
await Translator.load(mmm, file, true);
|
||||||
const json = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", file));
|
const json = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", file));
|
||||||
expect(Translator.translationsFallback[mmm.name]).toEqual(json);
|
expect(Translator.translationsFallback[mmm.name]).toEqual(json);
|
||||||
done();
|
done();
|
||||||
});
|
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should not load translations, if module fallback exists", (done) => {
|
it("should not load translations, if module fallback exists", (done) => {
|
||||||
const dom = new JSDOM(`<script>var Log = {log: () => {}};</script><script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`, { runScripts: "dangerously", resources: "usable" });
|
const dom = new JSDOM(`<script>var Log = {log: () => {}};</script><script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`, { runScripts: "dangerously", resources: "usable" });
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator, XMLHttpRequest } = dom.window;
|
const { Translator, XMLHttpRequest } = dom.window;
|
||||||
const file = "translation_test.json";
|
const file = "translation_test.json";
|
||||||
|
|
||||||
@ -198,13 +195,12 @@ describe("Translator", () => {
|
|||||||
Hello: "Hallo"
|
Hello: "Hallo"
|
||||||
};
|
};
|
||||||
|
|
||||||
Translator.load(mmm, file, false, () => {
|
await Translator.load(mmm, file, false);
|
||||||
expect(Translator.translations[mmm.name]).toBe(undefined);
|
expect(Translator.translations[mmm.name]).toBe(undefined);
|
||||||
expect(Translator.translationsFallback[mmm.name]).toEqual({
|
expect(Translator.translationsFallback[mmm.name]).toEqual({
|
||||||
Hello: "Hallo"
|
Hello: "Hallo"
|
||||||
});
|
});
|
||||||
done();
|
done();
|
||||||
});
|
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -216,9 +212,9 @@ describe("Translator", () => {
|
|||||||
<script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`,
|
<script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`,
|
||||||
{ runScripts: "dangerously", resources: "usable" }
|
{ runScripts: "dangerously", resources: "usable" }
|
||||||
);
|
);
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
Translator.loadCoreTranslations("en");
|
await Translator.loadCoreTranslations("en");
|
||||||
|
|
||||||
const en = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", "translation_test.json"));
|
const en = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", "translation_test.json"));
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
@ -235,9 +231,9 @@ describe("Translator", () => {
|
|||||||
<script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`,
|
<script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`,
|
||||||
{ runScripts: "dangerously", resources: "usable" }
|
{ runScripts: "dangerously", resources: "usable" }
|
||||||
);
|
);
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
Translator.loadCoreTranslations("MISSINGLANG");
|
await Translator.loadCoreTranslations("MISSINGLANG");
|
||||||
|
|
||||||
const en = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", "translation_test.json"));
|
const en = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", "translation_test.json"));
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
@ -256,9 +252,9 @@ describe("Translator", () => {
|
|||||||
<script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`,
|
<script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`,
|
||||||
{ runScripts: "dangerously", resources: "usable" }
|
{ runScripts: "dangerously", resources: "usable" }
|
||||||
);
|
);
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
Translator.loadCoreTranslationsFallback();
|
await Translator.loadCoreTranslationsFallback();
|
||||||
|
|
||||||
const en = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", "translation_test.json"));
|
const en = require(path.join(__dirname, "..", "..", "..", "tests", "mocks", "translation_test.json"));
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
@ -274,9 +270,9 @@ describe("Translator", () => {
|
|||||||
<script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`,
|
<script src="file://${path.join(__dirname, "..", "..", "..", "js", "translator.js")}">`,
|
||||||
{ runScripts: "dangerously", resources: "usable" }
|
{ runScripts: "dangerously", resources: "usable" }
|
||||||
);
|
);
|
||||||
dom.window.onload = () => {
|
dom.window.onload = async () => {
|
||||||
const { Translator } = dom.window;
|
const { Translator } = dom.window;
|
||||||
Translator.loadCoreTranslations();
|
await Translator.loadCoreTranslations();
|
||||||
|
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
expect(Translator.coreTranslationsFallback).toEqual({});
|
expect(Translator.coreTranslationsFallback).toEqual({});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user