test262/test/language/statements/class/elements/static-private-method-and-i...

65 lines
1.9 KiB
JavaScript

// This file was procedurally generated from the following sources:
// - src/class-elements/static-private-method-and-instance-method-brand-check.case
// - src/class-elements/default/cls-decl.template
/*---
description: Brand for static private names and instance private names are different (field definitions in a class declaration)
esid: prod-FieldDefinition
features: [class-static-methods-private, class-methods-private, class]
flags: [generated]
info: |
ClassTail : ClassHeritage { ClassBody }
...
32. If PrivateBoundIdentifiers of ClassBody contains a Private Name P such that P's [[Kind]] field is either "method" or "accessor" and P's [[Brand]] field is proto,
a. Set F.[[PrivateBrand]] to proto.
33. If PrivateBoundIdentifiers of ClassBody contains a Private Name P such that P's [[Kind]] field is either "method" or "accessor" and P's [[Brand]] is F,
a. PrivateBrandAdd(F, F).
...
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",
...
4. Perform ? PrivateBrandCheck(O, P).
5. If P.[[Kind]] is "method",
a. Return P.[[Value]].
...
PrivateBrandCheck(O, P)
1. If O.[[PrivateBrands]] does not contain an entry e such that SameValue(e, P.[[Brand]]) is true,
a. Throw a TypeError exception.
---*/
class C {
static #f() {
return 'static';
}
static access() {
return this.#f();
}
#instanceMethod() {
return 'instance';
}
instanceAccess() {
return this.#instanceMethod();
}
}
let c = new C();
assert.sameValue(C.access(), 'static');
assert.sameValue(c.instanceAccess(), 'instance');
assert.throws(TypeError, function() {
C.access.call(c);
}, 'Accessed static private method from instance of C');
assert.throws(TypeError, function() {
c.instanceAccess.call(C);
}, 'Accessed instance private method from C');