mirror of https://github.com/tc39/test262.git
Adding tests to validate HomeObject setup on private methods and accessors (#2214)
This commit is contained in:
parent
14b6bec36d
commit
166d5ac589
|
@ -0,0 +1,50 @@
|
|||
// 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 getter contains proper HomeObject
|
||||
esid: sec-method-definitions-runtime-semantics-classelementevaluation
|
||||
info: |
|
||||
MethodDefinition : get ClassElementName () { FunctionBody }
|
||||
1. Let key be the result of evaluating ClassElementName.
|
||||
2. ReturnIfAbrupt(key).
|
||||
3. If the function code for this MethodDefinition is strict mode code, let strict be true. Otherwise let strict be false.
|
||||
4. Let scope be the running execution context's LexicalEnvironment.
|
||||
5. Let formalParameterList be an instance of the production FormalParameters:[empty] .
|
||||
6. Let closure be FunctionCreate(Method, formalParameterList, FunctionBody, scope, strict).
|
||||
7. Perform MakeMethod(closure, homeObject).
|
||||
8. Perform SetFunctionName(closure, key, "get").
|
||||
9. If key is a Private Name,
|
||||
a. If key has a [[Kind]] field,
|
||||
i. Assert: key.[[Kind]] is "accessor".
|
||||
ii. Assert: key.[[Brand]] is homeObject.
|
||||
iii. Assert: key does not have a [[Get]] field.
|
||||
iv. Set key.[[Get]] to closure.
|
||||
b. Otherwise,
|
||||
i. Set key.[[Kind]] to "accessor".
|
||||
ii. Set key.[[Brand]] to homeObject.
|
||||
iii. Set key.[[Get]] to closure.
|
||||
10. Else,
|
||||
a. Let desc be the PropertyDescriptor{[[Get]]: closure, [[Enumerable]]: enumerable, [[Configurable]]: true}.
|
||||
b. Perform ? DefinePropertyOrThrow(homeObject, key, desc).
|
||||
features: [class-methods-private, class]
|
||||
---*/
|
||||
|
||||
class A {
|
||||
method() {
|
||||
return "Test262";
|
||||
}
|
||||
}
|
||||
|
||||
class C extends A {
|
||||
get #m() {
|
||||
return super.method();
|
||||
}
|
||||
|
||||
access() {
|
||||
return this.#m;
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
assert.sameValue(c.access(), "Test262");
|
|
@ -0,0 +1,50 @@
|
|||
// 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 method contains proper HomeObject
|
||||
esid: sec-method-definitions-runtime-semantics-classelementevaluation
|
||||
info: |
|
||||
MethodDefinition : ClassElementName ( UniqueFormalParameters ) { FunctionBody }
|
||||
1. Let methodDef be DefineMethod of MethodDefinition with argument homeObject.
|
||||
2. ReturnIfAbrupt(methodDef).
|
||||
3. Perform ? DefineOrdinaryMethod(methodDef.[[Key]], homeObject, methodDef.[[Closure]], _enumerable).
|
||||
|
||||
MethodDefinition : PropertyName ( UniqueFormalParameters ) { FunctionBody }
|
||||
1. Let propKey be the result of evaluating PropertyName.
|
||||
2. ReturnIfAbrupt(propKey).
|
||||
3. Let scope be the running execution context's LexicalEnvironment.
|
||||
4. If functionPrototype is present as a parameter, then
|
||||
a. Let kind be Normal.
|
||||
b. Let prototype be functionPrototype.
|
||||
5. Else,
|
||||
a. Let kind be Method.
|
||||
b. Let prototype be the intrinsic object %FunctionPrototype%.
|
||||
6. Let closure be FunctionCreate(kind, UniqueFormalParameters, FunctionBody, scope, prototype).
|
||||
7. Perform MakeMethod(closure, object).
|
||||
8. Set closure.[[SourceText]] to the source text matched by MethodDefinition.
|
||||
9. Return the Record { [[Key]]: propKey, [[Closure]]: closure }.
|
||||
features: [class-methods-private, class]
|
||||
---*/
|
||||
|
||||
class A {
|
||||
method() {
|
||||
return "Test262";
|
||||
}
|
||||
}
|
||||
|
||||
class C extends A {
|
||||
#m() {
|
||||
return super.method();
|
||||
}
|
||||
|
||||
access(o) {
|
||||
return this.#m.call(o);
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
assert.sameValue(c.access(c), "Test262");
|
||||
|
||||
let o = {};
|
||||
assert.sameValue(c.access(o), "Test262");
|
|
@ -0,0 +1,50 @@
|
|||
// 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 setter contains proper HomeObject
|
||||
esid: sec-method-definitions-runtime-semantics-classelementevaluation
|
||||
info: |
|
||||
MethodDefinition : set ClassElementName ( PropertySetParameterList ) { FunctionBody }
|
||||
1. Let key be the result of evaluating ClassElementName.
|
||||
2. ReturnIfAbrupt(key).
|
||||
3. If the function code for this MethodDefinition is strict mode code, let strict be true. Otherwise let strict be false.
|
||||
4. Let scope be the running execution context's LexicalEnvironment.
|
||||
5. Let closure be FunctionCreate(Method, PropertySetParameterList, FunctionBody, scope, strict).
|
||||
6. Perform MakeMethod(closure, homeObject).
|
||||
7. Perform SetFunctionName(closure, key, "set").
|
||||
8. If key is a Private Name,
|
||||
a. If key has a [[Kind]] field,
|
||||
i. Assert: key.[[Kind]] is "accessor".
|
||||
ii. Assert: key.[[Brand]] is homeObject.
|
||||
iii. Assert: key does not have a [[Set]] field.
|
||||
iv. Set key.[[Set]] to closure.
|
||||
b. Otherwise,
|
||||
i. Set key.[[Kind]] to "accessor".
|
||||
ii. Set key.[[Brand]] to homeObject.
|
||||
iii. Set key.[[Set]] to closure.
|
||||
9. Else,
|
||||
a. Let desc be the PropertyDescriptor{[[Set]]: closure, [[Enumerable]]: enumerable, [[Configurable]]: true}.
|
||||
b. Perform ? DefinePropertyOrThrow(homeObject, key, desc).
|
||||
features: [class-methods-private, class]
|
||||
---*/
|
||||
|
||||
class A {
|
||||
method(v) {
|
||||
return v;
|
||||
}
|
||||
}
|
||||
|
||||
class C extends A {
|
||||
set #m(v) {
|
||||
this._v = super.method(v);
|
||||
}
|
||||
|
||||
access() {
|
||||
return this.#m = "Test262";
|
||||
}
|
||||
}
|
||||
|
||||
let c = new C();
|
||||
c.access();
|
||||
assert.sameValue(c._v, "Test262");
|
Loading…
Reference in New Issue