mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-30 12:49:19 +00:00
LibJS: Use a custom property_name_to_value method instead of to_value
This commit is contained in:
parent
721238f41c
commit
ce59e49e27
Notes:
sideshowbarker
2024-07-18 10:23:00 +09:00
Author: https://github.com/davidot
Commit: ce59e49e27
Pull-request: https://github.com/SerenityOS/serenity/pull/8294
Reviewed-by: https://github.com/IdanHo
Reviewed-by: https://github.com/linusg ✅
7 changed files with 104 additions and 6 deletions
|
@ -27,6 +27,25 @@ describe("[[DefineProperty]] trap normal behavior", () => {
|
|||
Object.defineProperty(p, "foo", { configurable: true, writable: true, value: 10 });
|
||||
});
|
||||
|
||||
test("correct arguments passed to trap even for number", () => {
|
||||
let o = {};
|
||||
p = new Proxy(o, {
|
||||
defineProperty(target, name, descriptor) {
|
||||
expect(target).toBe(o);
|
||||
expect(name).toBe("1");
|
||||
expect(descriptor.configurable).toBeTrue();
|
||||
expect(descriptor.enumerable).toBeUndefined();
|
||||
expect(descriptor.writable).toBeTrue();
|
||||
expect(descriptor.value).toBe(10);
|
||||
expect(descriptor.get).toBeUndefined();
|
||||
expect(descriptor.set).toBeUndefined();
|
||||
return true;
|
||||
},
|
||||
});
|
||||
|
||||
Object.defineProperty(p, 1, { configurable: true, writable: true, value: 10 });
|
||||
});
|
||||
|
||||
test("optionally ignoring the define call", () => {
|
||||
let o = {};
|
||||
let p = new Proxy(o, {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue