mirror of
https://github.com/gethomepage/homepage.git
synced 2026-04-08 19:21:20 -07:00
Chore: homepage tests (#6278)
This commit is contained in:
48
src/widgets/apcups/component.test.jsx
Normal file
48
src/widgets/apcups/component.test.jsx
Normal file
@@ -0,0 +1,48 @@
|
||||
// @vitest-environment jsdom
|
||||
|
||||
import { screen } from "@testing-library/react";
|
||||
import { beforeEach, describe, expect, it, vi } from "vitest";
|
||||
|
||||
import { renderWithProviders } from "test-utils/render-with-providers";
|
||||
|
||||
const { useWidgetAPI } = vi.hoisted(() => ({ useWidgetAPI: vi.fn() }));
|
||||
|
||||
vi.mock("utils/proxy/use-widget-api", () => ({
|
||||
default: useWidgetAPI,
|
||||
}));
|
||||
|
||||
import Component from "./component";
|
||||
|
||||
describe("widgets/apcups/component", () => {
|
||||
beforeEach(() => {
|
||||
vi.clearAllMocks();
|
||||
});
|
||||
|
||||
it("renders placeholders while loading", () => {
|
||||
useWidgetAPI.mockReturnValue({ data: undefined, error: undefined });
|
||||
|
||||
const { container } = renderWithProviders(<Component service={{ widget: { type: "apcups" } }} />, {
|
||||
settings: { hideErrors: false },
|
||||
});
|
||||
|
||||
expect(container.querySelectorAll(".service-block")).toHaveLength(4);
|
||||
expect(screen.getByText("apcups.status")).toBeInTheDocument();
|
||||
expect(screen.getByText("apcups.load")).toBeInTheDocument();
|
||||
expect(screen.getByText("apcups.bcharge")).toBeInTheDocument();
|
||||
expect(screen.getByText("apcups.timeleft")).toBeInTheDocument();
|
||||
});
|
||||
|
||||
it("renders values when loaded", () => {
|
||||
useWidgetAPI.mockReturnValue({
|
||||
data: { status: "ONLINE", load: "12", bcharge: "99", timeleft: "30" },
|
||||
error: undefined,
|
||||
});
|
||||
|
||||
renderWithProviders(<Component service={{ widget: { type: "apcups" } }} />, { settings: { hideErrors: false } });
|
||||
|
||||
expect(screen.getByText("ONLINE")).toBeInTheDocument();
|
||||
expect(screen.getByText("12")).toBeInTheDocument();
|
||||
expect(screen.getByText("99")).toBeInTheDocument();
|
||||
expect(screen.getByText("30")).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
88
src/widgets/apcups/proxy.test.js
Normal file
88
src/widgets/apcups/proxy.test.js
Normal file
@@ -0,0 +1,88 @@
|
||||
import { beforeEach, describe, expect, it, vi } from "vitest";
|
||||
|
||||
import createMockRes from "test-utils/create-mock-res";
|
||||
|
||||
function encodeLine(line) {
|
||||
const buf = Buffer.alloc(2 + line.length);
|
||||
buf.writeUInt16BE(line.length, 0);
|
||||
buf.write(line, 2, "ascii");
|
||||
return buf;
|
||||
}
|
||||
|
||||
const { getServiceWidget, logger } = vi.hoisted(() => ({
|
||||
getServiceWidget: vi.fn(),
|
||||
logger: { debug: vi.fn(), error: vi.fn() },
|
||||
}));
|
||||
|
||||
vi.mock("utils/config/service-helpers", () => ({
|
||||
default: getServiceWidget,
|
||||
}));
|
||||
vi.mock("utils/logger", () => ({
|
||||
default: () => logger,
|
||||
}));
|
||||
|
||||
vi.mock("node:net", () => {
|
||||
class FakeSocket {
|
||||
constructor() {
|
||||
this._handlers = new Map();
|
||||
}
|
||||
setTimeout() {}
|
||||
connect() {
|
||||
queueMicrotask(() => this._emit("connect"));
|
||||
}
|
||||
on(event, cb) {
|
||||
const set = this._handlers.get(event) ?? new Set();
|
||||
set.add(cb);
|
||||
this._handlers.set(event, set);
|
||||
}
|
||||
write() {
|
||||
const response = Buffer.concat([
|
||||
encodeLine("STATUS : ONLINE"),
|
||||
encodeLine("LOADPCT : 10.0"),
|
||||
encodeLine("BCHARGE : 99.0"),
|
||||
encodeLine("TIMELEFT : 12.3"),
|
||||
encodeLine("END APC"),
|
||||
Buffer.from([0x00, 0x00]),
|
||||
]);
|
||||
queueMicrotask(() => this._emit("data", response));
|
||||
}
|
||||
end() {}
|
||||
destroy() {}
|
||||
_emit(event, payload) {
|
||||
const set = this._handlers.get(event);
|
||||
if (!set) return;
|
||||
set.forEach((cb) => cb(payload));
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
default: {
|
||||
Socket: FakeSocket,
|
||||
},
|
||||
};
|
||||
});
|
||||
|
||||
import apcupsProxyHandler from "./proxy";
|
||||
|
||||
describe("widgets/apcups/proxy", () => {
|
||||
beforeEach(() => {
|
||||
vi.clearAllMocks();
|
||||
});
|
||||
|
||||
it("parses the APCUPSD status response into JSON", async () => {
|
||||
getServiceWidget.mockResolvedValue({ url: "http://127.0.0.1:3551" });
|
||||
|
||||
const req = { query: { group: "g", service: "svc", index: "0" } };
|
||||
const res = createMockRes();
|
||||
|
||||
await apcupsProxyHandler(req, res);
|
||||
|
||||
expect(res.statusCode).toBe(200);
|
||||
expect(res.body).toEqual({
|
||||
status: "ONLINE",
|
||||
load: "10.0",
|
||||
bcharge: "99.0",
|
||||
timeleft: "12.3",
|
||||
});
|
||||
});
|
||||
});
|
||||
13
src/widgets/apcups/widget.test.js
Normal file
13
src/widgets/apcups/widget.test.js
Normal file
@@ -0,0 +1,13 @@
|
||||
import { describe, expect, it } from "vitest";
|
||||
|
||||
import { expectWidgetConfigShape } from "test-utils/widget-config";
|
||||
|
||||
import widget from "./widget";
|
||||
|
||||
describe("apcups widget config", () => {
|
||||
it("exports a valid widget config", () => {
|
||||
expectWidgetConfigShape(widget);
|
||||
// apcups talks TCP directly, so it does not use an `{url}/...` API template.
|
||||
expect(widget.api).toBeUndefined();
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user