2019-05-30 18:41:18 +02:00
|
|
|
// 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(this.hasOwnProperty("#m"), false);
|
|
|
|
assert.sameValue("#m" in this, false);
|
|
|
|
|
2019-06-21 16:42:25 +02:00
|
|
|
assert.sameValue(this.__lookupSetter__("#m"), undefined);
|
2019-05-30 18:41:18 +02:00
|
|
|
|
|
|
|
this.#m = "Test262";
|
|
|
|
assert.sameValue(this._v, "Test262");
|
2019-06-21 16:42:25 +02:00
|
|
|
|
|
|
|
return 0;
|
2019-05-30 18:41:18 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
let c = new C();
|
2019-06-21 16:42:25 +02:00
|
|
|
assert.sameValue(c.checkPrivateSetter(), 0);
|