guardia-messenger/node_modules/node-abort-controller/__tests__/abort-controller.js
DESKTOP-TKLFCPRython f29f525c77 refactor: 101.79.17.164 → zioinfo.co.kr 전체 도메인 변환 + Manager UI 배포
- 37개 파일 IP → zioinfo.co.kr 치환 (소스/매뉴얼/설정/하네스)
- Manager DrConsole/NetworkConsole/CsapConsole 빌드 + /var/www/manager/ 배포
- 테스트: Manager HTTP 200, ITSM 신규 API 7개 전체 200

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 10:09:17 +09:00

47 lines
1.4 KiB
JavaScript

const { AbortController } = require("../index.js");
describe("AbortController", function () {
it("should call abort handlers once", function () {
const controller = new AbortController();
const signal = controller.signal;
const handler = jest.fn();
expect(signal.onabort).toBeNull();
expect(signal.aborted).toBe(false);
expect(signal.reason).toBeUndefined();
signal.onabort = jest.fn();
signal.addEventListener("abort", handler);
controller.abort();
expect(signal.aborted).toBe(true);
expect(signal.reason).toEqual(new Error("AbortError"));
expect(handler).toBeCalledTimes(1);
expect(handler).toBeCalledWith({ type: "abort", target: signal });
expect(signal.onabort).toBeCalledTimes(1);
expect(signal.onabort).toBeCalledWith({ type: "abort", target: signal });
jest.clearAllMocks();
controller.abort();
expect(signal.aborted).toBe(true);
expect(signal.reason).toEqual(new Error("AbortError"));
expect(handler).not.toBeCalled();
expect(signal.onabort).not.toBeCalled();
});
it("should use custom abort reason", () => {
const controller = new AbortController();
const signal = controller.signal;
expect(signal.aborted).toBe(false);
expect(signal.reason).toBeUndefined();
const customReason = new Error("Custom Reason");
controller.abort(customReason);
expect(signal.aborted).toBe(true);
expect(signal.reason).toBe(customReason);
});
});