Merge pull request #2235 from mkubilayk/static-subclass-receiver

Check static private methods on super class are called with correct receiver
This commit is contained in:
Leo Balter 2019-07-19 14:01:51 -04:00 committed by GitHub
commit b3b0e8e190
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 107 additions and 0 deletions

View File

@ -0,0 +1,33 @@
// Copyright (C) 2019 Kubilay Kahveci (Bloomberg LP). All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
desc: Static private methods on the super-class cannot be called with sub-class as the receiver
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",
...
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.
template: default
features: [class-static-methods-private]
---*/
//- elements
static f() { return this.#g(); }
static #g() { return 42; }
//- assertions
class D extends C {}
assert.sameValue(C.f(), 42);
assert.throws(TypeError, function() {
D.f();
}, 'D does not contain static private method #g');

View File

@ -0,0 +1,37 @@
// This file was procedurally generated from the following sources:
// - src/class-elements/static-private-method-subclass-receiver.case
// - src/class-elements/default/cls-expr.template
/*---
description: Static private methods on the super-class cannot be called with sub-class as the receiver (field definitions in a class expression)
esid: prod-FieldDefinition
features: [class-static-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",
...
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.
---*/
var C = class {
static f() { return this.#g(); }
static #g() { return 42; }
}
class D extends C {}
assert.sameValue(C.f(), 42);
assert.throws(TypeError, function() {
D.f();
}, 'D does not contain static private method #g');

View File

@ -0,0 +1,37 @@
// This file was procedurally generated from the following sources:
// - src/class-elements/static-private-method-subclass-receiver.case
// - src/class-elements/default/cls-decl.template
/*---
description: Static private methods on the super-class cannot be called with sub-class as the receiver (field definitions in a class declaration)
esid: prod-FieldDefinition
features: [class-static-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",
...
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 this.#g(); }
static #g() { return 42; }
}
class D extends C {}
assert.sameValue(C.f(), 42);
assert.throws(TypeError, function() {
D.f();
}, 'D does not contain static private method #g');