mirror of
https://github.com/tc39/test262.git
synced 2025-07-04 20:54:47 +02:00
* Accessing `ta[0]` throws a TypeError. * Fix array indices starting at 0 and property references * Fix classfields templates for properly checking static propnames. * Generate tests * `assert.equal` is not defined * Add missing includes * Generate tests * typo s/Avalue/42/ * fix whitespace * Add missing var for strict mode * Expand generated class fields tests for forbidden computed property name values Ref https://github.com/tc39/test262/pull/1339#issuecomment-342830243 * derived classes have access to private names in base classes, if private names are in scope
34 lines
935 B
JavaScript
34 lines
935 B
JavaScript
// This file was procedurally generated from the following sources:
|
|
// - src/class-fields/propname-constructor.case
|
|
// - src/class-fields/propname-error/cls-decl-variable-name.template
|
|
/*---
|
|
description: class fields forbid PropName 'constructor' (no early error -- PropName of ComputedPropertyName not forbidden value)
|
|
esid: sec-class-definitions-static-semantics-early-errors
|
|
features: [class-fields]
|
|
flags: [generated]
|
|
info: |
|
|
Static Semantics: PropName
|
|
...
|
|
ComputedPropertyName : [ AssignmentExpression ]
|
|
Return empty.
|
|
|
|
|
|
// This test file tests the following early error:
|
|
Static Semantics: Early Errors
|
|
|
|
ClassElement : FieldDefinition;
|
|
It is a Syntax Error if PropName of FieldDefinition is "constructor".
|
|
|
|
---*/
|
|
|
|
|
|
var constructor = 'foo';
|
|
class C {
|
|
[constructor];
|
|
}
|
|
|
|
var c = new C();
|
|
|
|
assert.sameValue(c.hasOwnProperty("foo"), true);
|
|
assert.sameValue(C.hasOwnProperty("foo"), false);
|