// This file was procedurally generated from the following sources: // - src/class-elements/static-private-methods.case // - src/class-elements/productions/cls-decl-after-same-line-static-method.template /*--- description: static private methods (field definitions after a static method in the same line) esid: prod-FieldDefinition features: [class-static-methods-private, class, class-fields-public] flags: [generated] includes: [propertyHelper.js] info: | ClassElement : ... static FieldDefinition ; FieldDefinition : ClassElementName Initializer_opt ClassElementName : PrivateName PrivateName : # IdentifierName ---*/ class C { static m() { return 42; } ; static #x(value) { return value / 2; } static #y(value) { return value * 2; } static x() { return this.#x(84); } static y() { return this.#y(43); } } var c = new C(); assert.sameValue(C.m(), 42); assert.sameValue(Object.hasOwnProperty.call(c, "m"), false); assert.sameValue(Object.hasOwnProperty.call(C.prototype, "m"), false); verifyProperty(C, "m", { enumerable: false, configurable: true, writable: true, }); // Test the private methods do not appear as properties before set to value assert.sameValue(Object.hasOwnProperty.call(C.prototype, "#x"), false, "test 1"); assert.sameValue(Object.hasOwnProperty.call(C, "#x"), false, "test 2"); assert.sameValue(Object.hasOwnProperty.call(c, "#x"), false, "test 3"); assert.sameValue(Object.hasOwnProperty.call(C.prototype, "#y"), false, "test 4"); assert.sameValue(Object.hasOwnProperty.call(C, "#y"), false, "test 5"); assert.sameValue(Object.hasOwnProperty.call(c, "#y"), false, "test 6"); // Test if private fields can be sucessfully accessed and set to value assert.sameValue(C.x(), 42, "test 7"); assert.sameValue(C.y(), 86, "test 8"); // Test the private fields do not appear as properties before after set to value assert.sameValue(Object.hasOwnProperty.call(C, "#x"), false, "test 9"); assert.sameValue(Object.hasOwnProperty.call(C, "#y"), false, "test 10");