mirror of https://github.com/tc39/test262.git
Adding test cases to verify that private methods and accessors are not visible to [[GetOwnProperty]] and [[HasProperty]].
This commit is contained in:
parent
df1a1c75b7
commit
f1ac274f9d
|
@ -0,0 +1,48 @@
|
|||
// Copyright (C) 2019 Caio Lima (Igalia SL). All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
|
||||
/*---
|
||||
desc: Private getter is not stored as an own property of objects
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
template: default
|
||||
features: [class-methods-private]
|
||||
---*/
|
||||
|
||||
//- elements
|
||||
get #m() { return "Test262"; }
|
||||
|
||||
checkPrivateGetter() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
assert.sameValue(this.#m, "Test262");
|
||||
}
|
||||
//- assertions
|
||||
let c = new C();
|
||||
c.checkPrivateGetter();
|
|
@ -0,0 +1,49 @@
|
|||
// Copyright (C) 2019 Caio Lima (Igalia SL). All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
|
||||
/*---
|
||||
desc: Private method is not stored as an own property of objects
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
template: default
|
||||
includes: [compareArray.js]
|
||||
features: [class-methods-private]
|
||||
---*/
|
||||
|
||||
//- elements
|
||||
#m() { return "Test262"; }
|
||||
|
||||
checkPrivateMethod() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
assert.sameValue(this.#m(), "Test262");
|
||||
}
|
||||
//- assertions
|
||||
let c = new C();
|
||||
c.checkPrivateMethod();
|
|
@ -0,0 +1,49 @@
|
|||
// Copyright (C) 2019 Caio Lima (Igalia SL). All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
|
||||
/*---
|
||||
desc: Private setter is not stored as an own property of objects
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
template: default
|
||||
features: [class-methods-private]
|
||||
---*/
|
||||
|
||||
//- elements
|
||||
set #m(v) { this._v = v; }
|
||||
|
||||
checkPrivateSetter() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
this.#m = "Test262";
|
||||
assert.sameValue(this._v, "Test262");
|
||||
}
|
||||
//- assertions
|
||||
let c = new C();
|
||||
c.checkPrivateSetter();
|
|
@ -0,0 +1,52 @@
|
|||
// This file was procedurally generated from the following sources:
|
||||
// - src/class-elements/private-getter-is-not-a-own-property.case
|
||||
// - src/class-elements/default/cls-expr.template
|
||||
/*---
|
||||
description: Private getter is not stored as an own property of objects (field definitions in a class expression)
|
||||
esid: prod-FieldDefinition
|
||||
features: [class-methods-private, class]
|
||||
flags: [generated]
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
|
||||
---*/
|
||||
|
||||
|
||||
var C = class {
|
||||
get #m() { return "Test262"; }
|
||||
|
||||
checkPrivateGetter() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
assert.sameValue(this.#m, "Test262");
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
c.checkPrivateGetter();
|
|
@ -0,0 +1,53 @@
|
|||
// This file was procedurally generated from the following sources:
|
||||
// - src/class-elements/private-method-is-not-a-own-property.case
|
||||
// - src/class-elements/default/cls-expr.template
|
||||
/*---
|
||||
description: Private method is not stored as an own property of objects (field definitions in a class expression)
|
||||
esid: prod-FieldDefinition
|
||||
features: [class-methods-private, class]
|
||||
flags: [generated]
|
||||
includes: [compareArray.js]
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
|
||||
---*/
|
||||
|
||||
|
||||
var C = class {
|
||||
#m() { return "Test262"; }
|
||||
|
||||
checkPrivateMethod() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
assert.sameValue(this.#m(), "Test262");
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
c.checkPrivateMethod();
|
|
@ -0,0 +1,53 @@
|
|||
// This file was procedurally generated from the following sources:
|
||||
// - src/class-elements/private-setter-is-not-a-own-property.case
|
||||
// - src/class-elements/default/cls-expr.template
|
||||
/*---
|
||||
description: Private setter is not stored as an own property of objects (field definitions in a class expression)
|
||||
esid: prod-FieldDefinition
|
||||
features: [class-methods-private, class]
|
||||
flags: [generated]
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
|
||||
---*/
|
||||
|
||||
|
||||
var C = class {
|
||||
set #m(v) { this._v = v; }
|
||||
|
||||
checkPrivateSetter() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
this.#m = "Test262";
|
||||
assert.sameValue(this._v, "Test262");
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
c.checkPrivateSetter();
|
|
@ -0,0 +1,52 @@
|
|||
// This file was procedurally generated from the following sources:
|
||||
// - src/class-elements/private-getter-is-not-a-own-property.case
|
||||
// - src/class-elements/default/cls-decl.template
|
||||
/*---
|
||||
description: Private getter is not stored as an own property of objects (field definitions in a class declaration)
|
||||
esid: prod-FieldDefinition
|
||||
features: [class-methods-private, class]
|
||||
flags: [generated]
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
|
||||
---*/
|
||||
|
||||
|
||||
class C {
|
||||
get #m() { return "Test262"; }
|
||||
|
||||
checkPrivateGetter() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
assert.sameValue(this.#m, "Test262");
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
c.checkPrivateGetter();
|
|
@ -0,0 +1,53 @@
|
|||
// This file was procedurally generated from the following sources:
|
||||
// - src/class-elements/private-method-is-not-a-own-property.case
|
||||
// - src/class-elements/default/cls-decl.template
|
||||
/*---
|
||||
description: Private method is not stored as an own property of objects (field definitions in a class declaration)
|
||||
esid: prod-FieldDefinition
|
||||
features: [class-methods-private, class]
|
||||
flags: [generated]
|
||||
includes: [compareArray.js]
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
|
||||
---*/
|
||||
|
||||
|
||||
class C {
|
||||
#m() { return "Test262"; }
|
||||
|
||||
checkPrivateMethod() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
assert.sameValue(this.#m(), "Test262");
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
c.checkPrivateMethod();
|
|
@ -0,0 +1,53 @@
|
|||
// This file was procedurally generated from the following sources:
|
||||
// - src/class-elements/private-setter-is-not-a-own-property.case
|
||||
// - src/class-elements/default/cls-decl.template
|
||||
/*---
|
||||
description: Private setter is not stored as an own property of objects (field definitions in a class declaration)
|
||||
esid: prod-FieldDefinition
|
||||
features: [class-methods-private, class]
|
||||
flags: [generated]
|
||||
info: |
|
||||
PrivateFieldGet (P, O)
|
||||
1. Assert: P is a Private Name.
|
||||
2. If O is not an object, throw a TypeError exception.
|
||||
3. If P.[[Kind]] is "field",
|
||||
a. Let entry be PrivateFieldFind(P, O).
|
||||
b. If entry is empty, throw a TypeError exception.
|
||||
c. Return entry.[[PrivateFieldValue]].
|
||||
4. Perform ? PrivateBrandCheck(O, P).
|
||||
5. If P.[[Kind]] is "method",
|
||||
a. Return P.[[Value]].
|
||||
6. Else,
|
||||
a. Assert: P.[[Kind]] is "accessor".
|
||||
b. If P does not have a [[Get]] field, throw a TypeError exception.
|
||||
c. Let getter be P.[[Get]].
|
||||
d. Return ? Call(getter, O).
|
||||
|
||||
---*/
|
||||
|
||||
|
||||
class C {
|
||||
set #m(v) { this._v = v; }
|
||||
|
||||
checkPrivateSetter() {
|
||||
assert.sameValue(Object.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
assert.sameValue(Reflect.getOwnPropertyDescriptor(this, "#m"), undefined);
|
||||
|
||||
assert.sameValue(this.hasOwnProperty("#m"), false);
|
||||
assert.sameValue(Reflect.has(this, "#m"), false);
|
||||
|
||||
assert.compareArray(Object.getOwnPropertyNames(this), []);
|
||||
assert.compareArray(Reflect.ownKeys(this), []);
|
||||
|
||||
assert.sameValue("#m" in this, false);
|
||||
|
||||
const descriptors = Object.getOwnPropertyDescriptors(this);
|
||||
assert.sameValue("#m" in descriptors, false);
|
||||
|
||||
this.#m = "Test262";
|
||||
assert.sameValue(this._v, "Test262");
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
c.checkPrivateSetter();
|
Loading…
Reference in New Issue