Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allowed describe and it/test to take in functions again #12484

Merged
merged 18 commits into from
Feb 24, 2022
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 7 additions & 6 deletions packages/jest-circus/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,24 +7,24 @@

import type {Circus, Global} from '@jest/types';
import {bind as bindEach} from 'jest-each';
import {ErrorWithStack, isPromise} from 'jest-util';
import {ErrorWithStack, convertDescriptorToString, isPromise} from 'jest-util';
import {dispatchSync} from './state';

export {setState, getState, resetState} from './state';
export {default as run} from './run';

type THook = (fn: Circus.HookFn, timeout?: number) => void;
type DescribeFn = (
blockName: Circus.BlockName,
blockName: Circus.BlockNameLike,
blockFn: Circus.BlockFn,
) => void;

const describe = (() => {
const describe = (blockName: Circus.BlockName, blockFn: Circus.BlockFn) =>
const describe = (blockName: Circus.BlockNameLike, blockFn: Circus.BlockFn) =>
_dispatchDescribe(blockFn, blockName, describe);
const only = (blockName: Circus.BlockName, blockFn: Circus.BlockFn) =>
const only = (blockName: Circus.BlockNameLike, blockFn: Circus.BlockFn) =>
_dispatchDescribe(blockFn, blockName, only, 'only');
const skip = (blockName: Circus.BlockName, blockFn: Circus.BlockFn) =>
const skip = (blockName: Circus.BlockNameLike, blockFn: Circus.BlockFn) =>
_dispatchDescribe(blockFn, blockName, skip, 'skip');

describe.each = bindEach(describe, false);
Expand All @@ -40,7 +40,7 @@ const describe = (() => {

const _dispatchDescribe = (
blockFn: Circus.BlockFn,
blockName: Circus.BlockName,
blockName: Circus.BlockNameLike,
describeFn: DescribeFn,
mode?: Circus.BlockMode,
) => {
Expand All @@ -54,6 +54,7 @@ const _dispatchDescribe = (
asyncError.message = `Invalid second argument, ${blockFn}. It must be a callback function.`;
throw asyncError;
}
blockName = convertDescriptorToString(blockName);
JoshuaKGoldberg marked this conversation as resolved.
Show resolved Hide resolved
dispatchSync({
asyncError,
blockName,
Expand Down
5 changes: 3 additions & 2 deletions packages/jest-each/src/bind.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
*/

import type {Global} from '@jest/types';
import {ErrorWithStack} from 'jest-util';
import {ErrorWithStack, convertDescriptorToString} from 'jest-util';
import convertArrayTable from './table/array';
import convertTemplateTable from './table/template';
import {
Expand Down Expand Up @@ -37,10 +37,11 @@ export default function bind<EachCallback extends Global.TestCallback>(
...taggedTemplateData: Global.TemplateData
) =>
function eachBind(
title: string,
title: Global.BlockNameLike,
test: Global.EachTestFn<EachCallback>,
timeout?: number,
): void {
title = convertDescriptorToString(title);
try {
const tests = isArrayTable(taggedTemplateData)
? buildArrayTests(title, table)
Expand Down
1 change: 1 addition & 0 deletions packages/jest-types/src/Circus.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ type Process = NodeJS.Process;
export type DoneFn = Global.DoneFn;
export type BlockFn = Global.BlockFn;
export type BlockName = Global.BlockName;
export type BlockNameLike = Global.BlockNameLike;
export type BlockMode = void | 'skip' | 'only' | 'todo';
export type TestMode = BlockMode;
export type TestName = Global.TestName;
Expand Down
24 changes: 14 additions & 10 deletions packages/jest-types/src/Global.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,12 @@ export type GeneratorReturningTestFn = (
this: TestContext | undefined,
) => TestReturnValueGenerator;

export interface FunctionLike {
readonly name: string;
}
JoshuaKGoldberg marked this conversation as resolved.
Show resolved Hide resolved
// eslint-disable-next-line @typescript-eslint/ban-types
export type NameLike = number | Function | FunctionLike;

export type TestName = string;
export type TestFn =
| PromiseReturningTestFn
Expand All @@ -35,6 +41,8 @@ export type TestFn =
export type ConcurrentTestFn = () => TestReturnValuePromise;
export type BlockFn = () => void;
export type BlockName = string;
export type BlockNameLike = BlockName | NameLike;

export type HookFn = TestFn;

export type Col = unknown;
Expand All @@ -51,15 +59,11 @@ export type EachTestFn<EachCallback extends TestCallback> = (
...args: ReadonlyArray<any>
) => ReturnType<EachCallback>;

type Each<EachCallback extends TestCallback> =
type Each<EachCallback extends TestCallback, Name> =
| ((
table: EachTable,
...taggedTemplateData: TemplateData
) => (
name: BlockName | TestName,
test: EachTestFn<EachCallback>,
timeout?: number,
) => void)
) => (name: Name, test: EachTestFn<EachCallback>, timeout?: number) => void)
| (() => () => void);

export interface HookBase {
Expand All @@ -68,7 +72,7 @@ export interface HookBase {

export interface ItBase {
(testName: TestName, fn: TestFn, timeout?: number): void;
each: Each<TestFn>;
each: Each<TestFn, TestName>;
}

export interface It extends ItBase {
Expand All @@ -79,7 +83,7 @@ export interface It extends ItBase {

export interface ItConcurrentBase {
(testName: TestName, testFn: ConcurrentTestFn, timeout?: number): void;
each: Each<ConcurrentTestFn>;
each: Each<ConcurrentTestFn, TestName>;
}

export interface ItConcurrentExtended extends ItConcurrentBase {
Expand All @@ -92,8 +96,8 @@ export interface ItConcurrent extends It {
}

export interface DescribeBase {
(blockName: BlockName, blockFn: BlockFn): void;
each: Each<BlockFn>;
(blockName: BlockNameLike, blockFn: BlockFn): void;
each: Each<BlockFn, BlockNameLike | TestName>;
}

export interface Describe extends DescribeBase {
Expand Down
10 changes: 5 additions & 5 deletions packages/jest-util/src/convertDescriptorToString.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,18 +5,18 @@
* LICENSE file in the root directory of this source tree.
*/

/* eslint-disable local/ban-types-eventually */
import type {Global} from '@jest/types';

// See: https://github.com/facebook/jest/pull/5154
export default function convertDescriptorToString<
T extends number | string | Function | undefined,
>(descriptor: T): T | string {
export default function convertDescriptorToString(
descriptor: Global.BlockNameLike | undefined,
): string {
if (
typeof descriptor === 'string' ||
typeof descriptor === 'number' ||
descriptor === undefined
) {
return descriptor;
return `${descriptor}`;
}

if (typeof descriptor !== 'function') {
Expand Down