From 7d24cf605f9cabe5ad9df3106b1ab8820f268e9e Mon Sep 17 00:00:00 2001 From: Victor Domene Gimeno <49651769+madmaxdios@users.noreply.github.com> Date: Sun, 15 Dec 2024 10:04:45 +0100 Subject: [PATCH] Update Configuration.md for testSequencer example in ts --- docs/Configuration.md | 31 ++++++++++++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) diff --git a/docs/Configuration.md b/docs/Configuration.md index 1ca9a15e1341..76ec1af78e2a 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -2195,7 +2195,7 @@ Both `sort` and `shard` may optionally return a `Promise`. For example, you may sort test paths alphabetically: -```js title="custom-sequencer.js" +```js tab const Sequencer = require('@jest/test-sequencer').default; class CustomSequencer extends Sequencer { @@ -2228,6 +2228,35 @@ class CustomSequencer extends Sequencer { module.exports = CustomSequencer; ``` +```ts tab +import TestSequencer, { ShardOptions } from '@jest/test-sequencer' +import { Test } from '@jest/test-result' + +export default class CustomSequencer extends TestSequencer { + /** + * Select tests for shard requested via --shard=shardIndex/shardCount + * Sharding is applied before sorting + */ + shard (tests: Test[], { shardIndex, shardCount }: ShardOptions): any[] { + const shardSize = Math.ceil(tests.length / shardCount) + const shardStart = shardSize * (shardIndex - 1) + const shardEnd = shardSize * shardIndex + + return [...tests].sort((a, b) => (a.path > b.path ? 1 : -1)).slice(shardStart, shardEnd) + } + + /** + * Sort test to determine order of execution + * Sorting is applied after sharding + */ + sort (tests: Test[]): any[] { + const copyTests = [...tests] + return copyTests.sort((testA, testB) => (testA.path > testB.path ? 1 : -1)) + } +} + +``` + Add `custom-sequencer` to your Jest configuration: ```js tab