// This file was procedurally generated from the following sources: // - src/class-elements/computed-symbol-names.case // - src/class-elements/productions/cls-decl-wrapped-in-sc.template /*--- description: Computed property symbol names (fields definition wrapped in semicolons) esid: prod-FieldDefinition features: [class-fields-public, Symbol, computed-property-names, class] flags: [generated] includes: [propertyHelper.js] info: | ClassElement: ... FieldDefinition ; FieldDefinition: ClassElementName Initializer_opt ClassElementName: PropertyName ---*/ var x = Symbol(); var y = Symbol(); class C { ;;;; ;;;;;;[x]; [y] = 42;;;;;;; ;;;; } var c = new C(); assert( !Object.prototype.hasOwnProperty.call(C.prototype, x), "Symbol x doesn't appear as an own property on C prototype" ); assert( !Object.prototype.hasOwnProperty.call(C, x), "Symbol x doesn't appear as an own property on C constructor" ); verifyProperty(c, x, { value: undefined, enumerable: true, writable: true, configurable: true }); assert( !Object.prototype.hasOwnProperty.call(C.prototype, y), "Symbol y doesn't appear as an own property on C prototype" ); assert( !Object.prototype.hasOwnProperty.call(C, y), "Symbol y doesn't appear as an own property on C constructor" ); verifyProperty(c, y, { value: 42, enumerable: true, writable: true, configurable: true }); assert( !Object.prototype.hasOwnProperty.call(C.prototype, "x"), "x doesn't appear as an own property on C prototype" ); assert( !Object.prototype.hasOwnProperty.call(C, "x"), "x doesn't appear as an own property on C constructor" ); assert( !Object.prototype.hasOwnProperty.call(c, "x"), "x doesn't appear as an own property on C instance" ); assert( !Object.prototype.hasOwnProperty.call(C.prototype, "y"), "y doesn't appear as an own property on C prototype" ); assert( !Object.prototype.hasOwnProperty.call(C, "y"), "y doesn't appear as an own property on C constructor" ); assert( !Object.prototype.hasOwnProperty.call(c, "y"), "y doesn't appear as an own property on C instance" ); reportCompare(0, 0);