import { describe, it, expect } from "vitest" ;
import { applyMergePatch } from "./merge-patch.js" ;
describe("applyMergePatch prototype pollution guard" , () => {
it("ignores __proto__ keys in patch" , () => {
const base = { a: 1 };
const patch = JSON.parse('{"__proto__": {"polluted": true}, "b": 2}' );
const result = applyMergePatch(base, patch) as Record<string, unknown>;
expect(result.b).toBe(2 );
expect(result.a).toBe(1 );
expect(Object.prototype.hasOwnProperty.call(result, "__proto__" )).toBe(false );
expect(result.polluted).toBeUndefined();
expect(({} as Record<string, unknown>).polluted).toBeUndefined();
});
it("ignores constructor key in patch" , () => {
const base = { a: 1 };
const patch = { constructor: { polluted: true }, b: 2 };
const result = applyMergePatch(base, patch) as Record<string, unknown>;
expect(result.b).toBe(2 );
expect(Object.prototype.hasOwnProperty.call(result, "constructor" )).toBe(false );
});
it("ignores prototype key in patch" , () => {
const base = { a: 1 };
const patch = { prototype: { polluted: true }, b: 2 };
const result = applyMergePatch(base, patch) as Record<string, unknown>;
expect(result.b).toBe(2 );
expect(Object.prototype.hasOwnProperty.call(result, "prototype" )).toBe(false );
});
it("ignores __proto__ in nested patches" , () => {
const base = { nested: { x: 1 } };
const patch = JSON.parse('{"nested": {"__proto__": {"polluted": true}, "y": 2}}' );
const result = applyMergePatch(base, patch) as { nested: Record<string, unknown> };
expect(result.nested.y).toBe(2 );
expect(result.nested.x).toBe(1 );
expect(Object.prototype.hasOwnProperty.call(result.nested, "__proto__" )).toBe(false );
expect(result.nested.polluted).toBeUndefined();
expect(({} as Record<string, unknown>).polluted).toBeUndefined();
});
});
Messung V0.5 in Prozent C=94 H=95 G=94
¤ Dauer der Verarbeitung: 0.10 Sekunden
(vorverarbeitet am 2026-06-05)
¤
*© Formatika GbR, Deutschland