mirror of https://github.com/tc39/test262.git
Added private static accessor cases with direct eval access (#2305)
This commit is contained in:
parent
8042c57d9b
commit
8790a8e98a
|
@ -0,0 +1,61 @@
|
|||
// Copyright (C) 2019 Caio Lima (Igalia SL). All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
|
||||
/*---
|
||||
description: Private static getter is visible to direct eval code
|
||||
esid: sec-privatefieldget
|
||||
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).
|
||||
|
||||
ClassElementName : PrivateIdentifier
|
||||
1. Let privateIdentifier be StringValue of PrivateIdentifier.
|
||||
2. Let privateName be NewPrivateName(privateIdentifier).
|
||||
3. Let scope be the running execution context's PrivateEnvironment.
|
||||
4. Let scopeEnvRec be scope's EnvironmentRecord.
|
||||
5. Perform ! scopeEnvRec.InitializeBinding(privateIdentifier, privateName).
|
||||
6. Return privateName.
|
||||
|
||||
MakePrivateReference ( baseValue, privateIdentifier )
|
||||
1. Let env be the running execution context's PrivateEnvironment.
|
||||
2. Let privateNameBinding be ? ResolveBinding(privateIdentifier, env).
|
||||
3. Let privateName be GetValue(privateNameBinding).
|
||||
4. Assert: privateName is a Private Name.
|
||||
5. Return a value of type Reference whose base value is baseValue, whose referenced name is privateName, whose strict reference flag is true.
|
||||
features: [class-static-methods-private, class]
|
||||
---*/
|
||||
|
||||
class C {
|
||||
static get #m() {
|
||||
return 'Test262';
|
||||
}
|
||||
|
||||
static getWithEval() {
|
||||
return eval('this.#m');
|
||||
}
|
||||
}
|
||||
|
||||
class D {
|
||||
static get #m() {
|
||||
throw new Test262Error('should never be executed');
|
||||
}
|
||||
}
|
||||
|
||||
assert.sameValue(C.getWithEval(), 'Test262');
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
C.getWithEval.call(D);
|
||||
}, 'invalid access to a static private getter');
|
|
@ -0,0 +1,62 @@
|
|||
// Copyright (C) 2019 Caio Lima (Igalia SL). All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
|
||||
/*---
|
||||
description: Private static setter is visible to direct eval code
|
||||
esid: sec-privatefieldget
|
||||
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).
|
||||
|
||||
ClassElementName : PrivateIdentifier
|
||||
1. Let privateIdentifier be StringValue of PrivateIdentifier.
|
||||
2. Let privateName be NewPrivateName(privateIdentifier).
|
||||
3. Let scope be the running execution context's PrivateEnvironment.
|
||||
4. Let scopeEnvRec be scope's EnvironmentRecord.
|
||||
5. Perform ! scopeEnvRec.InitializeBinding(privateIdentifier, privateName).
|
||||
6. Return privateName.
|
||||
|
||||
MakePrivateReference ( baseValue, privateIdentifier )
|
||||
1. Let env be the running execution context's PrivateEnvironment.
|
||||
2. Let privateNameBinding be ? ResolveBinding(privateIdentifier, env).
|
||||
3. Let privateName be GetValue(privateNameBinding).
|
||||
4. Assert: privateName is a Private Name.
|
||||
5. Return a value of type Reference whose base value is baseValue, whose referenced name is privateName, whose strict reference flag is true.
|
||||
features: [class-static-methods-private, class]
|
||||
---*/
|
||||
|
||||
class C {
|
||||
static set #m(v) {
|
||||
this._v = v;
|
||||
}
|
||||
|
||||
static setWithEval() {
|
||||
eval('this.#m = "Test262"');
|
||||
}
|
||||
}
|
||||
|
||||
class D {
|
||||
static set #m(v) {
|
||||
throw new Test262Error('should never be called');
|
||||
}
|
||||
}
|
||||
|
||||
C.setWithEval();
|
||||
assert.sameValue(C._v, 'Test262');
|
||||
|
||||
assert.throws(TypeError, function() {
|
||||
C.getWithEval.call(D);
|
||||
}, 'invalid access to a static private getter');
|
Loading…
Reference in New Issue