mirror of
https://github.com/MichMich/MagicMirror.git
synced 2025-06-27 03:39:55 +00:00
Jest was in the plugin array of the ESLint configuration, but no rules
were enabled. So ESLint hasn't checked any Jest rules yet.
So I activated the recommended Jest rules and added a few more. Then I
fixed the issues (mostly automatically). I have deactivated the rules
"jest/expect-expect" and "jest/no-done-callback" for the time being, as
they would have entailed major changes. I didn't want to make the PR too
big.
I'm not a Jest expert, but the changes so far look good to me. What do
you think of that @khassel? 🙂
78 lines
2.5 KiB
JavaScript
78 lines
2.5 KiB
JavaScript
const helpers = require("../helpers/global-setup");
|
|
|
|
describe("Newsfeed module", () => {
|
|
afterAll(async () => {
|
|
await helpers.stopApplication();
|
|
});
|
|
|
|
describe("Default configuration", () => {
|
|
beforeAll(async () => {
|
|
await helpers.startApplication("tests/configs/modules/newsfeed/default.js");
|
|
await helpers.getDocument();
|
|
});
|
|
|
|
it("should show the newsfeed title", async () => {
|
|
const elem = await helpers.waitForElement(".newsfeed .newsfeed-source");
|
|
expect(elem).not.toBeNull();
|
|
expect(elem.textContent).toContain("Rodrigo Ramirez Blog");
|
|
});
|
|
|
|
it("should show the newsfeed article", async () => {
|
|
const elem = await helpers.waitForElement(".newsfeed .newsfeed-title");
|
|
expect(elem).not.toBeNull();
|
|
expect(elem.textContent).toContain("QPanel");
|
|
});
|
|
|
|
it("should NOT show the newsfeed description", async () => {
|
|
await helpers.waitForElement(".newsfeed");
|
|
const elem = document.querySelector(".newsfeed .newsfeed-desc");
|
|
expect(elem).toBeNull();
|
|
});
|
|
});
|
|
|
|
describe("Custom configuration", () => {
|
|
beforeAll(async () => {
|
|
await helpers.startApplication("tests/configs/modules/newsfeed/prohibited_words.js");
|
|
await helpers.getDocument();
|
|
});
|
|
|
|
it("should not show articles with prohibited words", async () => {
|
|
const elem = await helpers.waitForElement(".newsfeed .newsfeed-title");
|
|
expect(elem).not.toBeNull();
|
|
expect(elem.textContent).toContain("Problema VirtualBox");
|
|
});
|
|
|
|
it("should show the newsfeed description", async () => {
|
|
const elem = await helpers.waitForElement(".newsfeed .newsfeed-desc");
|
|
expect(elem).not.toBeNull();
|
|
expect(elem.textContent).not.toHaveLength(0);
|
|
});
|
|
});
|
|
|
|
describe("Invalid configuration", () => {
|
|
beforeAll(async () => {
|
|
await helpers.startApplication("tests/configs/modules/newsfeed/incorrect_url.js");
|
|
await helpers.getDocument();
|
|
});
|
|
|
|
it("should show malformed url warning", async () => {
|
|
const elem = await helpers.waitForElement(".newsfeed .small", "No news at the moment.");
|
|
expect(elem).not.toBeNull();
|
|
expect(elem.textContent).toContain("Error in the Newsfeed module. Malformed url.");
|
|
});
|
|
});
|
|
|
|
describe("Ignore items", () => {
|
|
beforeAll(async () => {
|
|
await helpers.startApplication("tests/configs/modules/newsfeed/ignore_items.js");
|
|
await helpers.getDocument();
|
|
});
|
|
|
|
it("should show empty items info message", async () => {
|
|
const elem = await helpers.waitForElement(".newsfeed .small");
|
|
expect(elem).not.toBeNull();
|
|
expect(elem.textContent).toContain("No news at the moment.");
|
|
});
|
|
});
|
|
});
|