mirror of https://github.com/tc39/test262.git
Add test for proposal-class-fields#92
This commit is contained in:
parent
845407e0b6
commit
dba8d7cdc7
|
@ -0,0 +1,43 @@
|
||||||
|
// Copyright (C) 2018 Kevin Gibbons. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
/*---
|
||||||
|
esid: sec-super-keyword-runtime-semantics-evaluation
|
||||||
|
description: >
|
||||||
|
`this` is bound in the constructor of derived classes immediately before running initializers
|
||||||
|
info: |
|
||||||
|
[...]
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
[...]
|
||||||
|
10. Perform ? thisER.BindThisValue(result).
|
||||||
|
11. Perform ? InitializeInstanceFields(result, F).
|
||||||
|
[...]
|
||||||
|
features: [class-fields-public]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
var probeCtorThis;
|
||||||
|
var thisDuringField;
|
||||||
|
var thisFromProbe;
|
||||||
|
var thisDuringCtor;
|
||||||
|
|
||||||
|
class Base {
|
||||||
|
constructor() {
|
||||||
|
assert.throws(ReferenceError, probeCtorThis);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var C = class extends Base {
|
||||||
|
field = (thisDuringField = this, thisFromProbe = probeCtorThis());
|
||||||
|
constructor() {
|
||||||
|
probeCtorThis = () => this;
|
||||||
|
assert.throws(ReferenceError, probeCtorThis);
|
||||||
|
super();
|
||||||
|
thisDuringCtor = this;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var instance = new C();
|
||||||
|
|
||||||
|
assert.sameValue(thisDuringField, instance);
|
||||||
|
assert.sameValue(thisFromProbe, instance);
|
||||||
|
assert.sameValue(thisDuringCtor, instance);
|
Loading…
Reference in New Issue