55c33c015e
According to spec https://tc39.es/ecma262/#sec-object.preventextensions, the commit 8e0ef9b9a0
is missing the last step when object is proxy, it needs to return the object.
var proxy = new Proxy({}, {});
var object = Object.preventExtensions(proxy);
proxy === object; // should be true
Also, add mjsunit test.
Bug: v8:6664
Change-Id: Ic3688519539f8903ee0bc7e885905a86d195a4db
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1668443
Commit-Queue: Z Nguyen-Huu <duongn@microsoft.com>
Reviewed-by: Maya Lekova <mslekova@chromium.org>
Reviewed-by: Jakob Gruber <jgruber@chromium.org>
Cr-Commit-Position: refs/heads/master@{#62393}
204 lines
5.3 KiB
JavaScript
204 lines
5.3 KiB
JavaScript
// Copyright 2015 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Reflect.
|
|
(function () {
|
|
// No trap.
|
|
|
|
var target = {};
|
|
var handler = {};
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertTrue(Reflect.isExtensible(target));
|
|
assertTrue(Reflect.isExtensible(proxy));
|
|
assertTrue(Reflect.preventExtensions(proxy));
|
|
assertFalse(Reflect.isExtensible(target));
|
|
assertFalse(Reflect.isExtensible(proxy));
|
|
})();
|
|
|
|
(function () {
|
|
// "Undefined" trap.
|
|
|
|
var target = {};
|
|
var handler = { preventExtensions: null };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertTrue(Reflect.isExtensible(target));
|
|
assertTrue(Reflect.isExtensible(proxy));
|
|
assertTrue(Reflect.preventExtensions(proxy));
|
|
assertFalse(Reflect.isExtensible(target));
|
|
assertFalse(Reflect.isExtensible(proxy));
|
|
})();
|
|
|
|
|
|
(function () {
|
|
// Invalid trap.
|
|
|
|
var target = {};
|
|
var handler = { preventExtensions: 42 };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertThrows(() => { Reflect.preventExtensions(proxy) }, TypeError);
|
|
})();
|
|
|
|
|
|
(function () {
|
|
var target = {};
|
|
var handler = { isExtensible() { return "bla" } };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
// Trap returns trueish and target is extensible.
|
|
assertTrue(Reflect.isExtensible(proxy));
|
|
|
|
// Trap returns trueish but target is not extensible.
|
|
Reflect.preventExtensions(target);
|
|
assertThrows(() => { Reflect.isExtensible(proxy) }, TypeError);
|
|
})();
|
|
|
|
|
|
(function () {
|
|
// Trap returns falsish.
|
|
|
|
var target = {};
|
|
var handler = { preventExtensions() { return 0 } };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertFalse(Reflect.preventExtensions(proxy));
|
|
Reflect.preventExtensions(target);
|
|
assertFalse(Reflect.preventExtensions(proxy));
|
|
})();
|
|
|
|
|
|
(function () {
|
|
var target = {};
|
|
var handler = { preventExtensions() { return Symbol() } };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
// Trap returns trueish but target is extensible.
|
|
assertThrows(() => { Reflect.preventExtensions(proxy) }, TypeError);
|
|
|
|
// Trap returns trueish and target is not extensible.
|
|
Reflect.preventExtensions(target);
|
|
assertTrue(Reflect.preventExtensions(proxy));
|
|
})();
|
|
|
|
|
|
(function () {
|
|
// Target is proxy
|
|
var object = {};
|
|
assertTrue(Reflect.preventExtensions(object));
|
|
var target = new Proxy(object, {});
|
|
var proxy = new Proxy(target, {});
|
|
assertFalse(Reflect.isExtensible(object));
|
|
assertFalse(Reflect.isExtensible(target));
|
|
assertFalse(Reflect.isExtensible(proxy));
|
|
})();
|
|
|
|
// Object.
|
|
(function () {
|
|
// No trap.
|
|
|
|
var target = {};
|
|
var handler = {};
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertTrue(Object.isExtensible(target));
|
|
assertTrue(Object.isExtensible(proxy));
|
|
assertSame(proxy, Object.preventExtensions(proxy));
|
|
assertFalse(Object.isExtensible(target));
|
|
assertFalse(Object.isExtensible(proxy));
|
|
})();
|
|
|
|
(function () {
|
|
// "Undefined" trap.
|
|
|
|
var target = {};
|
|
var handler = { preventExtensions: null };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertTrue(Object.isExtensible(target));
|
|
assertTrue(Object.isExtensible(proxy));
|
|
assertSame(proxy, Object.preventExtensions(proxy));
|
|
assertFalse(Object.isExtensible(target));
|
|
assertFalse(Object.isExtensible(proxy));
|
|
})();
|
|
|
|
|
|
(function () {
|
|
// Invalid trap.
|
|
|
|
var target = {};
|
|
var handler = { preventExtensions: 42 };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertThrows(() => { Object.preventExtensions(proxy) }, TypeError);
|
|
})();
|
|
|
|
|
|
(function () {
|
|
var target = {};
|
|
var handler = { isExtensible() { return "bla" } };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
// Trap returns trueish and target is extensible.
|
|
assertTrue(Object.isExtensible(proxy));
|
|
|
|
// Trap returns trueish but target is not extensible.
|
|
assertSame(target, Object.preventExtensions(target));
|
|
assertThrows(() => { Object.isExtensible(proxy) }, TypeError);
|
|
})();
|
|
|
|
|
|
(function () {
|
|
// Trap returns falsish.
|
|
|
|
var target = {};
|
|
var handler = { isExtensible() { return false } };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertThrows(() => { Object.isExtensible(proxy) }, TypeError);
|
|
assertSame(target, Object.preventExtensions(target));
|
|
assertFalse(Object.isExtensible(proxy));
|
|
})();
|
|
|
|
|
|
(function () {
|
|
// Trap returns falsish.
|
|
|
|
var target = {};
|
|
var handler = { preventExtensions() { return 0 } };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
assertFalse(Reflect.preventExtensions(proxy));
|
|
assertSame(target, Object.preventExtensions(target));
|
|
assertFalse(Reflect.preventExtensions(proxy));
|
|
assertThrows(() => { Object.preventExtensions(proxy) }, TypeError);
|
|
})();
|
|
|
|
|
|
(function () {
|
|
var target = {};
|
|
var handler = { preventExtensions() { return Symbol() } };
|
|
var proxy = new Proxy(target, handler);
|
|
|
|
// Trap returns trueish but target is extensible.
|
|
assertThrows(() => { Object.preventExtensions(proxy) }, TypeError);
|
|
|
|
// Trap returns trueish and target is not extensible.
|
|
assertSame(target, Object.preventExtensions(target));
|
|
assertTrue(Reflect.preventExtensions(proxy));
|
|
})();
|
|
|
|
|
|
(function () {
|
|
// Target is proxy
|
|
var object = {};
|
|
assertSame(object, Object.preventExtensions(object));
|
|
var target = new Proxy(object, {});
|
|
var proxy = new Proxy(target, {});
|
|
assertFalse(Object.isExtensible(object));
|
|
assertFalse(Object.isExtensible(target));
|
|
assertFalse(Object.isExtensible(proxy));
|
|
})();
|