Skip to content

Commit

Permalink
Add doc strings
Browse files Browse the repository at this point in the history
Basically conclusions from a discussion in #12403
  • Loading branch information
fatso83 committed Feb 16, 2022
1 parent 47062c7 commit 924e2c1
Showing 1 changed file with 11 additions and 0 deletions.
11 changes: 11 additions & 0 deletions packages/jest-transform/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,12 @@ export interface AsyncTransformer<OptionType = unknown> {
) => Promise<TransformedSource>;
}

/**
* We have both sync (process) and async (processAsync) code transformation, which both can be provided.
* `require` will always use process, and import will use `processAsync` if it exists, otherwise fall back to process.
* Meaning, if you use import exclusively you do not need process, but in most cases supplying both makes sense:
* Jest transpiles on demand rather than ahead of time, so the sync one needs to exist.
*/
export type Transformer<OptionType = unknown> =
| SyncTransformer<OptionType>
| AsyncTransformer<OptionType>;
Expand All @@ -144,4 +150,9 @@ type TransformerCreator<OptionType = unknown> = (
options?: OptionType,
) => Transformer<OptionType>;

/**
* Instead of having your custom transformer implement the Transformer interface
* directly, you can choose to export a factory function to dynamically create
* transformers. This is to allow having a transformer config in your jest config.
*/
export type TransformerFactory = {createTransformer: TransformerCreator};

0 comments on commit 924e2c1

Please sign in to comment.