ladybird/Libraries/LibJS/Tests/builtins/Reflect/Reflect.preventExtensions.js
Matthew Olsson 93ebd320ef LibJS: Object.preventExtensions should allow property modfication
Existing properties on a non-extensible object should be changable and
deletable.
2020-07-07 10:47:10 +02:00

42 lines
1.2 KiB
JavaScript

describe("errors", () => {
test("target must be an object", () => {
[null, undefined, "foo", 123, NaN, Infinity].forEach(value => {
expect(() => {
Reflect.preventExtensions(value);
}).toThrowWithMessage(
TypeError,
"First argument of Reflect.preventExtensions() must be an object"
);
});
});
});
describe("normal behavior", () => {
test("length is 1", () => {
expect(Reflect.preventExtensions).toHaveLength(1);
});
test("properties cannot be added", () => {
var o = {};
o.foo = "foo";
expect(Reflect.preventExtensions(o)).toBeTrue();
o.bar = "bar";
expect(o.foo).toBe("foo");
expect(o.bar).toBeUndefined();
});
test("modifying existing properties", () => {
const o = {};
o.foo = "foo";
expect(Reflect.preventExtensions(o)).toBeTrue();
o.foo = "bar";
expect(o.foo).toBe("bar");
});
test("deleting existing properties", () => {
const o = { foo: "bar" };
Reflect.preventExtensions(o);
delete o.foo;
expect(o).not.toHaveProperty("foo");
});
});