mirror of
https://github.com/tc39/test262.git
synced 2025-07-26 23:44:27 +02:00
Add test coverage for correct binding object MOP executions in with-environment
This commit is contained in:
parent
8cbcc309e6
commit
867ca540d6
@ -0,0 +1,66 @@
|
|||||||
|
// Copyright (C) 2024 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-object-environment-records-getbindingvalue-n-s
|
||||||
|
description: >
|
||||||
|
Lookups in proxy binding object for call expression.
|
||||||
|
info: |
|
||||||
|
9.1.1.2.1 HasBinding ( N )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let foundBinding be ? HasProperty(bindingObject, N).
|
||||||
|
3. If foundBinding is false, return false.
|
||||||
|
...
|
||||||
|
5. Let unscopables be ? Get(bindingObject, %Symbol.unscopables%).
|
||||||
|
...
|
||||||
|
7. Return true.
|
||||||
|
|
||||||
|
9.1.1.2.6 GetBindingValue ( N, S )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let value be ? HasProperty(bindingObject, N).
|
||||||
|
3. If value is false, then
|
||||||
|
a. If S is false, return undefined; otherwise throw a ReferenceError exception.
|
||||||
|
4. Return ? Get(bindingObject, N).
|
||||||
|
|
||||||
|
features: [Proxy, Reflect]
|
||||||
|
flags: [noStrict]
|
||||||
|
includes: [compareArray.js, proxyTrapsHelper.js]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var log = [];
|
||||||
|
|
||||||
|
// Environment contains referenced binding.
|
||||||
|
var env = {
|
||||||
|
Object,
|
||||||
|
};
|
||||||
|
|
||||||
|
var proxy = new Proxy(env, allowProxyTraps({
|
||||||
|
has(t, pk) {
|
||||||
|
log.push("has:" + String(pk));
|
||||||
|
return Reflect.has(t, pk);
|
||||||
|
},
|
||||||
|
get(t, pk, r) {
|
||||||
|
log.push("get:" + String(pk));
|
||||||
|
return Reflect.get(t, pk, r);
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
|
||||||
|
with (proxy) {
|
||||||
|
Object();
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.compareArray(log, [
|
||||||
|
// HasBinding, step 2.
|
||||||
|
"has:Object",
|
||||||
|
|
||||||
|
// HasBinding, step 5.
|
||||||
|
"get:Symbol(Symbol.unscopables)",
|
||||||
|
|
||||||
|
// GetBindingValue, step 2.
|
||||||
|
"has:Object",
|
||||||
|
|
||||||
|
// GetBindingValue, step 4.
|
||||||
|
"get:Object",
|
||||||
|
]);
|
@ -0,0 +1,66 @@
|
|||||||
|
// Copyright (C) 2024 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-object-environment-records-getbindingvalue-n-s
|
||||||
|
description: >
|
||||||
|
Lookups in proxy binding object for identifier reference.
|
||||||
|
info: |
|
||||||
|
9.1.1.2.1 HasBinding ( N )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let foundBinding be ? HasProperty(bindingObject, N).
|
||||||
|
3. If foundBinding is false, return false.
|
||||||
|
...
|
||||||
|
5. Let unscopables be ? Get(bindingObject, %Symbol.unscopables%).
|
||||||
|
...
|
||||||
|
7. Return true.
|
||||||
|
|
||||||
|
9.1.1.2.6 GetBindingValue ( N, S )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let value be ? HasProperty(bindingObject, N).
|
||||||
|
3. If value is false, then
|
||||||
|
a. If S is false, return undefined; otherwise throw a ReferenceError exception.
|
||||||
|
4. Return ? Get(bindingObject, N).
|
||||||
|
|
||||||
|
features: [Proxy, Reflect]
|
||||||
|
flags: [noStrict]
|
||||||
|
includes: [compareArray.js, proxyTrapsHelper.js]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var log = [];
|
||||||
|
|
||||||
|
// Environment contains referenced binding.
|
||||||
|
var env = {
|
||||||
|
Object,
|
||||||
|
};
|
||||||
|
|
||||||
|
var proxy = new Proxy(env, allowProxyTraps({
|
||||||
|
has(t, pk) {
|
||||||
|
log.push("has:" + String(pk));
|
||||||
|
return Reflect.has(t, pk);
|
||||||
|
},
|
||||||
|
get(t, pk, r) {
|
||||||
|
log.push("get:" + String(pk));
|
||||||
|
return Reflect.get(t, pk, r);
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
|
||||||
|
with (proxy) {
|
||||||
|
Object;
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.compareArray(log, [
|
||||||
|
// HasBinding, step 2.
|
||||||
|
"has:Object",
|
||||||
|
|
||||||
|
// HasBinding, step 5.
|
||||||
|
"get:Symbol(Symbol.unscopables)",
|
||||||
|
|
||||||
|
// GetBindingValue, step 2.
|
||||||
|
"has:Object",
|
||||||
|
|
||||||
|
// GetBindingValue, step 4.
|
||||||
|
"get:Object",
|
||||||
|
]);
|
@ -0,0 +1,40 @@
|
|||||||
|
// Copyright (C) 2024 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-object-environment-records-hasbinding-n
|
||||||
|
description: >
|
||||||
|
Lookups in proxy binding object for call expression.
|
||||||
|
info: |
|
||||||
|
9.1.1.2.1 HasBinding ( N )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let foundBinding be ? HasProperty(bindingObject, N).
|
||||||
|
3. If foundBinding is false, return false.
|
||||||
|
...
|
||||||
|
|
||||||
|
features: [Proxy, Reflect]
|
||||||
|
flags: [noStrict]
|
||||||
|
includes: [compareArray.js, proxyTrapsHelper.js]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var log = [];
|
||||||
|
|
||||||
|
// Empty environment.
|
||||||
|
var env = {};
|
||||||
|
|
||||||
|
var proxy = new Proxy(env, allowProxyTraps({
|
||||||
|
has(t, pk) {
|
||||||
|
log.push("has:" + String(pk));
|
||||||
|
return Reflect.has(t, pk);
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
|
||||||
|
with (proxy) {
|
||||||
|
Object();
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.compareArray(log, [
|
||||||
|
// HasBinding, step 2.
|
||||||
|
"has:Object",
|
||||||
|
]);
|
@ -0,0 +1,40 @@
|
|||||||
|
// Copyright (C) 2024 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-object-environment-records-hasbinding-n
|
||||||
|
description: >
|
||||||
|
Lookups in proxy binding object for identifier reference.
|
||||||
|
info: |
|
||||||
|
9.1.1.2.1 HasBinding ( N )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let foundBinding be ? HasProperty(bindingObject, N).
|
||||||
|
3. If foundBinding is false, return false.
|
||||||
|
...
|
||||||
|
|
||||||
|
features: [Proxy, Reflect]
|
||||||
|
flags: [noStrict]
|
||||||
|
includes: [compareArray.js, proxyTrapsHelper.js]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var log = [];
|
||||||
|
|
||||||
|
// Empty environment.
|
||||||
|
var env = {};
|
||||||
|
|
||||||
|
var proxy = new Proxy(env, allowProxyTraps({
|
||||||
|
has(t, pk) {
|
||||||
|
log.push("has:" + String(pk));
|
||||||
|
return Reflect.has(t, pk);
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
|
||||||
|
with (proxy) {
|
||||||
|
Object;
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.compareArray(log, [
|
||||||
|
// HasBinding, step 2.
|
||||||
|
"has:Object",
|
||||||
|
]);
|
@ -0,0 +1,105 @@
|
|||||||
|
// Copyright (C) 2024 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-object-environment-records-setmutablebinding-n-v-s
|
||||||
|
description: >
|
||||||
|
Lookups in proxy binding object for identifier reference.
|
||||||
|
info: |
|
||||||
|
9.1.1.2.1 HasBinding ( N )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let foundBinding be ? HasProperty(bindingObject, N).
|
||||||
|
3. If foundBinding is false, return false.
|
||||||
|
...
|
||||||
|
5. Let unscopables be ? Get(bindingObject, %Symbol.unscopables%).
|
||||||
|
...
|
||||||
|
7. Return true.
|
||||||
|
|
||||||
|
9.1.1.2.6 GetBindingValue ( N, S )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let value be ? HasProperty(bindingObject, N).
|
||||||
|
3. If value is false, then
|
||||||
|
a. If S is false, return undefined; otherwise throw a ReferenceError exception.
|
||||||
|
4. Return ? Get(bindingObject, N).
|
||||||
|
|
||||||
|
9.1.1.2.5 SetMutableBinding ( N, V, S )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let stillExists be ? HasProperty(bindingObject, N).
|
||||||
|
...
|
||||||
|
4. Perform ? Set(bindingObject, N, V, S).
|
||||||
|
...
|
||||||
|
|
||||||
|
10.1.9.2 OrdinarySetWithOwnDescriptor ( O, P, V, Receiver, ownDesc )
|
||||||
|
|
||||||
|
...
|
||||||
|
2. If IsDataDescriptor(ownDesc) is true, then
|
||||||
|
...
|
||||||
|
c. Let existingDescriptor be ? Receiver.[[GetOwnProperty]](P).
|
||||||
|
d. If existingDescriptor is not undefined, then
|
||||||
|
...
|
||||||
|
iv. Return ? Receiver.[[DefineOwnProperty]](P, valueDesc).
|
||||||
|
...
|
||||||
|
|
||||||
|
features: [Proxy, Reflect]
|
||||||
|
flags: [noStrict]
|
||||||
|
includes: [compareArray.js, proxyTrapsHelper.js]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var log = [];
|
||||||
|
|
||||||
|
// Environment contains referenced binding.
|
||||||
|
var env = {
|
||||||
|
p: 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
var proxy = new Proxy(env, allowProxyTraps({
|
||||||
|
has(t, pk) {
|
||||||
|
log.push("has:" + String(pk));
|
||||||
|
return Reflect.has(t, pk);
|
||||||
|
},
|
||||||
|
get(t, pk, r) {
|
||||||
|
log.push("get:" + String(pk));
|
||||||
|
return Reflect.get(t, pk, r);
|
||||||
|
},
|
||||||
|
set(t, pk, v, r) {
|
||||||
|
log.push("set:" + String(pk));
|
||||||
|
return Reflect.set(t, pk, v, r);
|
||||||
|
},
|
||||||
|
getOwnPropertyDescriptor(t, pk) {
|
||||||
|
log.push("getOwnPropertyDescriptor:" + String(pk));
|
||||||
|
return Reflect.getOwnPropertyDescriptor(t, pk);
|
||||||
|
},
|
||||||
|
defineProperty(t, pk, d) {
|
||||||
|
log.push("defineProperty:" + String(pk));
|
||||||
|
return Reflect.defineProperty(t, pk, d);
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
|
||||||
|
with (proxy) {
|
||||||
|
p += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.compareArray(log, [
|
||||||
|
// HasBinding, step 2.
|
||||||
|
"has:p",
|
||||||
|
|
||||||
|
// HasBinding, step 5.
|
||||||
|
"get:Symbol(Symbol.unscopables)",
|
||||||
|
|
||||||
|
// GetBindingValue, step 2.
|
||||||
|
"has:p",
|
||||||
|
|
||||||
|
// GetBindingValue, step 4.
|
||||||
|
"get:p",
|
||||||
|
|
||||||
|
// SetMutableBinding, step 2.
|
||||||
|
"has:p",
|
||||||
|
|
||||||
|
// SetMutableBinding, step 4.
|
||||||
|
"set:p",
|
||||||
|
"getOwnPropertyDescriptor:p",
|
||||||
|
"defineProperty:p",
|
||||||
|
]);
|
@ -0,0 +1,91 @@
|
|||||||
|
// Copyright (C) 2024 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-object-environment-records-setmutablebinding-n-v-s
|
||||||
|
description: >
|
||||||
|
Lookups in proxy binding object for identifier reference.
|
||||||
|
info: |
|
||||||
|
9.1.1.2.1 HasBinding ( N )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let foundBinding be ? HasProperty(bindingObject, N).
|
||||||
|
3. If foundBinding is false, return false.
|
||||||
|
...
|
||||||
|
5. Let unscopables be ? Get(bindingObject, %Symbol.unscopables%).
|
||||||
|
...
|
||||||
|
7. Return true.
|
||||||
|
|
||||||
|
9.1.1.2.5 SetMutableBinding ( N, V, S )
|
||||||
|
|
||||||
|
1. Let bindingObject be envRec.[[BindingObject]].
|
||||||
|
2. Let stillExists be ? HasProperty(bindingObject, N).
|
||||||
|
...
|
||||||
|
4. Perform ? Set(bindingObject, N, V, S).
|
||||||
|
...
|
||||||
|
|
||||||
|
10.1.9.2 OrdinarySetWithOwnDescriptor ( O, P, V, Receiver, ownDesc )
|
||||||
|
|
||||||
|
...
|
||||||
|
2. If IsDataDescriptor(ownDesc) is true, then
|
||||||
|
...
|
||||||
|
c. Let existingDescriptor be ? Receiver.[[GetOwnProperty]](P).
|
||||||
|
d. If existingDescriptor is not undefined, then
|
||||||
|
...
|
||||||
|
iv. Return ? Receiver.[[DefineOwnProperty]](P, valueDesc).
|
||||||
|
...
|
||||||
|
|
||||||
|
features: [Proxy, Reflect]
|
||||||
|
flags: [noStrict]
|
||||||
|
includes: [compareArray.js, proxyTrapsHelper.js]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var log = [];
|
||||||
|
|
||||||
|
// Environment contains referenced binding.
|
||||||
|
var env = {
|
||||||
|
p: 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
var proxy = new Proxy(env, allowProxyTraps({
|
||||||
|
has(t, pk) {
|
||||||
|
log.push("has:" + String(pk));
|
||||||
|
return Reflect.has(t, pk);
|
||||||
|
},
|
||||||
|
get(t, pk, r) {
|
||||||
|
log.push("get:" + String(pk));
|
||||||
|
return Reflect.get(t, pk, r);
|
||||||
|
},
|
||||||
|
set(t, pk, v, r) {
|
||||||
|
log.push("set:" + String(pk));
|
||||||
|
return Reflect.set(t, pk, v, r);
|
||||||
|
},
|
||||||
|
getOwnPropertyDescriptor(t, pk) {
|
||||||
|
log.push("getOwnPropertyDescriptor:" + String(pk));
|
||||||
|
return Reflect.getOwnPropertyDescriptor(t, pk);
|
||||||
|
},
|
||||||
|
defineProperty(t, pk, d) {
|
||||||
|
log.push("defineProperty:" + String(pk));
|
||||||
|
return Reflect.defineProperty(t, pk, d);
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
|
||||||
|
with (proxy) {
|
||||||
|
p = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.compareArray(log, [
|
||||||
|
// HasBinding, step 2.
|
||||||
|
"has:p",
|
||||||
|
|
||||||
|
// HasBinding, step 5.
|
||||||
|
"get:Symbol(Symbol.unscopables)",
|
||||||
|
|
||||||
|
// SetMutableBinding, step 2.
|
||||||
|
"has:p",
|
||||||
|
|
||||||
|
// SetMutableBinding, step 4.
|
||||||
|
"set:p",
|
||||||
|
"getOwnPropertyDescriptor:p",
|
||||||
|
"defineProperty:p",
|
||||||
|
]);
|
Loading…
x
Reference in New Issue
Block a user