TypeScript/tests/baselines/reference/privateNameStaticMethodAsync.types

80 lines
3.2 KiB
Plaintext
Raw Permalink Normal View History

ES private class elements (#42458) * Added support for private identifier methods. * Added tests for private methods. * Added check to only not allow private name method signatures in anything except classes. Changes objects literal checking to not bail on first private name found in object literal. * Added private accessors tests * Transform private methods Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Rename shouldTransformPrivateFields Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Accept baseline Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Use a single WeakSet for brand-check Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Accept baseline Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Add a test for using private methods in static field initializers Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Add breaking checker test Private methods inside class expressions should not error. Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Add to instances once per-instance Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Accept baseline Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * fix: evaluate receiver and rhs expressions before throwing on readonly assignment Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Add a test for evaluating rhs before readonly assignment Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Transpile private accessors Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Accept baseline Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * fix: handle readonly/writeonly accessors Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * accept baseline Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * add a test for private setter without a getter Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * fix: getAllUnscopedEmitHelpers Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * fix: better handling of duplicate names Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Fixed wrong error message for private methods in class expressions. * change error message Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * add a test for async private methods with a higher target Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * fix: setter assignment returns rhs value Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * add a test for setter assignment return value Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * fix: handle duplicate accessors Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * add tests for duplicate accessors Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * docs: add missing parameter docs Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Fixed failing test. * baseline-accept: ordering changes Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * fix: attach weakSetName to property declaration Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * add a test for nested private methods Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * add a test with any Signed-off-by: Kubilay Kahveci <kahvecikubilay@gmail.com> * Added support for static private fields accessors and methods. * Added error message for private identifiers used with static decorators. There is no spec to go with this behavior as of yet. * Fixed emit static bug that used private names outside of classes for initialization in esnext. Fixed issue where nested privates produce incorrect brand check. * Added tests for private static fields methods and accessors. * Fixed error messages and tests after merge. * Accept new baseline. * Improved duplicate identifier checks for static private class elements. * Added error when using initializers with private static fields when useDefineForClassFields is not specified and target is esnext. * Fixed code review issues. * Removed semantically wrong emit on `useDefineForClassFields:true` with `target:esnext` * Changed emit for uninitialized private static fields. * Added runtime error in helper if a static private field is accessed before it was declared. * Fixed code review comments for private identifier static class elements. * add debug.assertNever for unknown node type (#53) * Fixed code review issues. * Fixed code review issues for private class elements. * Fixes class shadowing when checking access to a private static class element. * fix private methods/accessors in class expr inside a loop * collapse switch case * fix class name * simplify getPrivateMethodsAndAccessors * remove findPreviousAccessorInfo * lazily create weakSetName identifier * do not allocate a node if not needed in visitMehodDeclaration (#55) * Removed all the emit helpers for private identifier methods accessors and modified the existing helpers for get and set fields to do the same job. * Simplified emit for private identifier class elements. * do not clone the receiver (#57) * leave bad code in for #constructor and duplicate private names (#58) * Added check for WeakSet collision. * Added error for using a set only accessor. * update keyof tests and ?? (#62) * replace ?? with || * update keyof tests * fix emit helpers comments * produce an error if private field helpers are not up to date * add tests * fix setter-only compound assignment * fix tests * fix duplicated trailing comments (#64) * clear receiver pos and setTextRange on helper calls Co-authored-by: Kubilay Kahveci <kahvecikubilay@gmail.com>
2021-03-25 02:15:50 +01:00
=== tests/cases/conformance/classes/members/privateNames/privateNameStaticMethodAsync.ts ===
const C = class {
>C : typeof C
>class { static async #bar() { return await Promise.resolve(42); } static async foo() { const b = await this.#bar(); return b + (this.#baz().next().value || 0) + ((await this.#qux().next()).value || 0); } static *#baz() { yield 42; } static async *#qux() { yield (await Promise.resolve(42)); } async static *#bazBad() { yield 42; }} : typeof C
static async #bar() { return await Promise.resolve(42); }
>#bar : () => Promise<number>
>await Promise.resolve(42) : number
>Promise.resolve(42) : Promise<number>
>Promise.resolve : { (): Promise<void>; <T>(value: T | PromiseLike<T>): Promise<T>; }
>Promise : PromiseConstructor
>resolve : { (): Promise<void>; <T>(value: T | PromiseLike<T>): Promise<T>; }
>42 : 42
static async foo() {
>foo : () => Promise<number>
const b = await this.#bar();
>b : number
>await this.#bar() : number
>this.#bar() : Promise<number>
>this.#bar : () => Promise<number>
>this : typeof C
return b + (this.#baz().next().value || 0) + ((await this.#qux().next()).value || 0);
>b + (this.#baz().next().value || 0) + ((await this.#qux().next()).value || 0) : number
>b + (this.#baz().next().value || 0) : number
>b : number
>(this.#baz().next().value || 0) : number
>this.#baz().next().value || 0 : number
>this.#baz().next().value : number | void
>this.#baz().next() : IteratorResult<number, void>
>this.#baz().next : (...args: [] | [unknown]) => IteratorResult<number, void>
>this.#baz() : Generator<number, void, unknown>
>this.#baz : () => Generator<number, void, unknown>
>this : typeof C
>next : (...args: [] | [unknown]) => IteratorResult<number, void>
>value : number | void
>0 : 0
>((await this.#qux().next()).value || 0) : number
>(await this.#qux().next()).value || 0 : number
>(await this.#qux().next()).value : number | void
>(await this.#qux().next()) : IteratorResult<number, void>
>await this.#qux().next() : IteratorResult<number, void>
>this.#qux().next() : Promise<IteratorResult<number, void>>
>this.#qux().next : (...args: [] | [unknown]) => Promise<IteratorResult<number, void>>
>this.#qux() : AsyncGenerator<number, void, unknown>
>this.#qux : () => AsyncGenerator<number, void, unknown>
>this : typeof C
>next : (...args: [] | [unknown]) => Promise<IteratorResult<number, void>>
>value : number | void
>0 : 0
}
static *#baz() { yield 42; }
>#baz : () => Generator<number, void, unknown>
>yield 42 : any
>42 : 42
static async *#qux() {
>#qux : () => AsyncGenerator<number, void, unknown>
yield (await Promise.resolve(42));
>yield (await Promise.resolve(42)) : any
>(await Promise.resolve(42)) : number
>await Promise.resolve(42) : number
>Promise.resolve(42) : Promise<number>
>Promise.resolve : { (): Promise<void>; <T>(value: T | PromiseLike<T>): Promise<T>; }
>Promise : PromiseConstructor
>resolve : { (): Promise<void>; <T>(value: T | PromiseLike<T>): Promise<T>; }
>42 : 42
}
async static *#bazBad() { yield 42; }
>#bazBad : () => AsyncGenerator<number, void, unknown>
>yield 42 : any
>42 : 42
}