aboutsummaryrefslogtreecommitdiff
path: root/node_modules/jest-each
diff options
context:
space:
mode:
authorJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
committerJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
commit080c5819d87b933816d724a83f3bf4f1686770a7 (patch)
tree4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/jest-each
parent5ac7049a9d30733165cc212dee308163c2a14644 (diff)
parentd003b82235a9329f912522a2f70aa950dfce4998 (diff)
downloadLYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz
LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/jest-each')
-rw-r--r--node_modules/jest-each/LICENSE21
-rw-r--r--node_modules/jest-each/README.md548
-rw-r--r--node_modules/jest-each/build/bind.d.ts15
-rw-r--r--node_modules/jest-each/build/bind.js79
-rw-r--r--node_modules/jest-each/build/index.d.ts79
-rw-r--r--node_modules/jest-each/build/index.js97
-rw-r--r--node_modules/jest-each/build/table/array.d.ts10
-rw-r--r--node_modules/jest-each/build/table/array.js151
-rw-r--r--node_modules/jest-each/build/table/interpolation.d.ts17
-rw-r--r--node_modules/jest-each/build/table/interpolation.js69
-rw-r--r--node_modules/jest-each/build/table/template.d.ts11
-rw-r--r--node_modules/jest-each/build/table/template.js45
-rw-r--r--node_modules/jest-each/build/validation.d.ts11
-rw-r--r--node_modules/jest-each/build/validation.js133
-rw-r--r--node_modules/jest-each/package.json41
15 files changed, 1327 insertions, 0 deletions
diff --git a/node_modules/jest-each/LICENSE b/node_modules/jest-each/LICENSE
new file mode 100644
index 0000000..b96dcb0
--- /dev/null
+++ b/node_modules/jest-each/LICENSE
@@ -0,0 +1,21 @@
+MIT License
+
+Copyright (c) Facebook, Inc. and its affiliates.
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
diff --git a/node_modules/jest-each/README.md b/node_modules/jest-each/README.md
new file mode 100644
index 0000000..da3b2ad
--- /dev/null
+++ b/node_modules/jest-each/README.md
@@ -0,0 +1,548 @@
+<div align="center">
+ <h1>jest-each</h1>
+ Jest Parameterised Testing
+</div>
+
+<hr />
+
+[![version](https://img.shields.io/npm/v/jest-each.svg?style=flat-square)](https://www.npmjs.com/package/jest-each) [![downloads](https://img.shields.io/npm/dm/jest-each.svg?style=flat-square)](http://npm-stat.com/charts.html?package=jest-each&from=2017-03-21) [![MIT License](https://img.shields.io/npm/l/jest-each.svg?style=flat-square)](https://github.com/facebook/jest/blob/main/LICENSE)
+
+A parameterised testing library for [Jest](https://jestjs.io/) inspired by [mocha-each](https://github.com/ryym/mocha-each).
+
+jest-each allows you to provide multiple arguments to your `test`/`describe` which results in the test/suite being run once per row of parameters.
+
+## Features
+
+- `.test` to runs multiple tests with parameterised data
+ - Also under the alias: `.it`
+- `.test.only` to only run the parameterised tests
+ - Also under the aliases: `.it.only` or `.fit`
+- `.test.skip` to skip the parameterised tests
+ - Also under the aliases: `.it.skip` or `.xit` or `.xtest`
+- `.test.concurrent`
+ - Also under the alias: `.it.concurrent`
+- `.test.concurrent.only`
+ - Also under the alias: `.it.concurrent.only`
+- `.test.concurrent.skip`
+ - Also under the alias: `.it.concurrent.skip`
+- `.describe` to runs test suites with parameterised data
+- `.describe.only` to only run the parameterised suite of tests
+ - Also under the aliases: `.fdescribe`
+- `.describe.skip` to skip the parameterised suite of tests
+ - Also under the aliases: `.xdescribe`
+- Asynchronous tests with `done`
+- Unique test titles with [`printf` formatting](https://nodejs.org/api/util.html#util_util_format_format_args):
+ - `%p` - [pretty-format](https://www.npmjs.com/package/pretty-format).
+ - `%s`- String.
+ - `%d`- Number.
+ - `%i` - Integer.
+ - `%f` - Floating point value.
+ - `%j` - JSON.
+ - `%o` - Object.
+ - `%#` - Index of the test case.
+ - `%%` - single percent sign ('%'). This does not consume an argument.
+- Unique test titles by injecting properties of test case object
+- 🖖 Spock like data tables with [Tagged Template Literals](#tagged-template-literal-of-rows)
+
+---
+
+- [Demo](#demo)
+- [Installation](#installation)
+- [Importing](#importing)
+- APIs
+ - [Array of Rows](#array-of-rows)
+ - [Usage](#usage)
+ - [Tagged Template Literal of rows](#tagged-template-literal-of-rows)
+ - [Usage](#usage-1)
+
+## Demo
+
+#### Tests without jest-each
+
+![Current jest tests](assets/default-demo.gif)
+
+#### Tests can be re-written with jest-each to:
+
+**`.test`**
+
+![Current jest tests](assets/test-demo.gif)
+
+**`.test` with Tagged Template Literals**
+
+![Current jest tests](assets/tagged-template-literal.gif)
+
+**`.describe`**
+
+![Current jest tests](assets/describe-demo.gif)
+
+## Installation
+
+`npm i --save-dev jest-each`
+
+`yarn add -D jest-each`
+
+## Importing
+
+jest-each is a default export so it can be imported with whatever name you like.
+
+```js
+// es6
+import each from 'jest-each';
+```
+
+```js
+// es5
+const each = require('jest-each').default;
+```
+
+## Array of rows
+
+### API
+
+#### `each([parameters]).test(name, testFn)`
+
+##### `each`:
+
+- parameters: `Array` of Arrays with the arguments that are passed into the `testFn` for each row
+ - _Note_ If you pass in a 1D array of primitives, internally it will be mapped to a table i.e. `[1, 2, 3] -> [[1], [2], [3]]`
+
+##### `.test`:
+
+- name: `String` the title of the `test`.
+ - Generate unique test titles by positionally injecting parameters with [`printf` formatting](https://nodejs.org/api/util.html#util_util_format_format_args):
+ - `%p` - [pretty-format](https://www.npmjs.com/package/pretty-format).
+ - `%s`- String.
+ - `%d`- Number.
+ - `%i` - Integer.
+ - `%f` - Floating point value.
+ - `%j` - JSON.
+ - `%o` - Object.
+ - `%#` - Index of the test case.
+ - `%%` - single percent sign ('%'). This does not consume an argument.
+ - Or generate unique test titles by injecting properties of test case object with `$variable`
+ - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value`
+ - You can use `$#` to inject the index of the test case
+ - You cannot use `$variable` with the `printf` formatting except for `%%`
+- testFn: `Function` the test logic, this is the function that will receive the parameters of each row as function arguments
+
+#### `each([parameters]).describe(name, suiteFn)`
+
+##### `each`:
+
+- parameters: `Array` of Arrays with the arguments that are passed into the `suiteFn` for each row
+ - _Note_ If you pass in a 1D array of primitives, internally it will be mapped to a table i.e. `[1, 2, 3] -> [[1], [2], [3]]`
+
+##### `.describe`:
+
+- name: `String` the title of the `describe`
+ - Generate unique test titles by positionally injecting parameters with [`printf` formatting](https://nodejs.org/api/util.html#util_util_format_format_args):
+ - `%p` - [pretty-format](https://www.npmjs.com/package/pretty-format).
+ - `%s`- String.
+ - `%d`- Number.
+ - `%i` - Integer.
+ - `%f` - Floating point value.
+ - `%j` - JSON.
+ - `%o` - Object.
+ - `%#` - Index of the test case.
+ - `%%` - single percent sign ('%'). This does not consume an argument.
+ - Or generate unique test titles by injecting properties of test case object with `$variable`
+ - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value`
+ - You can use `$#` to inject the index of the test case
+ - You cannot use `$variable` with the `printf` formatting except for `%%`
+- suiteFn: `Function` the suite of `test`/`it`s to be ran, this is the function that will receive the parameters in each row as function arguments
+
+### Usage
+
+#### `.test(name, fn)`
+
+Alias: `.it(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).test('returns the result of adding %d to %d', (a, b, expected) => {
+ expect(a + b).toBe(expected);
+});
+```
+
+```js
+each([
+ {a: 1, b: 1, expected: 2},
+ {a: 1, b: 2, expected: 3},
+ {a: 2, b: 1, expected: 3},
+]).test('returns the result of adding $a to $b', ({a, b, expected}) => {
+ expect(a + b).toBe(expected);
+});
+```
+
+#### `.test.only(name, fn)`
+
+Aliases: `.it.only(name, fn)` or `.fit(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).test.only('returns the result of adding %d to %d', (a, b, expected) => {
+ expect(a + b).toBe(expected);
+});
+```
+
+#### `.test.skip(name, fn)`
+
+Aliases: `.it.skip(name, fn)` or `.xit(name, fn)` or `.xtest(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).test.skip('returns the result of adding %d to %d', (a, b, expected) => {
+ expect(a + b).toBe(expected);
+});
+```
+
+#### `.test.concurrent(name, fn)`
+
+Aliases: `.it.concurrent(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).test.concurrent(
+ 'returns the result of adding %d to %d',
+ (a, b, expected) => {
+ expect(a + b).toBe(expected);
+ },
+);
+```
+
+#### `.test.concurrent.only(name, fn)`
+
+Aliases: `.it.concurrent.only(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).test.concurrent.only(
+ 'returns the result of adding %d to %d',
+ (a, b, expected) => {
+ expect(a + b).toBe(expected);
+ },
+);
+```
+
+#### `.test.concurrent.skip(name, fn)`
+
+Aliases: `.it.concurrent.skip(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).test.concurrent.skip(
+ 'returns the result of adding %d to %d',
+ (a, b, expected) => {
+ expect(a + b).toBe(expected);
+ },
+);
+```
+
+#### Asynchronous `.test(name, fn(done))`
+
+Alias: `.it(name, fn(done))`
+
+```js
+each([['hello'], ['mr'], ['spy']]).test(
+ 'gives 007 secret message: %s',
+ (str, done) => {
+ const asynchronousSpy = message => {
+ expect(message).toBe(str);
+ done();
+ };
+ callSomeAsynchronousFunction(asynchronousSpy)(str);
+ },
+);
+```
+
+#### `.describe(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).describe('.add(%d, %d)', (a, b, expected) => {
+ test(`returns ${expected}`, () => {
+ expect(a + b).toBe(expected);
+ });
+
+ test('does not mutate first arg', () => {
+ a + b;
+ expect(a).toBe(a);
+ });
+
+ test('does not mutate second arg', () => {
+ a + b;
+ expect(b).toBe(b);
+ });
+});
+```
+
+```js
+each([
+ {a: 1, b: 1, expected: 2},
+ {a: 1, b: 2, expected: 3},
+ {a: 2, b: 1, expected: 3},
+]).describe('.add($a, $b)', ({a, b, expected}) => {
+ test(`returns ${expected}`, () => {
+ expect(a + b).toBe(expected);
+ });
+
+ test('does not mutate first arg', () => {
+ a + b;
+ expect(a).toBe(a);
+ });
+
+ test('does not mutate second arg', () => {
+ a + b;
+ expect(b).toBe(b);
+ });
+});
+```
+
+#### `.describe.only(name, fn)`
+
+Aliases: `.fdescribe(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).describe.only('.add(%d, %d)', (a, b, expected) => {
+ test(`returns ${expected}`, () => {
+ expect(a + b).toBe(expected);
+ });
+});
+```
+
+#### `.describe.skip(name, fn)`
+
+Aliases: `.xdescribe(name, fn)`
+
+```js
+each([
+ [1, 1, 2],
+ [1, 2, 3],
+ [2, 1, 3],
+]).describe.skip('.add(%d, %d)', (a, b, expected) => {
+ test(`returns ${expected}`, () => {
+ expect(a + b).toBe(expected);
+ });
+});
+```
+
+---
+
+## Tagged Template Literal of rows
+
+### API
+
+#### `each[tagged template].test(name, suiteFn)`
+
+```js
+each`
+ a | b | expected
+ ${1} | ${1} | ${2}
+ ${1} | ${2} | ${3}
+ ${2} | ${1} | ${3}
+`.test('returns $expected when adding $a to $b', ({a, b, expected}) => {
+ expect(a + b).toBe(expected);
+});
+```
+
+##### `each` takes a tagged template string with:
+
+- First row of variable name column headings separated with `|`
+- One or more subsequent rows of data supplied as template literal expressions using `${value}` syntax.
+
+##### `.test`:
+
+- name: `String` the title of the `test`, use `$variable` in the name string to inject test values into the test title from the tagged template expressions
+ - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value`
+ - You can use `$#` to inject the index of the table row.
+- testFn: `Function` the test logic, this is the function that will receive the parameters of each row as function arguments
+
+#### `each[tagged template].describe(name, suiteFn)`
+
+```js
+each`
+ a | b | expected
+ ${1} | ${1} | ${2}
+ ${1} | ${2} | ${3}
+ ${2} | ${1} | ${3}
+`.describe('$a + $b', ({a, b, expected}) => {
+ test(`returns ${expected}`, () => {
+ expect(a + b).toBe(expected);
+ });
+
+ test('does not mutate first arg', () => {
+ a + b;
+ expect(a).toBe(a);
+ });
+
+ test('does not mutate second arg', () => {
+ a + b;
+ expect(b).toBe(b);
+ });
+});
+```
+
+##### `each` takes a tagged template string with:
+
+- First row of variable name column headings separated with `|`
+- One or more subsequent rows of data supplied as template literal expressions using `${value}` syntax.
+
+##### `.describe`:
+
+- name: `String` the title of the `test`, use `$variable` in the name string to inject test values into the test title from the tagged template expressions
+ - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value`
+- suiteFn: `Function` the suite of `test`/`it`s to be ran, this is the function that will receive the parameters in each row as function arguments
+
+### Usage
+
+#### `.test(name, fn)`
+
+Alias: `.it(name, fn)`
+
+```js
+each`
+ a | b | expected
+ ${1} | ${1} | ${2}
+ ${1} | ${2} | ${3}
+ ${2} | ${1} | ${3}
+`.test('returns $expected when adding $a to $b', ({a, b, expected}) => {
+ expect(a + b).toBe(expected);
+});
+```
+
+#### `.test.only(name, fn)`
+
+Aliases: `.it.only(name, fn)` or `.fit(name, fn)`
+
+```js
+each`
+ a | b | expected
+ ${1} | ${1} | ${2}
+ ${1} | ${2} | ${3}
+ ${2} | ${1} | ${3}
+`.test.only('returns $expected when adding $a to $b', ({a, b, expected}) => {
+ expect(a + b).toBe(expected);
+});
+```
+
+#### `.test.skip(name, fn)`
+
+Aliases: `.it.skip(name, fn)` or `.xit(name, fn)` or `.xtest(name, fn)`
+
+```js
+each`
+ a | b | expected
+ ${1} | ${1} | ${2}
+ ${1} | ${2} | ${3}
+ ${2} | ${1} | ${3}
+`.test.skip('returns $expected when adding $a to $b', ({a, b, expected}) => {
+ expect(a + b).toBe(expected);
+});
+```
+
+#### Asynchronous `.test(name, fn(done))`
+
+Alias: `.it(name, fn(done))`
+
+```js
+each`
+ str
+ ${'hello'}
+ ${'mr'}
+ ${'spy'}
+`.test('gives 007 secret message: $str', ({str}, done) => {
+ const asynchronousSpy = message => {
+ expect(message).toBe(str);
+ done();
+ };
+ callSomeAsynchronousFunction(asynchronousSpy)(str);
+});
+```
+
+#### `.describe(name, fn)`
+
+```js
+each`
+ a | b | expected
+ ${1} | ${1} | ${2}
+ ${1} | ${2} | ${3}
+ ${2} | ${1} | ${3}
+`.describe('$a + $b', ({a, b, expected}) => {
+ test(`returns ${expected}`, () => {
+ expect(a + b).toBe(expected);
+ });
+
+ test('does not mutate first arg', () => {
+ a + b;
+ expect(a).toBe(a);
+ });
+
+ test('does not mutate second arg', () => {
+ a + b;
+ expect(b).toBe(b);
+ });
+});
+```
+
+#### `.describe.only(name, fn)`
+
+Aliases: `.fdescribe(name, fn)`
+
+```js
+each`
+ a | b | expected
+ ${1} | ${1} | ${2}
+ ${1} | ${2} | ${3}
+ ${2} | ${1} | ${3}
+`.describe.only('$a + $b', ({a, b, expected}) => {
+ test(`returns ${expected}`, () => {
+ expect(a + b).toBe(expected);
+ });
+});
+```
+
+#### `.describe.skip(name, fn)`
+
+Aliases: `.xdescribe(name, fn)`
+
+```js
+each`
+ a | b | expected
+ ${1} | ${1} | ${2}
+ ${1} | ${2} | ${3}
+ ${2} | ${1} | ${3}
+`.describe.skip('$a + $b', ({a, b, expected}) => {
+ test(`returns ${expected}`, () => {
+ expect(a + b).toBe(expected);
+ });
+});
+```
+
+## License
+
+MIT
diff --git a/node_modules/jest-each/build/bind.d.ts b/node_modules/jest-each/build/bind.d.ts
new file mode 100644
index 0000000..1bce7a3
--- /dev/null
+++ b/node_modules/jest-each/build/bind.d.ts
@@ -0,0 +1,15 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+import type { Global } from '@jest/types';
+export declare type EachTests = ReadonlyArray<{
+ title: string;
+ arguments: ReadonlyArray<unknown>;
+}>;
+declare type GlobalCallback = (testName: string, fn: Global.ConcurrentTestFn, timeout?: number) => void;
+export default function bind<EachCallback extends Global.TestCallback>(cb: GlobalCallback, supportsDone?: boolean): (table: Global.EachTable, ...taggedTemplateData: Global.TemplateData) => (title: string, test: Global.EachTestFn<EachCallback>, timeout?: number | undefined) => void;
+export {};
diff --git a/node_modules/jest-each/build/bind.js b/node_modules/jest-each/build/bind.js
new file mode 100644
index 0000000..5514ed4
--- /dev/null
+++ b/node_modules/jest-each/build/bind.js
@@ -0,0 +1,79 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.default = bind;
+
+function _jestUtil() {
+ const data = require('jest-util');
+
+ _jestUtil = function () {
+ return data;
+ };
+
+ return data;
+}
+
+var _array = _interopRequireDefault(require('./table/array'));
+
+var _template = _interopRequireDefault(require('./table/template'));
+
+var _validation = require('./validation');
+
+function _interopRequireDefault(obj) {
+ return obj && obj.__esModule ? obj : {default: obj};
+}
+
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+function bind(cb, supportsDone = true) {
+ return (table, ...taggedTemplateData) =>
+ function eachBind(title, test, timeout) {
+ try {
+ const tests = isArrayTable(taggedTemplateData)
+ ? buildArrayTests(title, table)
+ : buildTemplateTests(title, table, taggedTemplateData);
+ return tests.forEach(row =>
+ cb(
+ row.title,
+ applyArguments(supportsDone, row.arguments, test),
+ timeout
+ )
+ );
+ } catch (e) {
+ const error = new (_jestUtil().ErrorWithStack)(e.message, eachBind);
+ return cb(title, () => {
+ throw error;
+ });
+ }
+ };
+}
+
+const isArrayTable = data => data.length === 0;
+
+const buildArrayTests = (title, table) => {
+ (0, _validation.validateArrayTable)(table);
+ return (0, _array.default)(title, table);
+};
+
+const buildTemplateTests = (title, table, taggedTemplateData) => {
+ const headings = getHeadingKeys(table[0]);
+ (0, _validation.validateTemplateTableArguments)(headings, taggedTemplateData);
+ return (0, _template.default)(title, headings, taggedTemplateData);
+};
+
+const getHeadingKeys = headings =>
+ (0, _validation.extractValidTemplateHeadings)(headings)
+ .replace(/\s/g, '')
+ .split('|');
+
+const applyArguments = (supportsDone, params, test) =>
+ supportsDone && params.length < test.length
+ ? done => test(...params, done)
+ : () => test(...params);
diff --git a/node_modules/jest-each/build/index.d.ts b/node_modules/jest-each/build/index.d.ts
new file mode 100644
index 0000000..31fa8d2
--- /dev/null
+++ b/node_modules/jest-each/build/index.d.ts
@@ -0,0 +1,79 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+import type { Global } from '@jest/types';
+import bind from './bind';
+declare type Global = Global.Global;
+declare const install: (g: Global, table: Global.EachTable, ...data: Global.TemplateData) => {
+ describe: {
+ (title: string, suite: Global.EachTestFn<Global.BlockFn>, timeout?: number | undefined): void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ };
+ fdescribe: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ fit: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ it: {
+ (title: string, test: Global.EachTestFn<Global.TestFn>, timeout?: number | undefined): void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ concurrent: {
+ (title: string, test: Global.EachTestFn<Global.TestFn>, timeout?: number | undefined): void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ };
+ };
+ test: {
+ (title: string, test: Global.EachTestFn<Global.TestFn>, timeout?: number | undefined): void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ concurrent: {
+ (title: string, test: Global.EachTestFn<Global.TestFn>, timeout?: number | undefined): void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ };
+ };
+ xdescribe: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ xit: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ xtest: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+};
+declare const each: {
+ (table: Global.EachTable, ...data: Global.TemplateData): ReturnType<typeof install>;
+ withGlobal(g: Global): (table: Global.EachTable, ...data: Global.TemplateData) => {
+ describe: {
+ (title: string, suite: Global.EachTestFn<Global.BlockFn>, timeout?: number | undefined): void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ };
+ fdescribe: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ fit: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ it: {
+ (title: string, test: Global.EachTestFn<Global.TestFn>, timeout?: number | undefined): void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ concurrent: {
+ (title: string, test: Global.EachTestFn<Global.TestFn>, timeout?: number | undefined): void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ };
+ };
+ test: {
+ (title: string, test: Global.EachTestFn<Global.TestFn>, timeout?: number | undefined): void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ concurrent: {
+ (title: string, test: Global.EachTestFn<Global.TestFn>, timeout?: number | undefined): void;
+ only: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ skip: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ };
+ };
+ xdescribe: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ xit: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ xtest: (title: string, test: Global.EachTestFn<Global.TestCallback>, timeout?: number | undefined) => void;
+ };
+};
+export { bind };
+export default each;
diff --git a/node_modules/jest-each/build/index.js b/node_modules/jest-each/build/index.js
new file mode 100644
index 0000000..6d7809d
--- /dev/null
+++ b/node_modules/jest-each/build/index.js
@@ -0,0 +1,97 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+Object.defineProperty(exports, 'bind', {
+ enumerable: true,
+ get: function () {
+ return _bind.default;
+ }
+});
+exports.default = void 0;
+
+var _bind = _interopRequireDefault(require('./bind'));
+
+function _interopRequireDefault(obj) {
+ return obj && obj.__esModule ? obj : {default: obj};
+}
+
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+const install = (g, table, ...data) => {
+ const bindingWithArray = data.length === 0;
+ const bindingWithTemplate = Array.isArray(table) && !!table.raw;
+
+ if (!bindingWithArray && !bindingWithTemplate) {
+ throw new Error(
+ '`.each` must only be called with an Array or Tagged Template Literal.'
+ );
+ }
+
+ const test = (title, test, timeout) =>
+ (0, _bind.default)(g.test)(table, ...data)(title, test, timeout);
+
+ test.skip = (0, _bind.default)(g.test.skip)(table, ...data);
+ test.only = (0, _bind.default)(g.test.only)(table, ...data);
+
+ const testConcurrent = (title, test, timeout) =>
+ (0, _bind.default)(g.test.concurrent)(table, ...data)(title, test, timeout);
+
+ test.concurrent = testConcurrent;
+ testConcurrent.only = (0, _bind.default)(g.test.concurrent.only)(
+ table,
+ ...data
+ );
+ testConcurrent.skip = (0, _bind.default)(g.test.concurrent.skip)(
+ table,
+ ...data
+ );
+
+ const it = (title, test, timeout) =>
+ (0, _bind.default)(g.it)(table, ...data)(title, test, timeout);
+
+ it.skip = (0, _bind.default)(g.it.skip)(table, ...data);
+ it.only = (0, _bind.default)(g.it.only)(table, ...data);
+ it.concurrent = testConcurrent;
+ const xit = (0, _bind.default)(g.xit)(table, ...data);
+ const fit = (0, _bind.default)(g.fit)(table, ...data);
+ const xtest = (0, _bind.default)(g.xtest)(table, ...data);
+
+ const describe = (title, suite, timeout) =>
+ (0, _bind.default)(g.describe, false)(table, ...data)(
+ title,
+ suite,
+ timeout
+ );
+
+ describe.skip = (0, _bind.default)(g.describe.skip, false)(table, ...data);
+ describe.only = (0, _bind.default)(g.describe.only, false)(table, ...data);
+ const fdescribe = (0, _bind.default)(g.fdescribe, false)(table, ...data);
+ const xdescribe = (0, _bind.default)(g.xdescribe, false)(table, ...data);
+ return {
+ describe,
+ fdescribe,
+ fit,
+ it,
+ test,
+ xdescribe,
+ xit,
+ xtest
+ };
+};
+
+const each = (table, ...data) => install(global, table, ...data);
+
+each.withGlobal =
+ g =>
+ (table, ...data) =>
+ install(g, table, ...data);
+
+var _default = each;
+exports.default = _default;
diff --git a/node_modules/jest-each/build/table/array.d.ts b/node_modules/jest-each/build/table/array.d.ts
new file mode 100644
index 0000000..a2f4cfb
--- /dev/null
+++ b/node_modules/jest-each/build/table/array.d.ts
@@ -0,0 +1,10 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+import type { Global } from '@jest/types';
+import type { EachTests } from '../bind';
+export default function array(title: string, arrayTable: Global.ArrayTable): EachTests;
diff --git a/node_modules/jest-each/build/table/array.js b/node_modules/jest-each/build/table/array.js
new file mode 100644
index 0000000..c687c81
--- /dev/null
+++ b/node_modules/jest-each/build/table/array.js
@@ -0,0 +1,151 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.default = array;
+
+function util() {
+ const data = _interopRequireWildcard(require('util'));
+
+ util = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _prettyFormat() {
+ const data = require('pretty-format');
+
+ _prettyFormat = function () {
+ return data;
+ };
+
+ return data;
+}
+
+var _interpolation = require('./interpolation');
+
+function _getRequireWildcardCache(nodeInterop) {
+ if (typeof WeakMap !== 'function') return null;
+ var cacheBabelInterop = new WeakMap();
+ var cacheNodeInterop = new WeakMap();
+ return (_getRequireWildcardCache = function (nodeInterop) {
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
+ })(nodeInterop);
+}
+
+function _interopRequireWildcard(obj, nodeInterop) {
+ if (!nodeInterop && obj && obj.__esModule) {
+ return obj;
+ }
+ if (obj === null || (typeof obj !== 'object' && typeof obj !== 'function')) {
+ return {default: obj};
+ }
+ var cache = _getRequireWildcardCache(nodeInterop);
+ if (cache && cache.has(obj)) {
+ return cache.get(obj);
+ }
+ var newObj = {};
+ var hasPropertyDescriptor =
+ Object.defineProperty && Object.getOwnPropertyDescriptor;
+ for (var key in obj) {
+ if (key !== 'default' && Object.prototype.hasOwnProperty.call(obj, key)) {
+ var desc = hasPropertyDescriptor
+ ? Object.getOwnPropertyDescriptor(obj, key)
+ : null;
+ if (desc && (desc.get || desc.set)) {
+ Object.defineProperty(newObj, key, desc);
+ } else {
+ newObj[key] = obj[key];
+ }
+ }
+ }
+ newObj.default = obj;
+ if (cache) {
+ cache.set(obj, newObj);
+ }
+ return newObj;
+}
+
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+const SUPPORTED_PLACEHOLDERS = /%[sdifjoOp]/g;
+const PRETTY_PLACEHOLDER = '%p';
+const INDEX_PLACEHOLDER = '%#';
+const PLACEHOLDER_PREFIX = '%';
+const ESCAPED_PLACEHOLDER_PREFIX = /%%/g;
+const JEST_EACH_PLACEHOLDER_ESCAPE = '@@__JEST_EACH_PLACEHOLDER_ESCAPE__@@';
+
+function array(title, arrayTable) {
+ if (isTemplates(title, arrayTable)) {
+ return arrayTable.map((template, index) => ({
+ arguments: [template],
+ title: (0, _interpolation.interpolateVariables)(
+ title,
+ template,
+ index
+ ).replace(ESCAPED_PLACEHOLDER_PREFIX, PLACEHOLDER_PREFIX)
+ }));
+ }
+
+ return normaliseTable(arrayTable).map((row, index) => ({
+ arguments: row,
+ title: formatTitle(title, row, index)
+ }));
+}
+
+const isTemplates = (title, arrayTable) =>
+ !SUPPORTED_PLACEHOLDERS.test(interpolateEscapedPlaceholders(title)) &&
+ !isTable(arrayTable) &&
+ arrayTable.every(col => col != null && typeof col === 'object');
+
+const normaliseTable = table => (isTable(table) ? table : table.map(colToRow));
+
+const isTable = table => table.every(Array.isArray);
+
+const colToRow = col => [col];
+
+const formatTitle = (title, row, rowIndex) =>
+ row
+ .reduce((formattedTitle, value) => {
+ const [placeholder] = getMatchingPlaceholders(formattedTitle);
+ const normalisedValue = normalisePlaceholderValue(value);
+ if (!placeholder) return formattedTitle;
+ if (placeholder === PRETTY_PLACEHOLDER)
+ return interpolatePrettyPlaceholder(formattedTitle, normalisedValue);
+ return util().format(formattedTitle, normalisedValue);
+ }, interpolateTitleIndex(interpolateEscapedPlaceholders(title), rowIndex))
+ .replace(new RegExp(JEST_EACH_PLACEHOLDER_ESCAPE, 'g'), PLACEHOLDER_PREFIX);
+
+const normalisePlaceholderValue = value =>
+ typeof value === 'string'
+ ? value.replace(
+ new RegExp(PLACEHOLDER_PREFIX, 'g'),
+ JEST_EACH_PLACEHOLDER_ESCAPE
+ )
+ : value;
+
+const getMatchingPlaceholders = title =>
+ title.match(SUPPORTED_PLACEHOLDERS) || [];
+
+const interpolateEscapedPlaceholders = title =>
+ title.replace(ESCAPED_PLACEHOLDER_PREFIX, JEST_EACH_PLACEHOLDER_ESCAPE);
+
+const interpolateTitleIndex = (title, index) =>
+ title.replace(INDEX_PLACEHOLDER, index.toString());
+
+const interpolatePrettyPlaceholder = (title, value) =>
+ title.replace(
+ PRETTY_PLACEHOLDER,
+ (0, _prettyFormat().format)(value, {
+ maxDepth: 1,
+ min: true
+ })
+ );
diff --git a/node_modules/jest-each/build/table/interpolation.d.ts b/node_modules/jest-each/build/table/interpolation.d.ts
new file mode 100644
index 0000000..7319506
--- /dev/null
+++ b/node_modules/jest-each/build/table/interpolation.d.ts
@@ -0,0 +1,17 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+export declare type Template = Record<string, unknown>;
+export declare type Templates = Array<Template>;
+export declare type Headings = Array<string>;
+export declare const interpolateVariables: (title: string, template: Template, index: number) => string;
+export declare function getPath<Obj extends Template, A extends keyof Obj, B extends keyof Obj[A], C extends keyof Obj[A][B], D extends keyof Obj[A][B][C], E extends keyof Obj[A][B][C][D]>(obj: Obj, path: [A, B, C, D, E]): Obj[A][B][C][D][E];
+export declare function getPath<Obj extends Template, A extends keyof Obj, B extends keyof Obj[A], C extends keyof Obj[A][B], D extends keyof Obj[A][B][C]>(obj: Obj, path: [A, B, C, D]): Obj[A][B][C][D];
+export declare function getPath<Obj extends Template, A extends keyof Obj, B extends keyof Obj[A], C extends keyof Obj[A][B]>(obj: Obj, path: [A, B, C]): Obj[A][B][C];
+export declare function getPath<Obj extends Template, A extends keyof Obj, B extends keyof Obj[A]>(obj: Obj, path: [A, B]): Obj[A][B];
+export declare function getPath<Obj extends Template, A extends keyof Obj>(obj: Obj, path: [A]): Obj[A];
+export declare function getPath<Obj extends Template>(obj: Obj, path: Array<string>): unknown;
diff --git a/node_modules/jest-each/build/table/interpolation.js b/node_modules/jest-each/build/table/interpolation.js
new file mode 100644
index 0000000..6e714ef
--- /dev/null
+++ b/node_modules/jest-each/build/table/interpolation.js
@@ -0,0 +1,69 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.getPath = getPath;
+exports.interpolateVariables = void 0;
+
+function _jestGetType() {
+ const data = require('jest-get-type');
+
+ _jestGetType = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _prettyFormat() {
+ const data = require('pretty-format');
+
+ _prettyFormat = function () {
+ return data;
+ };
+
+ return data;
+}
+
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+const interpolateVariables = (title, template, index) =>
+ Object.keys(template)
+ .reduce(getMatchingKeyPaths(title), []) // aka flatMap
+ .reduce(replaceKeyPathWithValue(template), title)
+ .replace('$#', '' + index);
+
+exports.interpolateVariables = interpolateVariables;
+
+const getMatchingKeyPaths = title => (matches, key) =>
+ matches.concat(title.match(new RegExp(`\\$${key}[\\.\\w]*`, 'g')) || []);
+
+const replaceKeyPathWithValue = template => (title, match) => {
+ const keyPath = match.replace('$', '').split('.');
+ const value = getPath(template, keyPath);
+
+ if ((0, _jestGetType().isPrimitive)(value)) {
+ return title.replace(match, String(value));
+ }
+
+ return title.replace(
+ match,
+ (0, _prettyFormat().format)(value, {
+ maxDepth: 1,
+ min: true
+ })
+ );
+};
+/* eslint import/export: 0*/
+
+function getPath(template, [head, ...tail]) {
+ if (!head || !template.hasOwnProperty || !template.hasOwnProperty(head))
+ return template;
+ return getPath(template[head], tail);
+}
diff --git a/node_modules/jest-each/build/table/template.d.ts b/node_modules/jest-each/build/table/template.d.ts
new file mode 100644
index 0000000..b1183e9
--- /dev/null
+++ b/node_modules/jest-each/build/table/template.d.ts
@@ -0,0 +1,11 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+import type { Global } from '@jest/types';
+import type { EachTests } from '../bind';
+import type { Headings } from './interpolation';
+export default function template(title: string, headings: Headings, row: Global.Row): EachTests;
diff --git a/node_modules/jest-each/build/table/template.js b/node_modules/jest-each/build/table/template.js
new file mode 100644
index 0000000..3edc0c1
--- /dev/null
+++ b/node_modules/jest-each/build/table/template.js
@@ -0,0 +1,45 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.default = template;
+
+var _interpolation = require('./interpolation');
+
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+function template(title, headings, row) {
+ const table = convertRowToTable(row, headings);
+ const templates = convertTableToTemplates(table, headings);
+ return templates.map((template, index) => ({
+ arguments: [template],
+ title: (0, _interpolation.interpolateVariables)(title, template, index)
+ }));
+}
+
+const convertRowToTable = (row, headings) =>
+ Array.from({
+ length: row.length / headings.length
+ }).map((_, index) =>
+ row.slice(
+ index * headings.length,
+ index * headings.length + headings.length
+ )
+ );
+
+const convertTableToTemplates = (table, headings) =>
+ table.map(row =>
+ row.reduce(
+ (acc, value, index) =>
+ Object.assign(acc, {
+ [headings[index]]: value
+ }),
+ {}
+ )
+ );
diff --git a/node_modules/jest-each/build/validation.d.ts b/node_modules/jest-each/build/validation.d.ts
new file mode 100644
index 0000000..8abfaaa
--- /dev/null
+++ b/node_modules/jest-each/build/validation.d.ts
@@ -0,0 +1,11 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+import type { Global } from '@jest/types';
+export declare const validateArrayTable: (table: unknown) => void;
+export declare const validateTemplateTableArguments: (headings: Array<string>, data: Global.TemplateData) => void;
+export declare const extractValidTemplateHeadings: (headings: string) => string;
diff --git a/node_modules/jest-each/build/validation.js b/node_modules/jest-each/build/validation.js
new file mode 100644
index 0000000..4007adf
--- /dev/null
+++ b/node_modules/jest-each/build/validation.js
@@ -0,0 +1,133 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.validateTemplateTableArguments =
+ exports.validateArrayTable =
+ exports.extractValidTemplateHeadings =
+ void 0;
+
+function _chalk() {
+ const data = _interopRequireDefault(require('chalk'));
+
+ _chalk = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _prettyFormat() {
+ const data = require('pretty-format');
+
+ _prettyFormat = function () {
+ return data;
+ };
+
+ return data;
+}
+
+function _interopRequireDefault(obj) {
+ return obj && obj.__esModule ? obj : {default: obj};
+}
+
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ *
+ */
+const EXPECTED_COLOR = _chalk().default.green;
+
+const RECEIVED_COLOR = _chalk().default.red;
+
+const validateArrayTable = table => {
+ if (!Array.isArray(table)) {
+ throw new Error(
+ '`.each` must be called with an Array or Tagged Template Literal.\n\n' +
+ `Instead was called with: ${(0, _prettyFormat().format)(table, {
+ maxDepth: 1,
+ min: true
+ })}\n`
+ );
+ }
+
+ if (isTaggedTemplateLiteral(table)) {
+ if (isEmptyString(table[0])) {
+ throw new Error(
+ 'Error: `.each` called with an empty Tagged Template Literal of table data.\n'
+ );
+ }
+
+ throw new Error(
+ 'Error: `.each` called with a Tagged Template Literal with no data, remember to interpolate with ${expression} syntax.\n'
+ );
+ }
+
+ if (isEmptyTable(table)) {
+ throw new Error(
+ 'Error: `.each` called with an empty Array of table data.\n'
+ );
+ }
+};
+
+exports.validateArrayTable = validateArrayTable;
+
+const isTaggedTemplateLiteral = array => array.raw !== undefined;
+
+const isEmptyTable = table => table.length === 0;
+
+const isEmptyString = str => typeof str === 'string' && str.trim() === '';
+
+const validateTemplateTableArguments = (headings, data) => {
+ const missingData = data.length % headings.length;
+
+ if (missingData > 0) {
+ throw new Error(
+ 'Not enough arguments supplied for given headings:\n' +
+ EXPECTED_COLOR(headings.join(' | ')) +
+ '\n\n' +
+ 'Received:\n' +
+ RECEIVED_COLOR((0, _prettyFormat().format)(data)) +
+ '\n\n' +
+ `Missing ${RECEIVED_COLOR(missingData.toString())} ${pluralize(
+ 'argument',
+ missingData
+ )}`
+ );
+ }
+};
+
+exports.validateTemplateTableArguments = validateTemplateTableArguments;
+
+const pluralize = (word, count) => word + (count === 1 ? '' : 's');
+
+const START_OF_LINE = '^';
+const NEWLINE = '\\n';
+const HEADING = '\\s*[^\\s]+\\s*';
+const PIPE = '\\|';
+const REPEATABLE_HEADING = `(${PIPE}${HEADING})*`;
+const HEADINGS_FORMAT = new RegExp(
+ START_OF_LINE + NEWLINE + HEADING + REPEATABLE_HEADING + NEWLINE,
+ 'g'
+);
+
+const extractValidTemplateHeadings = headings => {
+ const matches = headings.match(HEADINGS_FORMAT);
+
+ if (matches === null) {
+ throw new Error(
+ 'Table headings do not conform to expected format:\n\n' +
+ EXPECTED_COLOR('heading1 | headingN') +
+ '\n\n' +
+ 'Received:\n\n' +
+ RECEIVED_COLOR((0, _prettyFormat().format)(headings))
+ );
+ }
+
+ return matches[0];
+};
+
+exports.extractValidTemplateHeadings = extractValidTemplateHeadings;
diff --git a/node_modules/jest-each/package.json b/node_modules/jest-each/package.json
new file mode 100644
index 0000000..c2d9bb8
--- /dev/null
+++ b/node_modules/jest-each/package.json
@@ -0,0 +1,41 @@
+{
+ "name": "jest-each",
+ "version": "27.5.1",
+ "description": "Parameterised tests for Jest",
+ "main": "./build/index.js",
+ "types": "./build/index.d.ts",
+ "exports": {
+ ".": {
+ "types": "./build/index.d.ts",
+ "default": "./build/index.js"
+ },
+ "./package.json": "./package.json"
+ },
+ "repository": {
+ "type": "git",
+ "url": "https://github.com/facebook/jest.git",
+ "directory": "packages/jest-each"
+ },
+ "keywords": [
+ "jest",
+ "parameterised",
+ "test",
+ "each"
+ ],
+ "author": "Matt Phillips (mattphillips)",
+ "license": "MIT",
+ "dependencies": {
+ "@jest/types": "^27.5.1",
+ "chalk": "^4.0.0",
+ "jest-get-type": "^27.5.1",
+ "jest-util": "^27.5.1",
+ "pretty-format": "^27.5.1"
+ },
+ "engines": {
+ "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0"
+ },
+ "publishConfig": {
+ "access": "public"
+ },
+ "gitHead": "67c1aa20c5fec31366d733e901fee2b981cb1850"
+}