Chore: homepage tests (#6278)

This commit is contained in:
shamoon
2026-02-04 19:58:39 -08:00
committed by GitHub
parent 7d019185a3
commit 872a3600aa
558 changed files with 32606 additions and 84 deletions

View 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();
});
});

View 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",
});
});
});

View 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();
});
});