Files
OmniRoute/tests/unit/ip-filter.test.mjs
T
diegosouzapw 0546d06c0a
Build Electron Desktop App / Validate version (push) Failing after 32s
Build Electron Desktop App / Build Electron (macos-arm64) (push) Has been skipped
Build Electron Desktop App / Build Electron (linux) (push) Has been skipped
Build Electron Desktop App / Build Electron (macos-intel) (push) Has been skipped
Build Electron Desktop App / Build Electron (windows) (push) Has been skipped
Build Electron Desktop App / Create Release (push) Has been skipped
fix(types): cast extracted usage to Record<string,number> in stream.ts to resolve TS property errors
Also fix syntax error in openai-to-claude-strip-empty.test.mjs (tool/assistant messages were incorrectly nested)
2026-03-23 09:21:03 -03:00

167 lines
6.4 KiB
JavaScript

import test from "node:test";
import assert from "node:assert/strict";
const {
checkIP,
configureIPFilter,
tempBanIP,
removeTempBan,
addToBlacklist,
removeFromBlacklist,
addToWhitelist,
removeFromWhitelist,
getIPFilterConfig,
checkRequestIP,
resetIPFilter,
} = await import("../../open-sse/services/ipFilter.ts");
test.beforeEach(() => resetIPFilter());
// ─── Disabled ───────────────────────────────────────────────────────────────
test("disabled: allows all IPs", () => {
assert.equal(checkIP("1.2.3.4").allowed, true);
});
// ─── Blacklist Mode ─────────────────────────────────────────────────────────
test("blacklist: blocks blacklisted IP", () => {
configureIPFilter({ enabled: true, mode: "blacklist", blacklist: ["1.2.3.4"] });
assert.equal(checkIP("1.2.3.4").allowed, false);
assert.equal(checkIP("5.6.7.8").allowed, true);
});
test("blacklist: CIDR match", () => {
configureIPFilter({ enabled: true, mode: "blacklist", blacklist: ["192.168.1.0/24"] });
assert.equal(checkIP("192.168.1.100").allowed, false);
assert.equal(checkIP("192.168.2.1").allowed, true);
});
test("blacklist: wildcard match", () => {
configureIPFilter({ enabled: true, mode: "blacklist", blacklist: ["10.0.*.*"] });
assert.equal(checkIP("10.0.1.1").allowed, false);
assert.equal(checkIP("10.1.0.1").allowed, true);
});
// ─── Whitelist Mode ─────────────────────────────────────────────────────────
test("whitelist: only allows listed IPs", () => {
configureIPFilter({ enabled: true, mode: "whitelist", whitelist: ["1.2.3.4"] });
assert.equal(checkIP("1.2.3.4").allowed, true);
assert.equal(checkIP("5.6.7.8").allowed, false);
});
test("whitelist: CIDR match", () => {
configureIPFilter({ enabled: true, mode: "whitelist", whitelist: ["10.0.0.0/8"] });
assert.equal(checkIP("10.255.255.255").allowed, true);
assert.equal(checkIP("11.0.0.1").allowed, false);
});
// ─── Whitelist Priority Mode ────────────────────────────────────────────────
test("whitelist-priority: whitelist overrides blacklist", () => {
configureIPFilter({
enabled: true,
mode: "whitelist-priority",
blacklist: ["192.168.1.0/24"],
whitelist: ["192.168.1.100"],
});
assert.equal(checkIP("192.168.1.100").allowed, true); // Whitelisted
assert.equal(checkIP("192.168.1.50").allowed, false); // Blacklisted
assert.equal(checkIP("10.0.0.1").allowed, true); // Neither
});
// ─── Temporary Bans ─────────────────────────────────────────────────────────
test("tempBanIP: bans temporarily", () => {
configureIPFilter({ enabled: true, mode: "blacklist" });
tempBanIP("5.5.5.5", 60000, "abuse");
assert.equal(checkIP("5.5.5.5").allowed, false);
assert.ok(checkIP("5.5.5.5").reason.includes("banned"));
});
test("removeTempBan: removes ban", () => {
configureIPFilter({ enabled: true, mode: "blacklist" });
tempBanIP("5.5.5.5", 60000, "abuse");
removeTempBan("5.5.5.5");
assert.equal(checkIP("5.5.5.5").allowed, true);
});
// ─── Dynamic List Management ────────────────────────────────────────────────
test("addToBlacklist/removeFromBlacklist: dynamic updates", () => {
configureIPFilter({ enabled: true, mode: "blacklist" });
addToBlacklist("9.9.9.9");
assert.equal(checkIP("9.9.9.9").allowed, false);
removeFromBlacklist("9.9.9.9");
assert.equal(checkIP("9.9.9.9").allowed, true);
});
test("addToWhitelist/removeFromWhitelist: dynamic updates", () => {
configureIPFilter({ enabled: true, mode: "whitelist" });
addToWhitelist("1.1.1.1");
assert.equal(checkIP("1.1.1.1").allowed, true);
removeFromWhitelist("1.1.1.1");
assert.equal(checkIP("1.1.1.1").allowed, false);
});
// ─── IPv6 Normalization ─────────────────────────────────────────────────────
test("normalizes ::ffff: prefix", () => {
configureIPFilter({ enabled: true, mode: "blacklist", blacklist: ["1.2.3.4"] });
assert.equal(checkIP("::ffff:1.2.3.4").allowed, false);
});
// ─── T07: X-Forwarded-For validation ───────────────────────────────────────
test("checkRequestIP: skips invalid XFF entries and uses next valid IP", () => {
configureIPFilter({ enabled: true, mode: "whitelist", whitelist: ["1.2.3.4"] });
const req = {
headers: {
get(name) {
if (name === "x-forwarded-for") return "unknown, 1.2.3.4";
return null;
},
},
};
assert.equal(checkRequestIP(req).allowed, true);
});
test("checkRequestIP: all-invalid XFF falls back to x-real-ip", () => {
configureIPFilter({ enabled: true, mode: "whitelist", whitelist: ["9.9.9.9"] });
const req = {
headers: {
get(name) {
if (name === "x-forwarded-for") return "unknown, -, not_an_ip";
if (name === "x-real-ip") return "9.9.9.9";
return null;
},
},
};
assert.equal(checkRequestIP(req).allowed, true);
});
test("checkRequestIP: empty headers fall back to request.ip", () => {
configureIPFilter({ enabled: true, mode: "whitelist", whitelist: ["7.7.7.7"] });
const req = {
headers: {
get() {
return null;
},
},
ip: "7.7.7.7",
};
assert.equal(checkRequestIP(req).allowed, true);
});
// ─── Config API ─────────────────────────────────────────────────────────────
test("getIPFilterConfig: returns serializable config", () => {
configureIPFilter({ enabled: true, mode: "whitelist", whitelist: ["1.2.3.4"] });
const config = getIPFilterConfig();
assert.equal(config.enabled, true);
assert.equal(config.mode, "whitelist");
assert.ok(Array.isArray(config.whitelist));
assert.ok(config.whitelist.includes("1.2.3.4"));
});