@autometa/runner 0.6.1 → 0.6.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +26 -0
- package/dist/esm/index.js +21 -17
- package/dist/esm/index.js.map +1 -1
- package/dist/index.d.cts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +20 -16
- package/dist/index.js.map +1 -1
- package/package.json +14 -14
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,31 @@
|
|
|
1
1
|
# @autometa/runner
|
|
2
2
|
|
|
3
|
+
## 0.6.3
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- Updated dependencies [57e6e0e]
|
|
8
|
+
- @autometa/jest-executor@0.6.3
|
|
9
|
+
- @autometa/coordinator@0.3.32
|
|
10
|
+
|
|
11
|
+
## 0.6.2
|
|
12
|
+
|
|
13
|
+
### Patch Changes
|
|
14
|
+
|
|
15
|
+
- 8df323c: feat: tag filters for disposer methods
|
|
16
|
+
- Updated dependencies [8df323c]
|
|
17
|
+
- @autometa/jest-executor@0.6.2
|
|
18
|
+
- @autometa/injection@0.1.5
|
|
19
|
+
- @autometa/coordinator@0.3.31
|
|
20
|
+
- @autometa/app@0.4.2
|
|
21
|
+
- @autometa/http@1.4.20
|
|
22
|
+
- @autometa/gherkin@0.7.2
|
|
23
|
+
- @autometa/scopes@0.7.2
|
|
24
|
+
- @autometa/test-builder@0.4.2
|
|
25
|
+
- @autometa/config@0.1.27
|
|
26
|
+
- @autometa/cucumber-expressions@0.4.4
|
|
27
|
+
- @autometa/events@0.3.2
|
|
28
|
+
|
|
3
29
|
## 0.6.1
|
|
4
30
|
|
|
5
31
|
### Patch Changes
|
package/dist/esm/index.js
CHANGED
|
@@ -46,6 +46,8 @@ __export(src_exports, {
|
|
|
46
46
|
Container: () => Container,
|
|
47
47
|
DataTable: () => DataTable,
|
|
48
48
|
Dates: () => Dates,
|
|
49
|
+
DisposeMethod: () => DisposeMethod,
|
|
50
|
+
DisposeTagFilter: () => DisposeTagFilter,
|
|
49
51
|
Feature: () => Feature2,
|
|
50
52
|
FileObject: () => FileObject,
|
|
51
53
|
Fixture: () => Fixture,
|
|
@@ -130,8 +132,8 @@ var GroupLogEvents = class {
|
|
|
130
132
|
}
|
|
131
133
|
onFeatureEnd({ title, status }) {
|
|
132
134
|
console.groupEnd();
|
|
133
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
134
135
|
console.groupEnd();
|
|
136
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
135
137
|
}
|
|
136
138
|
onScenarioStart({ title }) {
|
|
137
139
|
console.group(title);
|
|
@@ -139,8 +141,8 @@ var GroupLogEvents = class {
|
|
|
139
141
|
}
|
|
140
142
|
onScenarioEnd({ title, status }) {
|
|
141
143
|
console.groupEnd();
|
|
142
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
143
144
|
console.groupEnd();
|
|
145
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
144
146
|
}
|
|
145
147
|
onScenarioOutlineStart(opts) {
|
|
146
148
|
console.group(opts.title);
|
|
@@ -148,8 +150,8 @@ var GroupLogEvents = class {
|
|
|
148
150
|
}
|
|
149
151
|
onScenarioOutlineEnd({ title, status }) {
|
|
150
152
|
console.groupEnd();
|
|
151
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
152
153
|
console.groupEnd();
|
|
154
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
153
155
|
}
|
|
154
156
|
onRuleStart({ title }) {
|
|
155
157
|
console.group(title);
|
|
@@ -157,8 +159,8 @@ var GroupLogEvents = class {
|
|
|
157
159
|
}
|
|
158
160
|
onRuleEnd({ title, status }) {
|
|
159
161
|
console.groupEnd();
|
|
160
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
161
162
|
console.groupEnd();
|
|
163
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
162
164
|
}
|
|
163
165
|
onStepStart({ title }) {
|
|
164
166
|
console.group(title);
|
|
@@ -166,8 +168,8 @@ var GroupLogEvents = class {
|
|
|
166
168
|
}
|
|
167
169
|
onStepEnd({ title, status }) {
|
|
168
170
|
console.groupEnd();
|
|
169
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
170
171
|
console.groupEnd();
|
|
172
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
171
173
|
}
|
|
172
174
|
onBeforeStart({ title, status }) {
|
|
173
175
|
if (status === "SKIPPED") {
|
|
@@ -181,8 +183,8 @@ var GroupLogEvents = class {
|
|
|
181
183
|
return;
|
|
182
184
|
}
|
|
183
185
|
console.groupEnd();
|
|
184
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
185
186
|
console.groupEnd();
|
|
187
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
186
188
|
}
|
|
187
189
|
onAfterStart({ title, status }) {
|
|
188
190
|
if (status === "SKIPPED") {
|
|
@@ -196,8 +198,8 @@ var GroupLogEvents = class {
|
|
|
196
198
|
return;
|
|
197
199
|
}
|
|
198
200
|
console.groupEnd();
|
|
199
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
200
201
|
console.groupEnd();
|
|
202
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
201
203
|
}
|
|
202
204
|
onTeardownStart({ title, status }) {
|
|
203
205
|
if (status === "SKIPPED") {
|
|
@@ -211,8 +213,8 @@ var GroupLogEvents = class {
|
|
|
211
213
|
return;
|
|
212
214
|
}
|
|
213
215
|
console.groupEnd();
|
|
214
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
215
216
|
console.groupEnd();
|
|
217
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
216
218
|
}
|
|
217
219
|
onSetupStart({ title, status }) {
|
|
218
220
|
if (status === "SKIPPED") {
|
|
@@ -226,8 +228,8 @@ var GroupLogEvents = class {
|
|
|
226
228
|
return;
|
|
227
229
|
}
|
|
228
230
|
console.groupEnd();
|
|
229
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
230
231
|
console.groupEnd();
|
|
232
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
231
233
|
}
|
|
232
234
|
onBeforeFeatureStart(opts) {
|
|
233
235
|
console.group(opts.title);
|
|
@@ -235,8 +237,8 @@ var GroupLogEvents = class {
|
|
|
235
237
|
}
|
|
236
238
|
onBeforeFeatureEnd(opts) {
|
|
237
239
|
console.groupEnd();
|
|
238
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
239
240
|
console.groupEnd();
|
|
241
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
240
242
|
}
|
|
241
243
|
onAfterFeatureStart(opts) {
|
|
242
244
|
console.group(opts.title);
|
|
@@ -244,8 +246,8 @@ var GroupLogEvents = class {
|
|
|
244
246
|
}
|
|
245
247
|
onAfterFeatureEnd(opts) {
|
|
246
248
|
console.groupEnd();
|
|
247
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
248
249
|
console.groupEnd();
|
|
250
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
249
251
|
}
|
|
250
252
|
onBeforeRuleStart(opts) {
|
|
251
253
|
console.group(opts.title);
|
|
@@ -253,8 +255,8 @@ var GroupLogEvents = class {
|
|
|
253
255
|
}
|
|
254
256
|
onBeforeRuleEnd(opts) {
|
|
255
257
|
console.groupEnd();
|
|
256
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
257
258
|
console.groupEnd();
|
|
259
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
258
260
|
}
|
|
259
261
|
onAfterRuleStart(opts) {
|
|
260
262
|
console.group(opts.title);
|
|
@@ -262,8 +264,8 @@ var GroupLogEvents = class {
|
|
|
262
264
|
}
|
|
263
265
|
onAfterRuleEnd(opts) {
|
|
264
266
|
console.groupEnd();
|
|
265
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
266
267
|
console.groupEnd();
|
|
268
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
267
269
|
}
|
|
268
270
|
onBeforeScenarioOutlineStart(opts) {
|
|
269
271
|
console.group(opts.title);
|
|
@@ -271,8 +273,8 @@ var GroupLogEvents = class {
|
|
|
271
273
|
}
|
|
272
274
|
onBeforeScenarioOutlineEnd(opts) {
|
|
273
275
|
console.groupEnd();
|
|
274
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
275
276
|
console.groupEnd();
|
|
277
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
276
278
|
}
|
|
277
279
|
onBeforeExamplesStart(opts) {
|
|
278
280
|
console.group(opts.title);
|
|
@@ -280,8 +282,8 @@ var GroupLogEvents = class {
|
|
|
280
282
|
}
|
|
281
283
|
onBeforeExamplesEnd(opts) {
|
|
282
284
|
console.groupEnd();
|
|
283
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
284
285
|
console.groupEnd();
|
|
286
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
285
287
|
}
|
|
286
288
|
onAfterExamplesStart(opts) {
|
|
287
289
|
console.group(opts.title);
|
|
@@ -289,8 +291,8 @@ var GroupLogEvents = class {
|
|
|
289
291
|
}
|
|
290
292
|
onAfterExamplesEnd(opts) {
|
|
291
293
|
console.groupEnd();
|
|
292
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
293
294
|
console.groupEnd();
|
|
295
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
294
296
|
}
|
|
295
297
|
};
|
|
296
298
|
function colorStatus(status, text) {
|
|
@@ -373,7 +375,7 @@ import {
|
|
|
373
375
|
Inject
|
|
374
376
|
} from "@autometa/injection";
|
|
375
377
|
import { getApp } from "@autometa/app";
|
|
376
|
-
import { DisposeMethod } from "@autometa/injection";
|
|
378
|
+
import { DisposeMethod, DisposeTagFilter } from "@autometa/injection";
|
|
377
379
|
var OPTS = {};
|
|
378
380
|
var AppType = at.bind(null, OPTS);
|
|
379
381
|
|
|
@@ -477,6 +479,8 @@ export {
|
|
|
477
479
|
Container,
|
|
478
480
|
DataTable,
|
|
479
481
|
Dates,
|
|
482
|
+
DisposeMethod,
|
|
483
|
+
DisposeTagFilter,
|
|
480
484
|
Feature2 as Feature,
|
|
481
485
|
FileObject,
|
|
482
486
|
Fixture,
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/config.ts","../../src/parameters.ts","../../src/scopes.ts","../../src/events.ts","../../src/event-logger.ts","../../src/executor.ts","../../src/app.ts"],"sourcesContent":["import type {\n FeatureAction,\n FeatureScope,\n ScenarioAction,\n ScenarioScope,\n SizedTimeout,\n TestTimeout,\n} from \"@autometa/scopes\";\n\nexport { defineConfig } from \"./config\";\nexport { defineParameterType } from \"./parameters\";\nimport {\n Feature as FeatureDefinition,\n Scenario as ScenarioDefinition,\n ScenarioOutline as ScenarioOutlineDefinition,\n Rule as RuleDefinition,\n Given as GivenDefinition,\n When as WhenDefinition,\n Then as ThenDefinition,\n Before as BeforeDefinition,\n After as AfterDefinition,\n Teardown as TeardownDefinition,\n Setup as SetupDefinition,\n BeforeFeature as BeforeFeatureDefinition,\n AfterFeature as AfterFeatureDefinition,\n BeforeScenarioOutline as BeforeScenarioOutlineDefinition,\n AfterScenarioOutline as AfterScenarioOutlineDefinition,\n BeforeExamples as BeforeExamplesDefinition,\n AfterExamples as AfterExamplesDefinition,\n BeforeRule as BeforeRuleDefinition,\n AfterRule as AfterRuleDefinition,\n} from \"./scopes\";\nimport { RuleAction } from \"@autometa/scopes\";\nimport { RuleScope } from \"@autometa/scopes\";\nexport { Pass } from \"./scopes\";\nexport * from \"@autometa/phrases\";\nexport {\n AppType,\n Fixture,\n Container,\n Constructor,\n AutometaApp,\n getApp,\n AutometaWorld,\n App,\n World,\n INJECTION_SCOPE,\n InjectionScope,\n Inject,\n} from \"./app\";\nexport { Dates, Time } from \"@autometa/datetime\";\nexport { AutomationError, raise } from \"@autometa/errors\";\nexport {\n DataTable,\n HTable,\n VTable,\n MTable,\n TableDocument,\n} from \"@autometa/gherkin\";\nexport { Bind } from \"@autometa/bind-decorator\";\nexport { Types } from \"@autometa/scopes\";\nexport * from \"./events\";\nexport * from \"@autometa/http\";\nexport * from \"@autometa/asserters\";\nexport {\n GetAccessedCount,\n GetAssignedValues,\n TrackAccess,\n} from \"@autometa/fixture-proxies\";\n\nexport { FileObject } from \"@autometa/file-proxies\";\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n *\n * ``ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n *\n * Feature('../features/my-feature.feature')\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * }\n * ```\n *\n * Global steps are defined in standard Cucumber stle.\n * ```ts\n * // ./test/steps/my-steps.ts\n * import { Given, When, Then } from '@autometa/runner'\n *\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * ```\n * @param filepath The absolute, relative, or 'feature root' path to the `.feature` file.\n */\nexport function Feature(filepath: string): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n * Accepts a timeout in milliseconds which will be applied to\n * all tests within the feature.\n *\n * ```ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n * // 10 second timeout\n * Feature('../features/my-feature.feature', 10_000)\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * }\n * ```\n *\n * Global steps are defined in standard Cucumber style.\n *\n * ```ts\n * // ./test/steps/my-steps.ts\n * import { Given, When, Then } from '@autometa/runner'\n *\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * ```\n * @param filepath The absolute, relative, or 'feature root' path to the `.feature` file.\n * @param timeout The timeout in milliseconds to apply to all tests within the feature.\n */\nexport function Feature(filepath: string, timeout: number): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n * Accepts a timeout as a `TestTimeout` which is a tuple of `[durationNumber, 'ms' | 's' | 'm' | 'h']`\n * which will be applied to all tests within the feature.\n *\n * i.e. `[10, 's']` is a 10 second timeout. `[1, 'm']` is a 1 minute timeout.\n *\n * ```ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n *\n * // 10 second timeout\n * Feature('../features/my-feature.feature', [10, 's'])\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * };\n *\n * ```\n *\n * @param filepath\n * @param timeout\n */\nexport function Feature(filepath: string, timeout: TestTimeout): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and optionally locally defined steps,\n * mixed with optionally globally defined Step Definitions.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * })\n * ```\n *\n * If defined in the Gherkin, it will also use any Globally defined Step Definitions which match,\n * if none is defined locally. If a Step Definition is defined both globally and locally,\n * the most local definition will be used. This applies to sub-scopes like Scenarios and Rules\n * also.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n *\n * Scenario('My Scenario', () => {\n * Given('I have a step', () => {})\n * })\n *\n * Rule('My Rule', () => {\n * Given('I have a step', () => {})\n * })\n *\n * @param testDefinition\n * @param filepath\n */\nexport function Feature(\n testDefinition: FeatureAction,\n filepath: string\n): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and optionally locally defined steps,\n * mixed with optionally globally defined Step Definitions.\n * Accepts a timeout in milliseconds which will be applied to\n * all tests within the feature.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * // 10 second timeout\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * }, 10_000)\n * ```\n * @param testDefinition the Feature definition callback\n * @param filepath\n * @param timeout\n */\nexport function Feature(\n testDefinition: FeatureAction,\n filepath: string,\n timeout: number\n): FeatureScope;\nexport function Feature(\n ...args: (FeatureAction | string | TestTimeout)[]\n): FeatureScope {\n return FeatureDefinition(...args);\n}\n\nexport function Scenario(title: string, action: ScenarioAction): ScenarioScope;\nexport function Scenario(\n title: string,\n action: ScenarioAction,\n timeout: number\n): ScenarioScope;\nexport function Scenario(\n title: string,\n action: ScenarioAction,\n timeout: SizedTimeout\n): ScenarioScope;\nexport function Scenario(\n ...args: (string | ScenarioAction | SizedTimeout | number)[]\n): ScenarioScope {\n return ScenarioDefinition(...args);\n}\n\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction\n): ScenarioScope;\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction,\n timeout: number\n): ScenarioScope;\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction,\n timeout: SizedTimeout\n): ScenarioScope;\nexport function ScenarioOutline(\n ...args: (string | ScenarioAction | SizedTimeout | number)[]\n): ScenarioScope {\n return ScenarioOutlineDefinition(...args);\n}\n\nexport function Rule(title: string, action: RuleAction): RuleScope;\nexport function Rule(\n title: string,\n action: RuleAction,\n timeout: number\n): RuleScope;\nexport function Rule(\n title: string,\n action: RuleAction,\n timeout: SizedTimeout\n): RuleScope;\nexport function Rule(\n ...args: (string | RuleAction | SizedTimeout | number)[]\n): RuleScope {\n return RuleDefinition(...args);\n}\n/**\n * Defines a `Given` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n * the context of a scenario, but cannot be accessed from the same step in a different\n * scenario.\n *\n * ```ts\n * import { Given } from '@autometa/runner'\n *\n * Given('I have a step', (app) => {\n * app.world.someData = 'some value'\n * })\n * // using destructuring\n * Given('I have a step', ({ world }) => {\n * world.someData = 'some value'\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { Given } from '@autometa/runner'\n *\n * // matches 'Given I have a step with a 'blue' value'\n * Given('I have a step with a {string} value', (value, { world }) => {\n * world.someData = value\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const Given = GivenDefinition;\n/**\n * Defines a `When` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n *\n * ```ts\n * import { When } from '@autometa/runner'\n *\n * When('I do something', async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * When('I do something', async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { When } from '@autometa/runner'\n *\n * // matches 'When I do something with a 'blue' value'\n * When('I do something with a {string} value', async (value, { webdriver }) => {\n * await webdriver.click(`#some-button-${value}`)\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const When = WhenDefinition;\n\n/**\n * Defines a `Then` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n *\n * ```ts\n * import { Then } from '@autometa/runner'\n *\n * Then('I expect something', async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Then('I expect something', async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { Then } from '@autometa/runner'\n *\n * // matches 'Then I expect something with a 'blue' value'\n * Then('I expect something with a {string} value', async (value, { world }) => {\n * expect(world.someData).toBe(value)\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const Then = ThenDefinition;\n\n/**\n * Defines a `Before` hook. Executes before each scenario.\n *\n * ```ts\n * import { Before } from '@autometa/runner'\n *\n * Before(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Before(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Before = BeforeDefinition;\n\n/**\n * Defines a `After` hook. Executes after each scenario.\n *\n * ```ts\n * import { After } from '@autometa/runner'\n *\n * After(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * After(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const After = AfterDefinition;\n\n/**\n * Defines a `Setup` hook. Executes before all scenarios.\n * Setups are scoped, meaning a Setup defined inside the scope of a rule\n * will only apply to scenarios within that rule.\n *\n * N.b the Setup Hook and Teardown Hook reference their own unique\n * copy of the App with it's own unique life cycle. Values stored here\n * will not be accessible in tests without a singleton fixture.\n *\n * ```ts\n * import { Setup } from '@autometa/runner'\n *\n * Setup(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Setup(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Teardown = TeardownDefinition;\n\n/**\n * Defines a `Teardown` hook. Executes after all scenarios have completed.\n * Teardowns are scoped, meaning a Teardown defined inside the scope of a rule\n * will only apply to scenarios within that rule.\n *\n * N.b the Setup Hook and Teardown Hook reference their own unique\n * copy of the App with it's own unique life cycle. Values stored here\n * will not be accessible in tests without a singleston fixture.\n * ```ts\n * import { Teardown } from '@autometa/runner'\n *\n * Teardown(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Teardown(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Setup = SetupDefinition;\n\n/**\n * Defines a `BeforeFeature` hook. Executes before each feature.\n *\n * ```ts\n * import { BeforeFeature } from '@autometa/runner'\n *\n * BeforeFeature(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeFeature(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const BeforeFeature = BeforeFeatureDefinition;\n\n/**\n * Defines a `AfterFeature` hook. Executes after each feature.\n *\n * ```ts\n * import { AfterFeature } from '@autometa/runner'\n *\n * AfterFeature(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterFeature(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const AfterFeature = AfterFeatureDefinition;\n\n/**\n * Defines a `BeforeScenarioOutline` hook. Executes before each scenario outline.\n *\n * ```ts\n * import { BeforeScenarioOutline } from '@autometa/runner'\n *\n * BeforeScenarioOutline(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeScenarioOutline(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const BeforeScenarioOutline = BeforeScenarioOutlineDefinition;\n\n/**\n * Defines a `AfterScenarioOutline` hook. Executes after each scenario outline.\n *\n * ```ts\n * import { AfterScenarioOutline } from '@autometa/runner'\n *\n * AfterScenarioOutline(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterScenarioOutline(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const AfterScenarioOutline = AfterScenarioOutlineDefinition;\n\n/**\n * Defines a `BeforeExamples` hook. Executes before each examples table.\n *\n * ```ts\n * import { BeforeExamples } from '@autometa/runner'\n *\n * BeforeExamples(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeExamples(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const BeforeExamples = BeforeExamplesDefinition;\n\n/**\n * Defines a `AfterExamples` hook. Executes after each examples table.\n *\n * ```ts\n * import { AfterExamples } from '@autometa/runner'\n *\n * AfterExamples(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterExamples(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const AfterExamples = AfterExamplesDefinition;\n\n/**\n * Defines a `BeforeRule` hook. Executes before each rule.\n *\n * ```ts\n * import { BeforeRule } from '@autometa/runner'\n *\n * BeforeRule(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeRule(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const BeforeRule = BeforeRuleDefinition;\n\n/**\n * Defines a `AfterRule` hook. Executes after each rule.\n *\n * ```ts\n * import { AfterRule } from '@autometa/runner'\n *\n * AfterRule(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterRule(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const AfterRule = AfterRuleDefinition;\n","import {\n Config,\n TestExecutorConfig,\n defineConfig as dc,\n} from \"@autometa/config\";\n\nexport const CONFIG = new Config(new Map<string, TestExecutorConfig>());\nexport const defineConfig = dc.bind(null, CONFIG);\n","import { ParameterTypeRegistry } from \"@cucumber/cucumber-expressions\";\nimport {\n BooleanParam,\n DateParam,\n NumberParam,\n PrimitiveParam,\n OrdinalParam,\n TextParam,\n defineParameterType as dpt,\n} from \"@autometa/cucumber-expressions\";\n\nexport const PARAM_REGISTRY = new ParameterTypeRegistry();\n\n/**\n * Defines a parameter type for use in step definitions.\n *\n * ```ts\n * import { Color } from '../support/color';\n *\n * defineParameterType({\n * name: \"color\",\n * regex: /red|blue|yellow/,\n * transform: (value: string) => Color(value)\n * })\n *\n * // using regex arrays\n * defineParameterType({\n * name: \"color\",\n * regex: [/red/, /blue/, /yellow/],\n * transform: (value: string) => Color(value)\n * })\n * ```\n */\nexport const defineParameterType = dpt.bind(null, PARAM_REGISTRY);\n\ndefineParameterType(\n NumberParam,\n BooleanParam,\n PrimitiveParam,\n TextParam,\n DateParam,\n OrdinalParam\n);\n","import { PARAM_REGISTRY } from \"./parameters\";\nimport { GetCucumberFunctions, Pass } from \"@autometa/scopes\";\nimport { Coordinator } from \"@autometa/coordinator\";\nimport { CONFIG } from \"./config\";\nimport { makeTestEmitter } from \"./events\";\nimport { executor } from \"./executor\";\nimport { OPTS } from \"./app\";\nconst {\n BeforeFeature,\n AfterFeature,\n BeforeScenarioOutline,\n AfterScenarioOutline,\n BeforeExamples,\n AfterExamples,\n BeforeRule,\n AfterRule,\n Feature,\n Scenario,\n ScenarioOutline,\n Rule,\n Given,\n When,\n Then,\n Before,\n After,\n Teardown,\n Setup,\n Global,\n} = GetCucumberFunctions(PARAM_REGISTRY);\nconst coordinator = new Coordinator(Global, CONFIG, OPTS);\nGlobal.onFeatureExecuted = (feature, caller) => {\n const groupLogger = CONFIG.current.test?.groupLogging ?? false;\n const events = makeTestEmitter({ groupLogger });\n coordinator.run(feature, caller, events, executor);\n};\n\nexport {\n Feature,\n Scenario,\n ScenarioOutline,\n Rule,\n Given,\n When,\n Then,\n Before,\n After,\n Teardown,\n Setup,\n BeforeFeature,\n AfterFeature,\n BeforeScenarioOutline,\n AfterScenarioOutline,\n BeforeExamples,\n AfterExamples,\n BeforeRule,\n AfterRule,\n Pass,\n};\n","import { TestEventEmitter } from \"@autometa/events\";\nimport { CONFIG } from \"./config\";\nexport * from \"@autometa/events\";\nimport { GroupLogEvents } from \"./event-logger\";\nimport p from \"path\";\nexport function makeTestEmitter(opts: { groupLogger: boolean }) {\n const events = CONFIG.current.events;\n const emitter = new TestEventEmitter();\n if (opts.groupLogger) {\n emitter.load(new GroupLogEvents());\n }\n if (!events) {\n return emitter;\n }\n\n for (const event of events) {\n const isLocal = isRelativePath(event) || isAbsolutePath(event);\n if (isLocal) {\n const uriRoot = process.cwd();\n const uri = p.join(uriRoot, event);\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const listener = require(uri);\n if (\"default\" in listener && typeof listener.default === \"function\") {\n emitter.load(new listener.default());\n return emitter;\n }\n if (\"default\" in listener && typeof listener.default === \"object\") {\n emitter.load(listener.default);\n return emitter;\n }\n if (typeof listener === \"function\") {\n emitter.load(new listener());\n return emitter;\n }\n emitter.load(listener);\n return emitter;\n }\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const listener = require(event);\n if (\"default\" in listener) {\n emitter.load(listener.default);\n return emitter;\n }\n emitter.load(listener);\n return emitter;\n }\n\n return emitter;\n}\n\nfunction isRelativePath(path: string) {\n return path.startsWith(\".\");\n}\n\nfunction isAbsolutePath(path: string) {\n return p.isAbsolute(path);\n}\n","import {\n EndAfterOpts,\n EndBeforeOpts,\n EndFeatureOpts,\n EndRuleOpts,\n EndScenarioOpts,\n EndScenarioOutlineOpts,\n EndSetupOpts,\n EndStepOpts,\n EndTeardownOpts,\n EventSubscriber,\n StartAfterOpts,\n StartBeforeOpts,\n StartFeatureOpts,\n StartRuleOpts,\n StartScenarioOpts,\n StartScenarioOutlineOpts,\n StartSetupOpts,\n StartStepOpts,\n StartTeardownOpts,\n} from \"@autometa/events\";\nimport colors from \"colors-cli\";\nexport class GroupLogEvents implements EventSubscriber {\n onFeatureStart({ title }: StartFeatureOpts) {\n console.group(title);\n console.group();\n }\n onFeatureEnd({ title, status }: EndFeatureOpts): void {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onScenarioStart({ title }: StartScenarioOpts): void {\n console.group(title);\n console.group();\n }\n onScenarioEnd({ title, status }: EndScenarioOpts): void {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onScenarioOutlineStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n onScenarioOutlineEnd({ title, status }: EndScenarioOutlineOpts): void {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onRuleStart({ title }: StartRuleOpts): void {\n console.group(title);\n console.group();\n }\n onRuleEnd({ title, status }: EndRuleOpts): void {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onStepStart({ title }: StartStepOpts) {\n console.group(title);\n console.group();\n }\n onStepEnd({ title, status }: EndStepOpts) {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onBeforeStart({ title, status }: StartBeforeOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onBeforeEnd({ title, status }: EndBeforeOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onAfterStart({ title, status }: StartAfterOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onAfterEnd({ title, status }: EndAfterOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onTeardownStart({ title, status }: StartTeardownOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onTeardownEnd({ title, status }: EndTeardownOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onSetupStart({ title, status }: StartSetupOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onSetupEnd({ title, status }: EndSetupOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onBeforeFeatureStart(opts: StartFeatureOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeFeatureEnd(opts: EndFeatureOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onAfterFeatureStart(opts: StartFeatureOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterFeatureEnd(opts: EndFeatureOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onBeforeRuleStart(opts: StartRuleOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeRuleEnd(opts: EndRuleOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onAfterRuleStart(opts: StartRuleOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterRuleEnd(opts: EndRuleOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onBeforeScenarioOutlineStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeScenarioOutlineEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onBeforeExamplesStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeExamplesEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onAfterExamplesStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterExamplesEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n}\nfunction colorStatus(\n status: \"FAILED\" | \"PASSED\" | \"SKIPPED\" | \"BROKEN\" | undefined,\n text: string\n) {\n switch (status) {\n case \"FAILED\":\n return `${colors.red(\"x\")} ${text}`;\n case \"PASSED\":\n return `${colors.green(\"✔️\")} ${text}`;\n case \"SKIPPED\":\n return `${colors.yellow(\"⊘\")} ${text}`;\n default:\n return text;\n }\n}\n","import { execute } from \"@autometa/jest-executor\";\n\nexport const executor = execute;\n","import \"@autometa/types\";\nimport { AppType as at } from \"@autometa/app\";\nimport { CoordinatorOpts } from \"@autometa/coordinator\";\nexport { AutometaApp, AutometaWorld, App, World } from \"@autometa/app\";\nexport {\n Fixture,\n INJECTION_SCOPE,\n InjectionScope,\n Token,\n Container,\n Constructor,\n Inject,\n} from \"@autometa/injection\";\nexport const OPTS = {} as Record<string, CoordinatorOpts>;\n/**\n * Marks a class as being the `App` of the test framework. The `App` is the\n * entry point for the test framework. The App will be made available as the final\n * argument in the Step Definition Callbacks.\n *\n * ```ts\n *\n * @AppType(World)\n * @Constructor(MyClient)\n * class App {\n * constructor(readonly myCLient: MyClient) {}\n * }\n * ```\n * Or with tokens\n *\n * ```ts\n * import from \"@autometa/runner\";\n * import { World } from \"./default.world\";\n * @AppType(World)\n * @Constructor(HTTP, Token(\"MyClient\"))\n * class App {\n * constructor(readonly http: HTTP, readonly myClient: MyClient) {}\n * }\n * ```\n */\nexport const AppType = at.bind(null, OPTS);\nexport { getApp } from \"@autometa/app\";\nexport { DisposeMethod } from \"@autometa/injection\";\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA,eAAAA;AAAA,EAAA,qBAAAC;AAAA,EAAA,oBAAAC;AAAA,EAAA,iBAAAC;AAAA,EAAA,4BAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBAAAC;AAAA,EAAA,sBAAAC;AAAA,EAAA,qBAAAC;AAAA,EAAA,kBAAAC;AAAA,EAAA,6BAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,eAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,cAAAC;AAAA,EAAA,gBAAAC;AAAA,EAAA,uBAAAC;AAAA,EAAA,aAAAC;AAAA,EAAA;AAAA,kBAAAC;AAAA,EAAA,YAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,cAAAC;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA;AAAA,EACE;AAAA,EAEA,gBAAgB;AAAA,OACX;AAEA,IAAM,SAAS,IAAI,OAAO,oBAAI,IAAgC,CAAC;AAC/D,IAAM,eAAe,GAAG,KAAK,MAAM,MAAM;;;ACPhD,SAAS,6BAA6B;AACtC;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,uBAAuB;AAAA,OAClB;AAEA,IAAM,iBAAiB,IAAI,sBAAsB;AAsBjD,IAAM,sBAAsB,IAAI,KAAK,MAAM,cAAc;AAEhE;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;;;ACzCA,SAAS,sBAAsB,YAAY;AAC3C,SAAS,mBAAmB;;;ACF5B;AAAA;AAAA;AAAA;AAAA,SAAS,wBAAwB;AAEjC;AAAA,6BAAc;;;ACmBd,OAAO,YAAY;AACZ,IAAM,iBAAN,MAAgD;AAAA,EACrD,eAAe,EAAE,MAAM,GAAqB;AAC1C,YAAQ,MAAM,KAAK;AACnB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,aAAa,EAAE,OAAO,OAAO,GAAyB;AACpD,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,gBAAgB,EAAE,MAAM,GAA4B;AAClD,YAAQ,MAAM,KAAK;AACnB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,cAAc,EAAE,OAAO,OAAO,GAA0B;AACtD,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,uBAAuB,MAAsC;AAC3D,YAAQ,MAAM,KAAK,KAAK;AACxB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,qBAAqB,EAAE,OAAO,OAAO,GAAiC;AACpE,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,YAAY,EAAE,MAAM,GAAwB;AAC1C,YAAQ,MAAM,KAAK;AACnB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,UAAU,EAAE,OAAO,OAAO,GAAsB;AAC9C,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,YAAY,EAAE,MAAM,GAAkB;AACpC,YAAQ,MAAM,KAAK;AACnB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,UAAU,EAAE,OAAO,OAAO,GAAgB;AACxC,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,cAAc,EAAE,OAAO,OAAO,GAA0B;AACtD,QAAI,WAAW,WAAW;AACxB;AAAA,IACF;AACA,YAAQ,MAAM,KAAK;AACnB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,YAAY,EAAE,OAAO,OAAO,GAAwB;AAClD,QAAI,WAAW,WAAW;AACxB;AAAA,IACF;AACA,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,aAAa,EAAE,OAAO,OAAO,GAAyB;AACpD,QAAI,WAAW,WAAW;AACxB;AAAA,IACF;AACA,YAAQ,MAAM,KAAK;AACnB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,WAAW,EAAE,OAAO,OAAO,GAAuB;AAChD,QAAI,WAAW,WAAW;AACxB;AAAA,IACF;AACA,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,gBAAgB,EAAE,OAAO,OAAO,GAA4B;AAC1D,QAAI,WAAW,WAAW;AACxB;AAAA,IACF;AACA,YAAQ,MAAM,KAAK;AACnB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,cAAc,EAAE,OAAO,OAAO,GAA0B;AACtD,QAAI,WAAW,WAAW;AACxB;AAAA,IACF;AACA,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,aAAa,EAAE,OAAO,OAAO,GAAyB;AACpD,QAAI,WAAW,WAAW;AACxB;AAAA,IACF;AACA,YAAQ,MAAM,KAAK;AACnB,YAAQ,MAAM;AAAA,EAChB;AAAA,EACA,WAAW,EAAE,OAAO,OAAO,GAAuB;AAChD,QAAI,WAAW,WAAW;AACxB;AAAA,IACF;AACA,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,QAAQ,UAAU,KAAK,EAAE,CAAC;AAClD,YAAQ,SAAS;AAAA,EACnB;AAAA,EACA,qBAAqB,MAA8B;AACjD,YAAQ,MAAM,KAAK,KAAK;AACxB,YAAQ,MAAM;AAAA,EAChB;AAAA,EAEA,mBAAmB,MAA4B;AAC7C,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,KAAK,QAAQ,UAAU,KAAK,KAAK,EAAE,CAAC;AAC5D,YAAQ,SAAS;AAAA,EACnB;AAAA,EAEA,oBAAoB,MAA8B;AAChD,YAAQ,MAAM,KAAK,KAAK;AACxB,YAAQ,MAAM;AAAA,EAChB;AAAA,EAEA,kBAAkB,MAA4B;AAC5C,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,KAAK,QAAQ,UAAU,KAAK,KAAK,EAAE,CAAC;AAC5D,YAAQ,SAAS;AAAA,EACnB;AAAA,EAEA,kBAAkB,MAA2B;AAC3C,YAAQ,MAAM,KAAK,KAAK;AACxB,YAAQ,MAAM;AAAA,EAChB;AAAA,EAEA,gBAAgB,MAAyB;AACvC,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,KAAK,QAAQ,UAAU,KAAK,KAAK,EAAE,CAAC;AAC5D,YAAQ,SAAS;AAAA,EACnB;AAAA,EAEA,iBAAiB,MAA2B;AAC1C,YAAQ,MAAM,KAAK,KAAK;AACxB,YAAQ,MAAM;AAAA,EAChB;AAAA,EAEA,eAAe,MAAyB;AACtC,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,KAAK,QAAQ,UAAU,KAAK,KAAK,EAAE,CAAC;AAC5D,YAAQ,SAAS;AAAA,EACnB;AAAA,EAEA,6BAA6B,MAAsC;AACjE,YAAQ,MAAM,KAAK,KAAK;AACxB,YAAQ,MAAM;AAAA,EAChB;AAAA,EAEA,2BAA2B,MAA6B;AACtD,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,KAAK,QAAQ,UAAU,KAAK,KAAK,EAAE,CAAC;AAC5D,YAAQ,SAAS;AAAA,EACnB;AAAA,EAEA,sBAAsB,MAAsC;AAC1D,YAAQ,MAAM,KAAK,KAAK;AACxB,YAAQ,MAAM;AAAA,EAChB;AAAA,EAEA,oBAAoB,MAA6B;AAC/C,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,KAAK,QAAQ,UAAU,KAAK,KAAK,EAAE,CAAC;AAC5D,YAAQ,SAAS;AAAA,EACnB;AAAA,EAEA,qBAAqB,MAAsC;AACzD,YAAQ,MAAM,KAAK,KAAK;AACxB,YAAQ,MAAM;AAAA,EAChB;AAAA,EAEA,mBAAmB,MAA6B;AAC9C,YAAQ,SAAS;AACjB,YAAQ,IAAI,YAAY,KAAK,QAAQ,UAAU,KAAK,KAAK,EAAE,CAAC;AAC5D,YAAQ,SAAS;AAAA,EACnB;AACF;AACA,SAAS,YACP,QACA,MACA;AACA,UAAQ,QAAQ;AAAA,IACd,KAAK;AACH,aAAO,GAAG,OAAO,IAAI,GAAG,CAAC,IAAI,IAAI;AAAA,IACnC,KAAK;AACH,aAAO,GAAG,OAAO,MAAM,cAAI,CAAC,IAAI,IAAI;AAAA,IACtC,KAAK;AACH,aAAO,GAAG,OAAO,OAAO,QAAG,CAAC,IAAI,IAAI;AAAA,IACtC;AACE,aAAO;AAAA,EACX;AACF;;;ADvNA,OAAO,OAAO;AACP,SAAS,gBAAgB,MAAgC;AAC9D,QAAM,SAAS,OAAO,QAAQ;AAC9B,QAAM,UAAU,IAAI,iBAAiB;AACrC,MAAI,KAAK,aAAa;AACpB,YAAQ,KAAK,IAAI,eAAe,CAAC;AAAA,EACnC;AACA,MAAI,CAAC,QAAQ;AACX,WAAO;AAAA,EACT;AAEA,aAAW,SAAS,QAAQ;AAC1B,UAAM,UAAU,eAAe,KAAK,KAAK,eAAe,KAAK;AAC7D,QAAI,SAAS;AACX,YAAM,UAAU,QAAQ,IAAI;AAC5B,YAAM,MAAM,EAAE,KAAK,SAAS,KAAK;AAEjC,YAAMC,YAAW,UAAQ,GAAG;AAC5B,UAAI,aAAaA,aAAY,OAAOA,UAAS,YAAY,YAAY;AACnE,gBAAQ,KAAK,IAAIA,UAAS,QAAQ,CAAC;AACnC,eAAO;AAAA,MACT;AACA,UAAI,aAAaA,aAAY,OAAOA,UAAS,YAAY,UAAU;AACjE,gBAAQ,KAAKA,UAAS,OAAO;AAC7B,eAAO;AAAA,MACT;AACA,UAAI,OAAOA,cAAa,YAAY;AAClC,gBAAQ,KAAK,IAAIA,UAAS,CAAC;AAC3B,eAAO;AAAA,MACT;AACA,cAAQ,KAAKA,SAAQ;AACrB,aAAO;AAAA,IACT;AAEA,UAAM,WAAW,UAAQ,KAAK;AAC9B,QAAI,aAAa,UAAU;AACzB,cAAQ,KAAK,SAAS,OAAO;AAC7B,aAAO;AAAA,IACT;AACA,YAAQ,KAAK,QAAQ;AACrB,WAAO;AAAA,EACT;AAEA,SAAO;AACT;AAEA,SAAS,eAAe,MAAc;AACpC,SAAO,KAAK,WAAW,GAAG;AAC5B;AAEA,SAAS,eAAe,MAAc;AACpC,SAAO,EAAE,WAAW,IAAI;AAC1B;;;AExDA,SAAS,eAAe;AAEjB,IAAM,WAAW;;;ACFxB,OAAO;AACP,SAAS,WAAW,UAAU;AAE9B,SAAS,aAAa,eAAe,KAAK,aAAa;AACvD;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AA4BP,SAAS,cAAc;AACvB,SAAS,qBAAqB;AA5BvB,IAAM,OAAO,CAAC;AA0Bd,IAAM,UAAU,GAAG,KAAK,MAAM,IAAI;;;AJhCzC,IAAM;AAAA,EACJ;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,IAAI,qBAAqB,cAAc;AACvC,IAAM,cAAc,IAAI,YAAY,QAAQ,QAAQ,IAAI;AACxD,OAAO,oBAAoB,CAAC,SAAS,WAAW;AAC9C,QAAM,cAAc,OAAO,QAAQ,MAAM,gBAAgB;AACzD,QAAM,SAAS,gBAAgB,EAAE,YAAY,CAAC;AAC9C,cAAY,IAAI,SAAS,QAAQ,QAAQ,QAAQ;AACnD;;;AH2BA,wBAAc;AA1Bd,cAAc;AAed,SAAS,OAAO,YAAY;AAC5B,SAAS,iBAAiB,aAAa;AACvC;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,YAAY;AACrB,SAAS,aAAa;AAEtB,cAAc;AACd,cAAc;AACd;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAEP,SAAS,kBAAkB;AA0LpB,SAASC,YACX,MACW;AACd,SAAO,QAAkB,GAAG,IAAI;AAClC;AAaO,SAASC,aACX,MACY;AACf,SAAO,SAAmB,GAAG,IAAI;AACnC;AAgBO,SAASC,oBACX,MACY;AACf,SAAO,gBAA0B,GAAG,IAAI;AAC1C;AAaO,SAASC,SACX,MACQ;AACX,SAAO,KAAe,GAAG,IAAI;AAC/B;AAuCO,IAAMC,SAAQ;AAsCd,IAAMC,QAAO;AAuCb,IAAMC,QAAO;AAoBb,IAAMC,UAAS;AAoBf,IAAMC,SAAQ;AA0Bd,IAAMC,YAAW;AAyBjB,IAAMC,SAAQ;AAoBd,IAAMC,iBAAgB;AAoBtB,IAAMC,gBAAe;AAoBrB,IAAMC,yBAAwB;AAqB9B,IAAMC,wBAAuB;AAqB7B,IAAMC,kBAAiB;AAoBvB,IAAMC,iBAAgB;AAqBtB,IAAMC,cAAa;AAqBnB,IAAMC,aAAY;","names":["After","AfterExamples","AfterFeature","AfterRule","AfterScenarioOutline","Before","BeforeExamples","BeforeFeature","BeforeRule","BeforeScenarioOutline","Feature","Given","Rule","Scenario","ScenarioOutline","Setup","Teardown","Then","When","listener","Feature","Scenario","ScenarioOutline","Rule","Given","When","Then","Before","After","Teardown","Setup","BeforeFeature","AfterFeature","BeforeScenarioOutline","AfterScenarioOutline","BeforeExamples","AfterExamples","BeforeRule","AfterRule"]}
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/config.ts","../../src/parameters.ts","../../src/scopes.ts","../../src/events.ts","../../src/event-logger.ts","../../src/executor.ts","../../src/app.ts"],"sourcesContent":["import type {\n FeatureAction,\n FeatureScope,\n ScenarioAction,\n ScenarioScope,\n SizedTimeout,\n TestTimeout,\n} from \"@autometa/scopes\";\n\nexport { defineConfig } from \"./config\";\nexport { defineParameterType } from \"./parameters\";\nimport {\n Feature as FeatureDefinition,\n Scenario as ScenarioDefinition,\n ScenarioOutline as ScenarioOutlineDefinition,\n Rule as RuleDefinition,\n Given as GivenDefinition,\n When as WhenDefinition,\n Then as ThenDefinition,\n Before as BeforeDefinition,\n After as AfterDefinition,\n Teardown as TeardownDefinition,\n Setup as SetupDefinition,\n BeforeFeature as BeforeFeatureDefinition,\n AfterFeature as AfterFeatureDefinition,\n BeforeScenarioOutline as BeforeScenarioOutlineDefinition,\n AfterScenarioOutline as AfterScenarioOutlineDefinition,\n BeforeExamples as BeforeExamplesDefinition,\n AfterExamples as AfterExamplesDefinition,\n BeforeRule as BeforeRuleDefinition,\n AfterRule as AfterRuleDefinition,\n} from \"./scopes\";\nimport { RuleAction } from \"@autometa/scopes\";\nimport { RuleScope } from \"@autometa/scopes\";\nexport { Pass } from \"./scopes\";\nexport * from \"@autometa/phrases\";\nexport {\n AppType,\n Fixture,\n Container,\n Constructor,\n AutometaApp,\n getApp,\n AutometaWorld,\n App,\n World,\n INJECTION_SCOPE,\n InjectionScope,\n Inject,\n DisposeTagFilter,\n DisposeMethod,\n} from \"./app\";\nexport { Dates, Time } from \"@autometa/datetime\";\nexport { AutomationError, raise } from \"@autometa/errors\";\nexport {\n DataTable,\n HTable,\n VTable,\n MTable,\n TableDocument,\n} from \"@autometa/gherkin\";\nexport { Bind } from \"@autometa/bind-decorator\";\nexport { Types } from \"@autometa/scopes\";\nexport * from \"./events\";\nexport * from \"@autometa/http\";\nexport * from \"@autometa/asserters\";\nexport {\n GetAccessedCount,\n GetAssignedValues,\n TrackAccess,\n} from \"@autometa/fixture-proxies\";\n\nexport { FileObject } from \"@autometa/file-proxies\";\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n *\n * ``ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n *\n * Feature('../features/my-feature.feature')\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * }\n * ```\n *\n * Global steps are defined in standard Cucumber stle.\n * ```ts\n * // ./test/steps/my-steps.ts\n * import { Given, When, Then } from '@autometa/runner'\n *\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * ```\n * @param filepath The absolute, relative, or 'feature root' path to the `.feature` file.\n */\nexport function Feature(filepath: string): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n * Accepts a timeout in milliseconds which will be applied to\n * all tests within the feature.\n *\n * ```ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n * // 10 second timeout\n * Feature('../features/my-feature.feature', 10_000)\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * }\n * ```\n *\n * Global steps are defined in standard Cucumber style.\n *\n * ```ts\n * // ./test/steps/my-steps.ts\n * import { Given, When, Then } from '@autometa/runner'\n *\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * ```\n * @param filepath The absolute, relative, or 'feature root' path to the `.feature` file.\n * @param timeout The timeout in milliseconds to apply to all tests within the feature.\n */\nexport function Feature(filepath: string, timeout: number): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n * Accepts a timeout as a `TestTimeout` which is a tuple of `[durationNumber, 'ms' | 's' | 'm' | 'h']`\n * which will be applied to all tests within the feature.\n *\n * i.e. `[10, 's']` is a 10 second timeout. `[1, 'm']` is a 1 minute timeout.\n *\n * ```ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n *\n * // 10 second timeout\n * Feature('../features/my-feature.feature', [10, 's'])\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * };\n *\n * ```\n *\n * @param filepath\n * @param timeout\n */\nexport function Feature(filepath: string, timeout: TestTimeout): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and optionally locally defined steps,\n * mixed with optionally globally defined Step Definitions.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * })\n * ```\n *\n * If defined in the Gherkin, it will also use any Globally defined Step Definitions which match,\n * if none is defined locally. If a Step Definition is defined both globally and locally,\n * the most local definition will be used. This applies to sub-scopes like Scenarios and Rules\n * also.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n *\n * Scenario('My Scenario', () => {\n * Given('I have a step', () => {})\n * })\n *\n * Rule('My Rule', () => {\n * Given('I have a step', () => {})\n * })\n *\n * @param testDefinition\n * @param filepath\n */\nexport function Feature(\n testDefinition: FeatureAction,\n filepath: string\n): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and optionally locally defined steps,\n * mixed with optionally globally defined Step Definitions.\n * Accepts a timeout in milliseconds which will be applied to\n * all tests within the feature.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * // 10 second timeout\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * }, 10_000)\n * ```\n * @param testDefinition the Feature definition callback\n * @param filepath\n * @param timeout\n */\nexport function Feature(\n testDefinition: FeatureAction,\n filepath: string,\n timeout: number\n): FeatureScope;\nexport function Feature(\n ...args: (FeatureAction | string | TestTimeout)[]\n): FeatureScope {\n return FeatureDefinition(...args);\n}\n\nexport function Scenario(title: string, action: ScenarioAction): ScenarioScope;\nexport function Scenario(\n title: string,\n action: ScenarioAction,\n timeout: number\n): ScenarioScope;\nexport function Scenario(\n title: string,\n action: ScenarioAction,\n timeout: SizedTimeout\n): ScenarioScope;\nexport function Scenario(\n ...args: (string | ScenarioAction | SizedTimeout | number)[]\n): ScenarioScope {\n return ScenarioDefinition(...args);\n}\n\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction\n): ScenarioScope;\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction,\n timeout: number\n): ScenarioScope;\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction,\n timeout: SizedTimeout\n): ScenarioScope;\nexport function ScenarioOutline(\n ...args: (string | ScenarioAction | SizedTimeout | number)[]\n): ScenarioScope {\n return ScenarioOutlineDefinition(...args);\n}\n\nexport function Rule(title: string, action: RuleAction): RuleScope;\nexport function Rule(\n title: string,\n action: RuleAction,\n timeout: number\n): RuleScope;\nexport function Rule(\n title: string,\n action: RuleAction,\n timeout: SizedTimeout\n): RuleScope;\nexport function Rule(\n ...args: (string | RuleAction | SizedTimeout | number)[]\n): RuleScope {\n return RuleDefinition(...args);\n}\n/**\n * Defines a `Given` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n * the context of a scenario, but cannot be accessed from the same step in a different\n * scenario.\n *\n * ```ts\n * import { Given } from '@autometa/runner'\n *\n * Given('I have a step', (app) => {\n * app.world.someData = 'some value'\n * })\n * // using destructuring\n * Given('I have a step', ({ world }) => {\n * world.someData = 'some value'\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { Given } from '@autometa/runner'\n *\n * // matches 'Given I have a step with a 'blue' value'\n * Given('I have a step with a {string} value', (value, { world }) => {\n * world.someData = value\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const Given = GivenDefinition;\n/**\n * Defines a `When` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n *\n * ```ts\n * import { When } from '@autometa/runner'\n *\n * When('I do something', async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * When('I do something', async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { When } from '@autometa/runner'\n *\n * // matches 'When I do something with a 'blue' value'\n * When('I do something with a {string} value', async (value, { webdriver }) => {\n * await webdriver.click(`#some-button-${value}`)\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const When = WhenDefinition;\n\n/**\n * Defines a `Then` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n *\n * ```ts\n * import { Then } from '@autometa/runner'\n *\n * Then('I expect something', async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Then('I expect something', async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { Then } from '@autometa/runner'\n *\n * // matches 'Then I expect something with a 'blue' value'\n * Then('I expect something with a {string} value', async (value, { world }) => {\n * expect(world.someData).toBe(value)\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const Then = ThenDefinition;\n\n/**\n * Defines a `Before` hook. Executes before each scenario.\n *\n * ```ts\n * import { Before } from '@autometa/runner'\n *\n * Before(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Before(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Before = BeforeDefinition;\n\n/**\n * Defines a `After` hook. Executes after each scenario.\n *\n * ```ts\n * import { After } from '@autometa/runner'\n *\n * After(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * After(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const After = AfterDefinition;\n\n/**\n * Defines a `Setup` hook. Executes before all scenarios.\n * Setups are scoped, meaning a Setup defined inside the scope of a rule\n * will only apply to scenarios within that rule.\n *\n * N.b the Setup Hook and Teardown Hook reference their own unique\n * copy of the App with it's own unique life cycle. Values stored here\n * will not be accessible in tests without a singleton fixture.\n *\n * ```ts\n * import { Setup } from '@autometa/runner'\n *\n * Setup(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Setup(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Teardown = TeardownDefinition;\n\n/**\n * Defines a `Teardown` hook. Executes after all scenarios have completed.\n * Teardowns are scoped, meaning a Teardown defined inside the scope of a rule\n * will only apply to scenarios within that rule.\n *\n * N.b the Setup Hook and Teardown Hook reference their own unique\n * copy of the App with it's own unique life cycle. Values stored here\n * will not be accessible in tests without a singleston fixture.\n * ```ts\n * import { Teardown } from '@autometa/runner'\n *\n * Teardown(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Teardown(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Setup = SetupDefinition;\n\n/**\n * Defines a `BeforeFeature` hook. Executes before each feature.\n *\n * ```ts\n * import { BeforeFeature } from '@autometa/runner'\n *\n * BeforeFeature(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeFeature(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const BeforeFeature = BeforeFeatureDefinition;\n\n/**\n * Defines a `AfterFeature` hook. Executes after each feature.\n *\n * ```ts\n * import { AfterFeature } from '@autometa/runner'\n *\n * AfterFeature(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterFeature(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const AfterFeature = AfterFeatureDefinition;\n\n/**\n * Defines a `BeforeScenarioOutline` hook. Executes before each scenario outline.\n *\n * ```ts\n * import { BeforeScenarioOutline } from '@autometa/runner'\n *\n * BeforeScenarioOutline(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeScenarioOutline(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const BeforeScenarioOutline = BeforeScenarioOutlineDefinition;\n\n/**\n * Defines a `AfterScenarioOutline` hook. Executes after each scenario outline.\n *\n * ```ts\n * import { AfterScenarioOutline } from '@autometa/runner'\n *\n * AfterScenarioOutline(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterScenarioOutline(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const AfterScenarioOutline = AfterScenarioOutlineDefinition;\n\n/**\n * Defines a `BeforeExamples` hook. Executes before each examples table.\n *\n * ```ts\n * import { BeforeExamples } from '@autometa/runner'\n *\n * BeforeExamples(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeExamples(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const BeforeExamples = BeforeExamplesDefinition;\n\n/**\n * Defines a `AfterExamples` hook. Executes after each examples table.\n *\n * ```ts\n * import { AfterExamples } from '@autometa/runner'\n *\n * AfterExamples(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterExamples(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const AfterExamples = AfterExamplesDefinition;\n\n/**\n * Defines a `BeforeRule` hook. Executes before each rule.\n *\n * ```ts\n * import { BeforeRule } from '@autometa/runner'\n *\n * BeforeRule(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeRule(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const BeforeRule = BeforeRuleDefinition;\n\n/**\n * Defines a `AfterRule` hook. Executes after each rule.\n *\n * ```ts\n * import { AfterRule } from '@autometa/runner'\n *\n * AfterRule(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterRule(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const AfterRule = AfterRuleDefinition;\n","import {\n Config,\n TestExecutorConfig,\n defineConfig as dc,\n} from \"@autometa/config\";\n\nexport const CONFIG = new Config(new Map<string, TestExecutorConfig>());\nexport const defineConfig = dc.bind(null, CONFIG);\n","import { ParameterTypeRegistry } from \"@cucumber/cucumber-expressions\";\nimport {\n BooleanParam,\n DateParam,\n NumberParam,\n PrimitiveParam,\n OrdinalParam,\n TextParam,\n defineParameterType as dpt,\n} from \"@autometa/cucumber-expressions\";\n\nexport const PARAM_REGISTRY = new ParameterTypeRegistry();\n\n/**\n * Defines a parameter type for use in step definitions.\n *\n * ```ts\n * import { Color } from '../support/color';\n *\n * defineParameterType({\n * name: \"color\",\n * regex: /red|blue|yellow/,\n * transform: (value: string) => Color(value)\n * })\n *\n * // using regex arrays\n * defineParameterType({\n * name: \"color\",\n * regex: [/red/, /blue/, /yellow/],\n * transform: (value: string) => Color(value)\n * })\n * ```\n */\nexport const defineParameterType = dpt.bind(null, PARAM_REGISTRY);\n\ndefineParameterType(\n NumberParam,\n BooleanParam,\n PrimitiveParam,\n TextParam,\n DateParam,\n OrdinalParam\n);\n","import { PARAM_REGISTRY } from \"./parameters\";\nimport { GetCucumberFunctions, Pass } from \"@autometa/scopes\";\nimport { Coordinator } from \"@autometa/coordinator\";\nimport { CONFIG } from \"./config\";\nimport { makeTestEmitter } from \"./events\";\nimport { executor } from \"./executor\";\nimport { OPTS } from \"./app\";\nconst {\n BeforeFeature,\n AfterFeature,\n BeforeScenarioOutline,\n AfterScenarioOutline,\n BeforeExamples,\n AfterExamples,\n BeforeRule,\n AfterRule,\n Feature,\n Scenario,\n ScenarioOutline,\n Rule,\n Given,\n When,\n Then,\n Before,\n After,\n Teardown,\n Setup,\n Global,\n} = GetCucumberFunctions(PARAM_REGISTRY);\nconst coordinator = new Coordinator(Global, CONFIG, OPTS);\nGlobal.onFeatureExecuted = (feature, caller) => {\n const groupLogger = CONFIG.current.test?.groupLogging ?? false;\n const events = makeTestEmitter({ groupLogger });\n coordinator.run(feature, caller, events, executor);\n};\n\nexport {\n Feature,\n Scenario,\n ScenarioOutline,\n Rule,\n Given,\n When,\n Then,\n Before,\n After,\n Teardown,\n Setup,\n BeforeFeature,\n AfterFeature,\n BeforeScenarioOutline,\n AfterScenarioOutline,\n BeforeExamples,\n AfterExamples,\n BeforeRule,\n AfterRule,\n Pass,\n};\n","import { TestEventEmitter } from \"@autometa/events\";\nimport { CONFIG } from \"./config\";\nexport * from \"@autometa/events\";\nimport { GroupLogEvents } from \"./event-logger\";\nimport p from \"path\";\nexport function makeTestEmitter(opts: { groupLogger: boolean }) {\n const events = CONFIG.current.events;\n const emitter = new TestEventEmitter();\n if (opts.groupLogger) {\n emitter.load(new GroupLogEvents());\n }\n if (!events) {\n return emitter;\n }\n\n for (const event of events) {\n const isLocal = isRelativePath(event) || isAbsolutePath(event);\n if (isLocal) {\n const uriRoot = process.cwd();\n const uri = p.join(uriRoot, event);\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const listener = require(uri);\n if (\"default\" in listener && typeof listener.default === \"function\") {\n emitter.load(new listener.default());\n return emitter;\n }\n if (\"default\" in listener && typeof listener.default === \"object\") {\n emitter.load(listener.default);\n return emitter;\n }\n if (typeof listener === \"function\") {\n emitter.load(new listener());\n return emitter;\n }\n emitter.load(listener);\n return emitter;\n }\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const listener = require(event);\n if (\"default\" in listener) {\n emitter.load(listener.default);\n return emitter;\n }\n emitter.load(listener);\n return emitter;\n }\n\n return emitter;\n}\n\nfunction isRelativePath(path: string) {\n return path.startsWith(\".\");\n}\n\nfunction isAbsolutePath(path: string) {\n return p.isAbsolute(path);\n}\n","import {\n EndAfterOpts,\n EndBeforeOpts,\n EndFeatureOpts,\n EndRuleOpts,\n EndScenarioOpts,\n EndScenarioOutlineOpts,\n EndSetupOpts,\n EndStepOpts,\n EndTeardownOpts,\n EventSubscriber,\n StartAfterOpts,\n StartBeforeOpts,\n StartFeatureOpts,\n StartRuleOpts,\n StartScenarioOpts,\n StartScenarioOutlineOpts,\n StartSetupOpts,\n StartStepOpts,\n StartTeardownOpts,\n} from \"@autometa/events\";\nimport colors from \"colors-cli\";\nexport class GroupLogEvents implements EventSubscriber {\n onFeatureStart({ title }: StartFeatureOpts) {\n console.group(title);\n console.group();\n }\n onFeatureEnd({ title, status }: EndFeatureOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onScenarioStart({ title }: StartScenarioOpts): void {\n console.group(title);\n console.group();\n }\n onScenarioEnd({ title, status }: EndScenarioOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onScenarioOutlineStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n onScenarioOutlineEnd({ title, status }: EndScenarioOutlineOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onRuleStart({ title }: StartRuleOpts): void {\n console.group(title);\n console.group();\n }\n onRuleEnd({ title, status }: EndRuleOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onStepStart({ title }: StartStepOpts) {\n console.group(title);\n console.group();\n }\n onStepEnd({ title, status }: EndStepOpts) {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onBeforeStart({ title, status }: StartBeforeOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onBeforeEnd({ title, status }: EndBeforeOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onAfterStart({ title, status }: StartAfterOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onAfterEnd({ title, status }: EndAfterOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onTeardownStart({ title, status }: StartTeardownOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onTeardownEnd({ title, status }: EndTeardownOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onSetupStart({ title, status }: StartSetupOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onSetupEnd({ title, status }: EndSetupOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onBeforeFeatureStart(opts: StartFeatureOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeFeatureEnd(opts: EndFeatureOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onAfterFeatureStart(opts: StartFeatureOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterFeatureEnd(opts: EndFeatureOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onBeforeRuleStart(opts: StartRuleOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeRuleEnd(opts: EndRuleOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onAfterRuleStart(opts: StartRuleOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterRuleEnd(opts: EndRuleOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onBeforeScenarioOutlineStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeScenarioOutlineEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onBeforeExamplesStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeExamplesEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onAfterExamplesStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterExamplesEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n}\nfunction colorStatus(\n status: \"FAILED\" | \"PASSED\" | \"SKIPPED\" | \"BROKEN\" | undefined,\n text: string\n) {\n switch (status) {\n case \"FAILED\":\n return `${colors.red(\"x\")} ${text}`;\n case \"PASSED\":\n return `${colors.green(\"✔️\")} ${text}`;\n case \"SKIPPED\":\n return `${colors.yellow(\"⊘\")} ${text}`;\n default:\n return text;\n }\n}\n","import { execute } from \"@autometa/jest-executor\";\n\nexport const executor = execute;\n","import \"@autometa/types\";\nimport { AppType as at } from \"@autometa/app\";\nimport { CoordinatorOpts } from \"@autometa/coordinator\";\nexport { AutometaApp, AutometaWorld, App, World } from \"@autometa/app\";\nexport {\n Fixture,\n INJECTION_SCOPE,\n InjectionScope,\n Token,\n Container,\n Constructor,\n Inject,\n} from \"@autometa/injection\";\nexport const OPTS = {} as Record<string, CoordinatorOpts>;\n/**\n * Marks a class as being the `App` of the test framework. The `App` is the\n * entry point for the test framework. The App will be made available as the final\n * argument in the Step Definition Callbacks.\n *\n * ```ts\n *\n * @AppType(World)\n * @Constructor(MyClient)\n * class App {\n * constructor(readonly myCLient: MyClient) {}\n * }\n * ```\n * Or with tokens\n *\n * ```ts\n * import from \"@autometa/runner\";\n * import { World } from \"./default.world\";\n * @AppType(World)\n * @Constructor(HTTP, Token(\"MyClient\"))\n * class App {\n * constructor(readonly http: HTTP, readonly myClient: MyClient) {}\n * }\n * ```\n */\nexport const AppType = at.bind(null, OPTS);\nexport { getApp } from \"@autometa/app\";\nexport { DisposeMethod, DisposeTagFilter } from \"@autometa/injection\";\n"],"mappings":"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","names":["After","AfterExamples","AfterFeature","AfterRule","AfterScenarioOutline","Before","BeforeExamples","BeforeFeature","BeforeRule","BeforeScenarioOutline","Feature","Given","Rule","Scenario","ScenarioOutline","Setup","Teardown","Then","When","listener","Feature","Scenario","ScenarioOutline","Rule","Given","When","Then","Before","After","Teardown","Setup","BeforeFeature","AfterFeature","BeforeScenarioOutline","AfterScenarioOutline","BeforeExamples","AfterExamples","BeforeRule","AfterRule"]}
|
package/dist/index.d.cts
CHANGED
|
@@ -18,7 +18,7 @@ export * from '@autometa/http';
|
|
|
18
18
|
export * from '@autometa/asserters';
|
|
19
19
|
export { GetAccessedCount, GetAssignedValues, TrackAccess } from '@autometa/fixture-proxies';
|
|
20
20
|
export { FileObject } from '@autometa/file-proxies';
|
|
21
|
-
export { Constructor, Container, Fixture, INJECTION_SCOPE, Inject, InjectionScope } from '@autometa/injection';
|
|
21
|
+
export { Constructor, Container, DisposeMethod, DisposeTagFilter, Fixture, INJECTION_SCOPE, Inject, InjectionScope } from '@autometa/injection';
|
|
22
22
|
|
|
23
23
|
declare const defineConfig: (...args: {
|
|
24
24
|
runner: "jest" | "vitest";
|
package/dist/index.d.ts
CHANGED
|
@@ -18,7 +18,7 @@ export * from '@autometa/http';
|
|
|
18
18
|
export * from '@autometa/asserters';
|
|
19
19
|
export { GetAccessedCount, GetAssignedValues, TrackAccess } from '@autometa/fixture-proxies';
|
|
20
20
|
export { FileObject } from '@autometa/file-proxies';
|
|
21
|
-
export { Constructor, Container, Fixture, INJECTION_SCOPE, Inject, InjectionScope } from '@autometa/injection';
|
|
21
|
+
export { Constructor, Container, DisposeMethod, DisposeTagFilter, Fixture, INJECTION_SCOPE, Inject, InjectionScope } from '@autometa/injection';
|
|
22
22
|
|
|
23
23
|
declare const defineConfig: (...args: {
|
|
24
24
|
runner: "jest" | "vitest";
|
package/dist/index.js
CHANGED
|
@@ -51,6 +51,8 @@ __export(src_exports, {
|
|
|
51
51
|
Container: () => import_injection.Container,
|
|
52
52
|
DataTable: () => import_gherkin.DataTable,
|
|
53
53
|
Dates: () => import_datetime.Dates,
|
|
54
|
+
DisposeMethod: () => import_injection2.DisposeMethod,
|
|
55
|
+
DisposeTagFilter: () => import_injection2.DisposeTagFilter,
|
|
54
56
|
Feature: () => Feature2,
|
|
55
57
|
FileObject: () => import_file_proxies.FileObject,
|
|
56
58
|
Fixture: () => import_injection.Fixture,
|
|
@@ -124,8 +126,8 @@ var GroupLogEvents = class {
|
|
|
124
126
|
}
|
|
125
127
|
onFeatureEnd({ title, status }) {
|
|
126
128
|
console.groupEnd();
|
|
127
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
128
129
|
console.groupEnd();
|
|
130
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
129
131
|
}
|
|
130
132
|
onScenarioStart({ title }) {
|
|
131
133
|
console.group(title);
|
|
@@ -133,8 +135,8 @@ var GroupLogEvents = class {
|
|
|
133
135
|
}
|
|
134
136
|
onScenarioEnd({ title, status }) {
|
|
135
137
|
console.groupEnd();
|
|
136
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
137
138
|
console.groupEnd();
|
|
139
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
138
140
|
}
|
|
139
141
|
onScenarioOutlineStart(opts) {
|
|
140
142
|
console.group(opts.title);
|
|
@@ -142,8 +144,8 @@ var GroupLogEvents = class {
|
|
|
142
144
|
}
|
|
143
145
|
onScenarioOutlineEnd({ title, status }) {
|
|
144
146
|
console.groupEnd();
|
|
145
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
146
147
|
console.groupEnd();
|
|
148
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
147
149
|
}
|
|
148
150
|
onRuleStart({ title }) {
|
|
149
151
|
console.group(title);
|
|
@@ -151,8 +153,8 @@ var GroupLogEvents = class {
|
|
|
151
153
|
}
|
|
152
154
|
onRuleEnd({ title, status }) {
|
|
153
155
|
console.groupEnd();
|
|
154
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
155
156
|
console.groupEnd();
|
|
157
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
156
158
|
}
|
|
157
159
|
onStepStart({ title }) {
|
|
158
160
|
console.group(title);
|
|
@@ -160,8 +162,8 @@ var GroupLogEvents = class {
|
|
|
160
162
|
}
|
|
161
163
|
onStepEnd({ title, status }) {
|
|
162
164
|
console.groupEnd();
|
|
163
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
164
165
|
console.groupEnd();
|
|
166
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
165
167
|
}
|
|
166
168
|
onBeforeStart({ title, status }) {
|
|
167
169
|
if (status === "SKIPPED") {
|
|
@@ -175,8 +177,8 @@ var GroupLogEvents = class {
|
|
|
175
177
|
return;
|
|
176
178
|
}
|
|
177
179
|
console.groupEnd();
|
|
178
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
179
180
|
console.groupEnd();
|
|
181
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
180
182
|
}
|
|
181
183
|
onAfterStart({ title, status }) {
|
|
182
184
|
if (status === "SKIPPED") {
|
|
@@ -190,8 +192,8 @@ var GroupLogEvents = class {
|
|
|
190
192
|
return;
|
|
191
193
|
}
|
|
192
194
|
console.groupEnd();
|
|
193
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
194
195
|
console.groupEnd();
|
|
196
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
195
197
|
}
|
|
196
198
|
onTeardownStart({ title, status }) {
|
|
197
199
|
if (status === "SKIPPED") {
|
|
@@ -205,8 +207,8 @@ var GroupLogEvents = class {
|
|
|
205
207
|
return;
|
|
206
208
|
}
|
|
207
209
|
console.groupEnd();
|
|
208
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
209
210
|
console.groupEnd();
|
|
211
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
210
212
|
}
|
|
211
213
|
onSetupStart({ title, status }) {
|
|
212
214
|
if (status === "SKIPPED") {
|
|
@@ -220,8 +222,8 @@ var GroupLogEvents = class {
|
|
|
220
222
|
return;
|
|
221
223
|
}
|
|
222
224
|
console.groupEnd();
|
|
223
|
-
console.log(colorStatus(status, `Ending ${title}`));
|
|
224
225
|
console.groupEnd();
|
|
226
|
+
console.log(colorStatus(status, `Ending ${title}`));
|
|
225
227
|
}
|
|
226
228
|
onBeforeFeatureStart(opts) {
|
|
227
229
|
console.group(opts.title);
|
|
@@ -229,8 +231,8 @@ var GroupLogEvents = class {
|
|
|
229
231
|
}
|
|
230
232
|
onBeforeFeatureEnd(opts) {
|
|
231
233
|
console.groupEnd();
|
|
232
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
233
234
|
console.groupEnd();
|
|
235
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
234
236
|
}
|
|
235
237
|
onAfterFeatureStart(opts) {
|
|
236
238
|
console.group(opts.title);
|
|
@@ -238,8 +240,8 @@ var GroupLogEvents = class {
|
|
|
238
240
|
}
|
|
239
241
|
onAfterFeatureEnd(opts) {
|
|
240
242
|
console.groupEnd();
|
|
241
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
242
243
|
console.groupEnd();
|
|
244
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
243
245
|
}
|
|
244
246
|
onBeforeRuleStart(opts) {
|
|
245
247
|
console.group(opts.title);
|
|
@@ -247,8 +249,8 @@ var GroupLogEvents = class {
|
|
|
247
249
|
}
|
|
248
250
|
onBeforeRuleEnd(opts) {
|
|
249
251
|
console.groupEnd();
|
|
250
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
251
252
|
console.groupEnd();
|
|
253
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
252
254
|
}
|
|
253
255
|
onAfterRuleStart(opts) {
|
|
254
256
|
console.group(opts.title);
|
|
@@ -256,8 +258,8 @@ var GroupLogEvents = class {
|
|
|
256
258
|
}
|
|
257
259
|
onAfterRuleEnd(opts) {
|
|
258
260
|
console.groupEnd();
|
|
259
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
260
261
|
console.groupEnd();
|
|
262
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
261
263
|
}
|
|
262
264
|
onBeforeScenarioOutlineStart(opts) {
|
|
263
265
|
console.group(opts.title);
|
|
@@ -265,8 +267,8 @@ var GroupLogEvents = class {
|
|
|
265
267
|
}
|
|
266
268
|
onBeforeScenarioOutlineEnd(opts) {
|
|
267
269
|
console.groupEnd();
|
|
268
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
269
270
|
console.groupEnd();
|
|
271
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
270
272
|
}
|
|
271
273
|
onBeforeExamplesStart(opts) {
|
|
272
274
|
console.group(opts.title);
|
|
@@ -274,8 +276,8 @@ var GroupLogEvents = class {
|
|
|
274
276
|
}
|
|
275
277
|
onBeforeExamplesEnd(opts) {
|
|
276
278
|
console.groupEnd();
|
|
277
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
278
279
|
console.groupEnd();
|
|
280
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
279
281
|
}
|
|
280
282
|
onAfterExamplesStart(opts) {
|
|
281
283
|
console.group(opts.title);
|
|
@@ -283,8 +285,8 @@ var GroupLogEvents = class {
|
|
|
283
285
|
}
|
|
284
286
|
onAfterExamplesEnd(opts) {
|
|
285
287
|
console.groupEnd();
|
|
286
|
-
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
287
288
|
console.groupEnd();
|
|
289
|
+
console.log(colorStatus(opts.status, `Ending ${opts.title}`));
|
|
288
290
|
}
|
|
289
291
|
};
|
|
290
292
|
function colorStatus(status, text) {
|
|
@@ -454,6 +456,8 @@ var AfterRule2 = AfterRule;
|
|
|
454
456
|
Container,
|
|
455
457
|
DataTable,
|
|
456
458
|
Dates,
|
|
459
|
+
DisposeMethod,
|
|
460
|
+
DisposeTagFilter,
|
|
457
461
|
Feature,
|
|
458
462
|
FileObject,
|
|
459
463
|
Fixture,
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/config.ts","../src/parameters.ts","../src/scopes.ts","../src/events.ts","../src/event-logger.ts","../src/executor.ts","../src/app.ts"],"sourcesContent":["import type {\n FeatureAction,\n FeatureScope,\n ScenarioAction,\n ScenarioScope,\n SizedTimeout,\n TestTimeout,\n} from \"@autometa/scopes\";\n\nexport { defineConfig } from \"./config\";\nexport { defineParameterType } from \"./parameters\";\nimport {\n Feature as FeatureDefinition,\n Scenario as ScenarioDefinition,\n ScenarioOutline as ScenarioOutlineDefinition,\n Rule as RuleDefinition,\n Given as GivenDefinition,\n When as WhenDefinition,\n Then as ThenDefinition,\n Before as BeforeDefinition,\n After as AfterDefinition,\n Teardown as TeardownDefinition,\n Setup as SetupDefinition,\n BeforeFeature as BeforeFeatureDefinition,\n AfterFeature as AfterFeatureDefinition,\n BeforeScenarioOutline as BeforeScenarioOutlineDefinition,\n AfterScenarioOutline as AfterScenarioOutlineDefinition,\n BeforeExamples as BeforeExamplesDefinition,\n AfterExamples as AfterExamplesDefinition,\n BeforeRule as BeforeRuleDefinition,\n AfterRule as AfterRuleDefinition,\n} from \"./scopes\";\nimport { RuleAction } from \"@autometa/scopes\";\nimport { RuleScope } from \"@autometa/scopes\";\nexport { Pass } from \"./scopes\";\nexport * from \"@autometa/phrases\";\nexport {\n AppType,\n Fixture,\n Container,\n Constructor,\n AutometaApp,\n getApp,\n AutometaWorld,\n App,\n World,\n INJECTION_SCOPE,\n InjectionScope,\n Inject,\n} from \"./app\";\nexport { Dates, Time } from \"@autometa/datetime\";\nexport { AutomationError, raise } from \"@autometa/errors\";\nexport {\n DataTable,\n HTable,\n VTable,\n MTable,\n TableDocument,\n} from \"@autometa/gherkin\";\nexport { Bind } from \"@autometa/bind-decorator\";\nexport { Types } from \"@autometa/scopes\";\nexport * from \"./events\";\nexport * from \"@autometa/http\";\nexport * from \"@autometa/asserters\";\nexport {\n GetAccessedCount,\n GetAssignedValues,\n TrackAccess,\n} from \"@autometa/fixture-proxies\";\n\nexport { FileObject } from \"@autometa/file-proxies\";\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n *\n * ``ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n *\n * Feature('../features/my-feature.feature')\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * }\n * ```\n *\n * Global steps are defined in standard Cucumber stle.\n * ```ts\n * // ./test/steps/my-steps.ts\n * import { Given, When, Then } from '@autometa/runner'\n *\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * ```\n * @param filepath The absolute, relative, or 'feature root' path to the `.feature` file.\n */\nexport function Feature(filepath: string): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n * Accepts a timeout in milliseconds which will be applied to\n * all tests within the feature.\n *\n * ```ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n * // 10 second timeout\n * Feature('../features/my-feature.feature', 10_000)\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * }\n * ```\n *\n * Global steps are defined in standard Cucumber style.\n *\n * ```ts\n * // ./test/steps/my-steps.ts\n * import { Given, When, Then } from '@autometa/runner'\n *\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * ```\n * @param filepath The absolute, relative, or 'feature root' path to the `.feature` file.\n * @param timeout The timeout in milliseconds to apply to all tests within the feature.\n */\nexport function Feature(filepath: string, timeout: number): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n * Accepts a timeout as a `TestTimeout` which is a tuple of `[durationNumber, 'ms' | 's' | 'm' | 'h']`\n * which will be applied to all tests within the feature.\n *\n * i.e. `[10, 's']` is a 10 second timeout. `[1, 'm']` is a 1 minute timeout.\n *\n * ```ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n *\n * // 10 second timeout\n * Feature('../features/my-feature.feature', [10, 's'])\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * };\n *\n * ```\n *\n * @param filepath\n * @param timeout\n */\nexport function Feature(filepath: string, timeout: TestTimeout): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and optionally locally defined steps,\n * mixed with optionally globally defined Step Definitions.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * })\n * ```\n *\n * If defined in the Gherkin, it will also use any Globally defined Step Definitions which match,\n * if none is defined locally. If a Step Definition is defined both globally and locally,\n * the most local definition will be used. This applies to sub-scopes like Scenarios and Rules\n * also.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n *\n * Scenario('My Scenario', () => {\n * Given('I have a step', () => {})\n * })\n *\n * Rule('My Rule', () => {\n * Given('I have a step', () => {})\n * })\n *\n * @param testDefinition\n * @param filepath\n */\nexport function Feature(\n testDefinition: FeatureAction,\n filepath: string\n): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and optionally locally defined steps,\n * mixed with optionally globally defined Step Definitions.\n * Accepts a timeout in milliseconds which will be applied to\n * all tests within the feature.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * // 10 second timeout\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * }, 10_000)\n * ```\n * @param testDefinition the Feature definition callback\n * @param filepath\n * @param timeout\n */\nexport function Feature(\n testDefinition: FeatureAction,\n filepath: string,\n timeout: number\n): FeatureScope;\nexport function Feature(\n ...args: (FeatureAction | string | TestTimeout)[]\n): FeatureScope {\n return FeatureDefinition(...args);\n}\n\nexport function Scenario(title: string, action: ScenarioAction): ScenarioScope;\nexport function Scenario(\n title: string,\n action: ScenarioAction,\n timeout: number\n): ScenarioScope;\nexport function Scenario(\n title: string,\n action: ScenarioAction,\n timeout: SizedTimeout\n): ScenarioScope;\nexport function Scenario(\n ...args: (string | ScenarioAction | SizedTimeout | number)[]\n): ScenarioScope {\n return ScenarioDefinition(...args);\n}\n\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction\n): ScenarioScope;\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction,\n timeout: number\n): ScenarioScope;\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction,\n timeout: SizedTimeout\n): ScenarioScope;\nexport function ScenarioOutline(\n ...args: (string | ScenarioAction | SizedTimeout | number)[]\n): ScenarioScope {\n return ScenarioOutlineDefinition(...args);\n}\n\nexport function Rule(title: string, action: RuleAction): RuleScope;\nexport function Rule(\n title: string,\n action: RuleAction,\n timeout: number\n): RuleScope;\nexport function Rule(\n title: string,\n action: RuleAction,\n timeout: SizedTimeout\n): RuleScope;\nexport function Rule(\n ...args: (string | RuleAction | SizedTimeout | number)[]\n): RuleScope {\n return RuleDefinition(...args);\n}\n/**\n * Defines a `Given` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n * the context of a scenario, but cannot be accessed from the same step in a different\n * scenario.\n *\n * ```ts\n * import { Given } from '@autometa/runner'\n *\n * Given('I have a step', (app) => {\n * app.world.someData = 'some value'\n * })\n * // using destructuring\n * Given('I have a step', ({ world }) => {\n * world.someData = 'some value'\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { Given } from '@autometa/runner'\n *\n * // matches 'Given I have a step with a 'blue' value'\n * Given('I have a step with a {string} value', (value, { world }) => {\n * world.someData = value\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const Given = GivenDefinition;\n/**\n * Defines a `When` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n *\n * ```ts\n * import { When } from '@autometa/runner'\n *\n * When('I do something', async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * When('I do something', async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { When } from '@autometa/runner'\n *\n * // matches 'When I do something with a 'blue' value'\n * When('I do something with a {string} value', async (value, { webdriver }) => {\n * await webdriver.click(`#some-button-${value}`)\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const When = WhenDefinition;\n\n/**\n * Defines a `Then` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n *\n * ```ts\n * import { Then } from '@autometa/runner'\n *\n * Then('I expect something', async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Then('I expect something', async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { Then } from '@autometa/runner'\n *\n * // matches 'Then I expect something with a 'blue' value'\n * Then('I expect something with a {string} value', async (value, { world }) => {\n * expect(world.someData).toBe(value)\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const Then = ThenDefinition;\n\n/**\n * Defines a `Before` hook. Executes before each scenario.\n *\n * ```ts\n * import { Before } from '@autometa/runner'\n *\n * Before(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Before(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Before = BeforeDefinition;\n\n/**\n * Defines a `After` hook. Executes after each scenario.\n *\n * ```ts\n * import { After } from '@autometa/runner'\n *\n * After(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * After(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const After = AfterDefinition;\n\n/**\n * Defines a `Setup` hook. Executes before all scenarios.\n * Setups are scoped, meaning a Setup defined inside the scope of a rule\n * will only apply to scenarios within that rule.\n *\n * N.b the Setup Hook and Teardown Hook reference their own unique\n * copy of the App with it's own unique life cycle. Values stored here\n * will not be accessible in tests without a singleton fixture.\n *\n * ```ts\n * import { Setup } from '@autometa/runner'\n *\n * Setup(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Setup(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Teardown = TeardownDefinition;\n\n/**\n * Defines a `Teardown` hook. Executes after all scenarios have completed.\n * Teardowns are scoped, meaning a Teardown defined inside the scope of a rule\n * will only apply to scenarios within that rule.\n *\n * N.b the Setup Hook and Teardown Hook reference their own unique\n * copy of the App with it's own unique life cycle. Values stored here\n * will not be accessible in tests without a singleston fixture.\n * ```ts\n * import { Teardown } from '@autometa/runner'\n *\n * Teardown(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Teardown(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Setup = SetupDefinition;\n\n/**\n * Defines a `BeforeFeature` hook. Executes before each feature.\n *\n * ```ts\n * import { BeforeFeature } from '@autometa/runner'\n *\n * BeforeFeature(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeFeature(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const BeforeFeature = BeforeFeatureDefinition;\n\n/**\n * Defines a `AfterFeature` hook. Executes after each feature.\n *\n * ```ts\n * import { AfterFeature } from '@autometa/runner'\n *\n * AfterFeature(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterFeature(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const AfterFeature = AfterFeatureDefinition;\n\n/**\n * Defines a `BeforeScenarioOutline` hook. Executes before each scenario outline.\n *\n * ```ts\n * import { BeforeScenarioOutline } from '@autometa/runner'\n *\n * BeforeScenarioOutline(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeScenarioOutline(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const BeforeScenarioOutline = BeforeScenarioOutlineDefinition;\n\n/**\n * Defines a `AfterScenarioOutline` hook. Executes after each scenario outline.\n *\n * ```ts\n * import { AfterScenarioOutline } from '@autometa/runner'\n *\n * AfterScenarioOutline(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterScenarioOutline(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const AfterScenarioOutline = AfterScenarioOutlineDefinition;\n\n/**\n * Defines a `BeforeExamples` hook. Executes before each examples table.\n *\n * ```ts\n * import { BeforeExamples } from '@autometa/runner'\n *\n * BeforeExamples(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeExamples(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const BeforeExamples = BeforeExamplesDefinition;\n\n/**\n * Defines a `AfterExamples` hook. Executes after each examples table.\n *\n * ```ts\n * import { AfterExamples } from '@autometa/runner'\n *\n * AfterExamples(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterExamples(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const AfterExamples = AfterExamplesDefinition;\n\n/**\n * Defines a `BeforeRule` hook. Executes before each rule.\n *\n * ```ts\n * import { BeforeRule } from '@autometa/runner'\n *\n * BeforeRule(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeRule(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const BeforeRule = BeforeRuleDefinition;\n\n/**\n * Defines a `AfterRule` hook. Executes after each rule.\n *\n * ```ts\n * import { AfterRule } from '@autometa/runner'\n *\n * AfterRule(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterRule(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const AfterRule = AfterRuleDefinition;\n","import {\n Config,\n TestExecutorConfig,\n defineConfig as dc,\n} from \"@autometa/config\";\n\nexport const CONFIG = new Config(new Map<string, TestExecutorConfig>());\nexport const defineConfig = dc.bind(null, CONFIG);\n","import { ParameterTypeRegistry } from \"@cucumber/cucumber-expressions\";\nimport {\n BooleanParam,\n DateParam,\n NumberParam,\n PrimitiveParam,\n OrdinalParam,\n TextParam,\n defineParameterType as dpt,\n} from \"@autometa/cucumber-expressions\";\n\nexport const PARAM_REGISTRY = new ParameterTypeRegistry();\n\n/**\n * Defines a parameter type for use in step definitions.\n *\n * ```ts\n * import { Color } from '../support/color';\n *\n * defineParameterType({\n * name: \"color\",\n * regex: /red|blue|yellow/,\n * transform: (value: string) => Color(value)\n * })\n *\n * // using regex arrays\n * defineParameterType({\n * name: \"color\",\n * regex: [/red/, /blue/, /yellow/],\n * transform: (value: string) => Color(value)\n * })\n * ```\n */\nexport const defineParameterType = dpt.bind(null, PARAM_REGISTRY);\n\ndefineParameterType(\n NumberParam,\n BooleanParam,\n PrimitiveParam,\n TextParam,\n DateParam,\n OrdinalParam\n);\n","import { PARAM_REGISTRY } from \"./parameters\";\nimport { GetCucumberFunctions, Pass } from \"@autometa/scopes\";\nimport { Coordinator } from \"@autometa/coordinator\";\nimport { CONFIG } from \"./config\";\nimport { makeTestEmitter } from \"./events\";\nimport { executor } from \"./executor\";\nimport { OPTS } from \"./app\";\nconst {\n BeforeFeature,\n AfterFeature,\n BeforeScenarioOutline,\n AfterScenarioOutline,\n BeforeExamples,\n AfterExamples,\n BeforeRule,\n AfterRule,\n Feature,\n Scenario,\n ScenarioOutline,\n Rule,\n Given,\n When,\n Then,\n Before,\n After,\n Teardown,\n Setup,\n Global,\n} = GetCucumberFunctions(PARAM_REGISTRY);\nconst coordinator = new Coordinator(Global, CONFIG, OPTS);\nGlobal.onFeatureExecuted = (feature, caller) => {\n const groupLogger = CONFIG.current.test?.groupLogging ?? false;\n const events = makeTestEmitter({ groupLogger });\n coordinator.run(feature, caller, events, executor);\n};\n\nexport {\n Feature,\n Scenario,\n ScenarioOutline,\n Rule,\n Given,\n When,\n Then,\n Before,\n After,\n Teardown,\n Setup,\n BeforeFeature,\n AfterFeature,\n BeforeScenarioOutline,\n AfterScenarioOutline,\n BeforeExamples,\n AfterExamples,\n BeforeRule,\n AfterRule,\n Pass,\n};\n","import { TestEventEmitter } from \"@autometa/events\";\nimport { CONFIG } from \"./config\";\nexport * from \"@autometa/events\";\nimport { GroupLogEvents } from \"./event-logger\";\nimport p from \"path\";\nexport function makeTestEmitter(opts: { groupLogger: boolean }) {\n const events = CONFIG.current.events;\n const emitter = new TestEventEmitter();\n if (opts.groupLogger) {\n emitter.load(new GroupLogEvents());\n }\n if (!events) {\n return emitter;\n }\n\n for (const event of events) {\n const isLocal = isRelativePath(event) || isAbsolutePath(event);\n if (isLocal) {\n const uriRoot = process.cwd();\n const uri = p.join(uriRoot, event);\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const listener = require(uri);\n if (\"default\" in listener && typeof listener.default === \"function\") {\n emitter.load(new listener.default());\n return emitter;\n }\n if (\"default\" in listener && typeof listener.default === \"object\") {\n emitter.load(listener.default);\n return emitter;\n }\n if (typeof listener === \"function\") {\n emitter.load(new listener());\n return emitter;\n }\n emitter.load(listener);\n return emitter;\n }\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const listener = require(event);\n if (\"default\" in listener) {\n emitter.load(listener.default);\n return emitter;\n }\n emitter.load(listener);\n return emitter;\n }\n\n return emitter;\n}\n\nfunction isRelativePath(path: string) {\n return path.startsWith(\".\");\n}\n\nfunction isAbsolutePath(path: string) {\n return p.isAbsolute(path);\n}\n","import {\n EndAfterOpts,\n EndBeforeOpts,\n EndFeatureOpts,\n EndRuleOpts,\n EndScenarioOpts,\n EndScenarioOutlineOpts,\n EndSetupOpts,\n EndStepOpts,\n EndTeardownOpts,\n EventSubscriber,\n StartAfterOpts,\n StartBeforeOpts,\n StartFeatureOpts,\n StartRuleOpts,\n StartScenarioOpts,\n StartScenarioOutlineOpts,\n StartSetupOpts,\n StartStepOpts,\n StartTeardownOpts,\n} from \"@autometa/events\";\nimport colors from \"colors-cli\";\nexport class GroupLogEvents implements EventSubscriber {\n onFeatureStart({ title }: StartFeatureOpts) {\n console.group(title);\n console.group();\n }\n onFeatureEnd({ title, status }: EndFeatureOpts): void {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onScenarioStart({ title }: StartScenarioOpts): void {\n console.group(title);\n console.group();\n }\n onScenarioEnd({ title, status }: EndScenarioOpts): void {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onScenarioOutlineStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n onScenarioOutlineEnd({ title, status }: EndScenarioOutlineOpts): void {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onRuleStart({ title }: StartRuleOpts): void {\n console.group(title);\n console.group();\n }\n onRuleEnd({ title, status }: EndRuleOpts): void {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onStepStart({ title }: StartStepOpts) {\n console.group(title);\n console.group();\n }\n onStepEnd({ title, status }: EndStepOpts) {\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onBeforeStart({ title, status }: StartBeforeOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onBeforeEnd({ title, status }: EndBeforeOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onAfterStart({ title, status }: StartAfterOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onAfterEnd({ title, status }: EndAfterOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onTeardownStart({ title, status }: StartTeardownOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onTeardownEnd({ title, status }: EndTeardownOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onSetupStart({ title, status }: StartSetupOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onSetupEnd({ title, status }: EndSetupOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n console.groupEnd();\n }\n onBeforeFeatureStart(opts: StartFeatureOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeFeatureEnd(opts: EndFeatureOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onAfterFeatureStart(opts: StartFeatureOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterFeatureEnd(opts: EndFeatureOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onBeforeRuleStart(opts: StartRuleOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeRuleEnd(opts: EndRuleOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onAfterRuleStart(opts: StartRuleOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterRuleEnd(opts: EndRuleOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onBeforeScenarioOutlineStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeScenarioOutlineEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onBeforeExamplesStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeExamplesEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n\n onAfterExamplesStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterExamplesEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n console.groupEnd();\n }\n}\nfunction colorStatus(\n status: \"FAILED\" | \"PASSED\" | \"SKIPPED\" | \"BROKEN\" | undefined,\n text: string\n) {\n switch (status) {\n case \"FAILED\":\n return `${colors.red(\"x\")} ${text}`;\n case \"PASSED\":\n return `${colors.green(\"✔️\")} ${text}`;\n case \"SKIPPED\":\n return `${colors.yellow(\"⊘\")} ${text}`;\n default:\n return text;\n }\n}\n","import { execute } from \"@autometa/jest-executor\";\n\nexport const executor = execute;\n","import \"@autometa/types\";\nimport { AppType as at } from \"@autometa/app\";\nimport { CoordinatorOpts } from \"@autometa/coordinator\";\nexport { AutometaApp, AutometaWorld, App, World } from \"@autometa/app\";\nexport {\n Fixture,\n INJECTION_SCOPE,\n InjectionScope,\n Token,\n Container,\n Constructor,\n Inject,\n} from \"@autometa/injection\";\nexport const OPTS = {} as Record<string, CoordinatorOpts>;\n/**\n * Marks a class as being the `App` of the test framework. The `App` is the\n * entry point for the test framework. The App will be made available as the final\n * argument in the Step Definition Callbacks.\n *\n * ```ts\n *\n * @AppType(World)\n * @Constructor(MyClient)\n * class App {\n * constructor(readonly myCLient: MyClient) {}\n * }\n * ```\n * Or with tokens\n *\n * ```ts\n * import from \"@autometa/runner\";\n * import { World } from \"./default.world\";\n * @AppType(World)\n * @Constructor(HTTP, Token(\"MyClient\"))\n * class App {\n * constructor(readonly http: HTTP, readonly myClient: MyClient) {}\n * }\n * ```\n */\nexport const AppType = at.bind(null, OPTS);\nexport { getApp } from \"@autometa/app\";\nexport { DisposeMethod } from \"@autometa/injection\";\n"],"mappings":"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","names":["After","AfterExamples","AfterFeature","AfterRule","AfterScenarioOutline","Before","BeforeExamples","BeforeFeature","BeforeRule","BeforeScenarioOutline","Feature","Given","Rule","Scenario","ScenarioOutline","Setup","Teardown","Then","When","dc","import_cucumber_expressions","dpt","colors","p","listener","import_app","import_injection","at","import_scopes","Feature","Scenario","ScenarioOutline","Rule","Given","When","Then","Before","After","Teardown","Setup","BeforeFeature","AfterFeature","BeforeScenarioOutline","AfterScenarioOutline","BeforeExamples","AfterExamples","BeforeRule","AfterRule"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/config.ts","../src/parameters.ts","../src/scopes.ts","../src/events.ts","../src/event-logger.ts","../src/executor.ts","../src/app.ts"],"sourcesContent":["import type {\n FeatureAction,\n FeatureScope,\n ScenarioAction,\n ScenarioScope,\n SizedTimeout,\n TestTimeout,\n} from \"@autometa/scopes\";\n\nexport { defineConfig } from \"./config\";\nexport { defineParameterType } from \"./parameters\";\nimport {\n Feature as FeatureDefinition,\n Scenario as ScenarioDefinition,\n ScenarioOutline as ScenarioOutlineDefinition,\n Rule as RuleDefinition,\n Given as GivenDefinition,\n When as WhenDefinition,\n Then as ThenDefinition,\n Before as BeforeDefinition,\n After as AfterDefinition,\n Teardown as TeardownDefinition,\n Setup as SetupDefinition,\n BeforeFeature as BeforeFeatureDefinition,\n AfterFeature as AfterFeatureDefinition,\n BeforeScenarioOutline as BeforeScenarioOutlineDefinition,\n AfterScenarioOutline as AfterScenarioOutlineDefinition,\n BeforeExamples as BeforeExamplesDefinition,\n AfterExamples as AfterExamplesDefinition,\n BeforeRule as BeforeRuleDefinition,\n AfterRule as AfterRuleDefinition,\n} from \"./scopes\";\nimport { RuleAction } from \"@autometa/scopes\";\nimport { RuleScope } from \"@autometa/scopes\";\nexport { Pass } from \"./scopes\";\nexport * from \"@autometa/phrases\";\nexport {\n AppType,\n Fixture,\n Container,\n Constructor,\n AutometaApp,\n getApp,\n AutometaWorld,\n App,\n World,\n INJECTION_SCOPE,\n InjectionScope,\n Inject,\n DisposeTagFilter,\n DisposeMethod,\n} from \"./app\";\nexport { Dates, Time } from \"@autometa/datetime\";\nexport { AutomationError, raise } from \"@autometa/errors\";\nexport {\n DataTable,\n HTable,\n VTable,\n MTable,\n TableDocument,\n} from \"@autometa/gherkin\";\nexport { Bind } from \"@autometa/bind-decorator\";\nexport { Types } from \"@autometa/scopes\";\nexport * from \"./events\";\nexport * from \"@autometa/http\";\nexport * from \"@autometa/asserters\";\nexport {\n GetAccessedCount,\n GetAssignedValues,\n TrackAccess,\n} from \"@autometa/fixture-proxies\";\n\nexport { FileObject } from \"@autometa/file-proxies\";\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n *\n * ``ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n *\n * Feature('../features/my-feature.feature')\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * }\n * ```\n *\n * Global steps are defined in standard Cucumber stle.\n * ```ts\n * // ./test/steps/my-steps.ts\n * import { Given, When, Then } from '@autometa/runner'\n *\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * ```\n * @param filepath The absolute, relative, or 'feature root' path to the `.feature` file.\n */\nexport function Feature(filepath: string): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n * Accepts a timeout in milliseconds which will be applied to\n * all tests within the feature.\n *\n * ```ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n * // 10 second timeout\n * Feature('../features/my-feature.feature', 10_000)\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * }\n * ```\n *\n * Global steps are defined in standard Cucumber style.\n *\n * ```ts\n * // ./test/steps/my-steps.ts\n * import { Given, When, Then } from '@autometa/runner'\n *\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * ```\n * @param filepath The absolute, relative, or 'feature root' path to the `.feature` file.\n * @param timeout The timeout in milliseconds to apply to all tests within the feature.\n */\nexport function Feature(filepath: string, timeout: number): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and globally defined Step Definitions.\n * Accepts a timeout as a `TestTimeout` which is a tuple of `[durationNumber, 'ms' | 's' | 'm' | 'h']`\n * which will be applied to all tests within the feature.\n *\n * i.e. `[10, 's']` is a 10 second timeout. `[1, 'm']` is a 1 minute timeout.\n *\n * ```ts\n * // using relative path\n * import { Feature } from '@autometa/runner'\n *\n * // 10 second timeout\n * Feature('../features/my-feature.feature', [10, 's'])\n * ```\n *\n * Steps will be automatically assembled from Globally defined Step Definitions,\n * if a step definition root and app root are defined.\n *\n * ```ts\n * import { defineConfig } from '@autometa/runner'\n *\n * defineConfig({\n * ...\n * roots: {\n * steps: ['./test/steps'],\n * app: ['./app'],\n * },\n * };\n *\n * ```\n *\n * @param filepath\n * @param timeout\n */\nexport function Feature(filepath: string, timeout: TestTimeout): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and optionally locally defined steps,\n * mixed with optionally globally defined Step Definitions.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * })\n * ```\n *\n * If defined in the Gherkin, it will also use any Globally defined Step Definitions which match,\n * if none is defined locally. If a Step Definition is defined both globally and locally,\n * the most local definition will be used. This applies to sub-scopes like Scenarios and Rules\n * also.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n *\n * Scenario('My Scenario', () => {\n * Given('I have a step', () => {})\n * })\n *\n * Rule('My Rule', () => {\n * Given('I have a step', () => {})\n * })\n *\n * @param testDefinition\n * @param filepath\n */\nexport function Feature(\n testDefinition: FeatureAction,\n filepath: string\n): FeatureScope;\n/**\n * Executes a gherkin `.feature` file. Assembles Tests\n * using the Cucumber file and optionally locally defined steps,\n * mixed with optionally globally defined Step Definitions.\n * Accepts a timeout in milliseconds which will be applied to\n * all tests within the feature.\n *\n * ```ts\n * import { Feature } from '@autometa/runner'\n *\n * // 10 second timeout\n * Feature('My Feature', () => {\n * Given('I have a step', () => {})\n * When('I do something', () => {})\n * Then('I expect something', () => {})\n * }, 10_000)\n * ```\n * @param testDefinition the Feature definition callback\n * @param filepath\n * @param timeout\n */\nexport function Feature(\n testDefinition: FeatureAction,\n filepath: string,\n timeout: number\n): FeatureScope;\nexport function Feature(\n ...args: (FeatureAction | string | TestTimeout)[]\n): FeatureScope {\n return FeatureDefinition(...args);\n}\n\nexport function Scenario(title: string, action: ScenarioAction): ScenarioScope;\nexport function Scenario(\n title: string,\n action: ScenarioAction,\n timeout: number\n): ScenarioScope;\nexport function Scenario(\n title: string,\n action: ScenarioAction,\n timeout: SizedTimeout\n): ScenarioScope;\nexport function Scenario(\n ...args: (string | ScenarioAction | SizedTimeout | number)[]\n): ScenarioScope {\n return ScenarioDefinition(...args);\n}\n\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction\n): ScenarioScope;\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction,\n timeout: number\n): ScenarioScope;\nexport function ScenarioOutline(\n title: string,\n action: ScenarioAction,\n timeout: SizedTimeout\n): ScenarioScope;\nexport function ScenarioOutline(\n ...args: (string | ScenarioAction | SizedTimeout | number)[]\n): ScenarioScope {\n return ScenarioOutlineDefinition(...args);\n}\n\nexport function Rule(title: string, action: RuleAction): RuleScope;\nexport function Rule(\n title: string,\n action: RuleAction,\n timeout: number\n): RuleScope;\nexport function Rule(\n title: string,\n action: RuleAction,\n timeout: SizedTimeout\n): RuleScope;\nexport function Rule(\n ...args: (string | RuleAction | SizedTimeout | number)[]\n): RuleScope {\n return RuleDefinition(...args);\n}\n/**\n * Defines a `Given` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n * the context of a scenario, but cannot be accessed from the same step in a different\n * scenario.\n *\n * ```ts\n * import { Given } from '@autometa/runner'\n *\n * Given('I have a step', (app) => {\n * app.world.someData = 'some value'\n * })\n * // using destructuring\n * Given('I have a step', ({ world }) => {\n * world.someData = 'some value'\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { Given } from '@autometa/runner'\n *\n * // matches 'Given I have a step with a 'blue' value'\n * Given('I have a step with a {string} value', (value, { world }) => {\n * world.someData = value\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const Given = GivenDefinition;\n/**\n * Defines a `When` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n *\n * ```ts\n * import { When } from '@autometa/runner'\n *\n * When('I do something', async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * When('I do something', async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { When } from '@autometa/runner'\n *\n * // matches 'When I do something with a 'blue' value'\n * When('I do something with a {string} value', async (value, { webdriver }) => {\n * await webdriver.click(`#some-button-${value}`)\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const When = WhenDefinition;\n\n/**\n * Defines a `Then` step definition. Matches a gherkin step\n * as either a string literal match, or a Cucumber Expression.\n *\n * The callback function is passed as it's last (or only) argument\n * a copy of the `App` object which also contains a reference to the World.\n * This can be used to access features, or store data across steps within a test.\n *\n * N.b. The App instance is shared between all step definitions and hooks within\n *\n * ```ts\n * import { Then } from '@autometa/runner'\n *\n * Then('I expect something', async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Then('I expect something', async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * Steps also support Cucumber Expressions, which can be used to match\n * dynamic values in the step.\n *\n * ```ts\n * import { Then } from '@autometa/runner'\n *\n * // matches 'Then I expect something with a 'blue' value'\n * Then('I expect something with a {string} value', async (value, { world }) => {\n * expect(world.someData).toBe(value)\n * })\n *\n * @param pattern The step pattern to match.\n * @param action The step action to execute.\n */\nexport const Then = ThenDefinition;\n\n/**\n * Defines a `Before` hook. Executes before each scenario.\n *\n * ```ts\n * import { Before } from '@autometa/runner'\n *\n * Before(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Before(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Before = BeforeDefinition;\n\n/**\n * Defines a `After` hook. Executes after each scenario.\n *\n * ```ts\n * import { After } from '@autometa/runner'\n *\n * After(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * After(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const After = AfterDefinition;\n\n/**\n * Defines a `Setup` hook. Executes before all scenarios.\n * Setups are scoped, meaning a Setup defined inside the scope of a rule\n * will only apply to scenarios within that rule.\n *\n * N.b the Setup Hook and Teardown Hook reference their own unique\n * copy of the App with it's own unique life cycle. Values stored here\n * will not be accessible in tests without a singleton fixture.\n *\n * ```ts\n * import { Setup } from '@autometa/runner'\n *\n * Setup(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Setup(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Teardown = TeardownDefinition;\n\n/**\n * Defines a `Teardown` hook. Executes after all scenarios have completed.\n * Teardowns are scoped, meaning a Teardown defined inside the scope of a rule\n * will only apply to scenarios within that rule.\n *\n * N.b the Setup Hook and Teardown Hook reference their own unique\n * copy of the App with it's own unique life cycle. Values stored here\n * will not be accessible in tests without a singleston fixture.\n * ```ts\n * import { Teardown } from '@autometa/runner'\n *\n * Teardown(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * Teardown(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const Setup = SetupDefinition;\n\n/**\n * Defines a `BeforeFeature` hook. Executes before each feature.\n *\n * ```ts\n * import { BeforeFeature } from '@autometa/runner'\n *\n * BeforeFeature(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeFeature(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const BeforeFeature = BeforeFeatureDefinition;\n\n/**\n * Defines a `AfterFeature` hook. Executes after each feature.\n *\n * ```ts\n * import { AfterFeature } from '@autometa/runner'\n *\n * AfterFeature(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterFeature(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const AfterFeature = AfterFeatureDefinition;\n\n/**\n * Defines a `BeforeScenarioOutline` hook. Executes before each scenario outline.\n *\n * ```ts\n * import { BeforeScenarioOutline } from '@autometa/runner'\n *\n * BeforeScenarioOutline(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeScenarioOutline(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const BeforeScenarioOutline = BeforeScenarioOutlineDefinition;\n\n/**\n * Defines a `AfterScenarioOutline` hook. Executes after each scenario outline.\n *\n * ```ts\n * import { AfterScenarioOutline } from '@autometa/runner'\n *\n * AfterScenarioOutline(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterScenarioOutline(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const AfterScenarioOutline = AfterScenarioOutlineDefinition;\n\n/**\n * Defines a `BeforeExamples` hook. Executes before each examples table.\n *\n * ```ts\n * import { BeforeExamples } from '@autometa/runner'\n *\n * BeforeExamples(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeExamples(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const BeforeExamples = BeforeExamplesDefinition;\n\n/**\n * Defines a `AfterExamples` hook. Executes after each examples table.\n *\n * ```ts\n * import { AfterExamples } from '@autometa/runner'\n *\n * AfterExamples(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterExamples(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\nexport const AfterExamples = AfterExamplesDefinition;\n\n/**\n * Defines a `BeforeRule` hook. Executes before each rule.\n *\n * ```ts\n * import { BeforeRule } from '@autometa/runner'\n *\n * BeforeRule(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * BeforeRule(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const BeforeRule = BeforeRuleDefinition;\n\n/**\n * Defines a `AfterRule` hook. Executes after each rule.\n *\n * ```ts\n * import { AfterRule } from '@autometa/runner'\n *\n * AfterRule(async (app) => {\n * await app.webdriver.click('#some-button')\n * })\n *\n * // using destructuring\n * AfterRule(async ({ webdriver }) => {\n * await webdriver.click('#some-button')\n * })\n * ```\n *\n * @param action The hook action to execute.\n */\n\nexport const AfterRule = AfterRuleDefinition;\n","import {\n Config,\n TestExecutorConfig,\n defineConfig as dc,\n} from \"@autometa/config\";\n\nexport const CONFIG = new Config(new Map<string, TestExecutorConfig>());\nexport const defineConfig = dc.bind(null, CONFIG);\n","import { ParameterTypeRegistry } from \"@cucumber/cucumber-expressions\";\nimport {\n BooleanParam,\n DateParam,\n NumberParam,\n PrimitiveParam,\n OrdinalParam,\n TextParam,\n defineParameterType as dpt,\n} from \"@autometa/cucumber-expressions\";\n\nexport const PARAM_REGISTRY = new ParameterTypeRegistry();\n\n/**\n * Defines a parameter type for use in step definitions.\n *\n * ```ts\n * import { Color } from '../support/color';\n *\n * defineParameterType({\n * name: \"color\",\n * regex: /red|blue|yellow/,\n * transform: (value: string) => Color(value)\n * })\n *\n * // using regex arrays\n * defineParameterType({\n * name: \"color\",\n * regex: [/red/, /blue/, /yellow/],\n * transform: (value: string) => Color(value)\n * })\n * ```\n */\nexport const defineParameterType = dpt.bind(null, PARAM_REGISTRY);\n\ndefineParameterType(\n NumberParam,\n BooleanParam,\n PrimitiveParam,\n TextParam,\n DateParam,\n OrdinalParam\n);\n","import { PARAM_REGISTRY } from \"./parameters\";\nimport { GetCucumberFunctions, Pass } from \"@autometa/scopes\";\nimport { Coordinator } from \"@autometa/coordinator\";\nimport { CONFIG } from \"./config\";\nimport { makeTestEmitter } from \"./events\";\nimport { executor } from \"./executor\";\nimport { OPTS } from \"./app\";\nconst {\n BeforeFeature,\n AfterFeature,\n BeforeScenarioOutline,\n AfterScenarioOutline,\n BeforeExamples,\n AfterExamples,\n BeforeRule,\n AfterRule,\n Feature,\n Scenario,\n ScenarioOutline,\n Rule,\n Given,\n When,\n Then,\n Before,\n After,\n Teardown,\n Setup,\n Global,\n} = GetCucumberFunctions(PARAM_REGISTRY);\nconst coordinator = new Coordinator(Global, CONFIG, OPTS);\nGlobal.onFeatureExecuted = (feature, caller) => {\n const groupLogger = CONFIG.current.test?.groupLogging ?? false;\n const events = makeTestEmitter({ groupLogger });\n coordinator.run(feature, caller, events, executor);\n};\n\nexport {\n Feature,\n Scenario,\n ScenarioOutline,\n Rule,\n Given,\n When,\n Then,\n Before,\n After,\n Teardown,\n Setup,\n BeforeFeature,\n AfterFeature,\n BeforeScenarioOutline,\n AfterScenarioOutline,\n BeforeExamples,\n AfterExamples,\n BeforeRule,\n AfterRule,\n Pass,\n};\n","import { TestEventEmitter } from \"@autometa/events\";\nimport { CONFIG } from \"./config\";\nexport * from \"@autometa/events\";\nimport { GroupLogEvents } from \"./event-logger\";\nimport p from \"path\";\nexport function makeTestEmitter(opts: { groupLogger: boolean }) {\n const events = CONFIG.current.events;\n const emitter = new TestEventEmitter();\n if (opts.groupLogger) {\n emitter.load(new GroupLogEvents());\n }\n if (!events) {\n return emitter;\n }\n\n for (const event of events) {\n const isLocal = isRelativePath(event) || isAbsolutePath(event);\n if (isLocal) {\n const uriRoot = process.cwd();\n const uri = p.join(uriRoot, event);\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const listener = require(uri);\n if (\"default\" in listener && typeof listener.default === \"function\") {\n emitter.load(new listener.default());\n return emitter;\n }\n if (\"default\" in listener && typeof listener.default === \"object\") {\n emitter.load(listener.default);\n return emitter;\n }\n if (typeof listener === \"function\") {\n emitter.load(new listener());\n return emitter;\n }\n emitter.load(listener);\n return emitter;\n }\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const listener = require(event);\n if (\"default\" in listener) {\n emitter.load(listener.default);\n return emitter;\n }\n emitter.load(listener);\n return emitter;\n }\n\n return emitter;\n}\n\nfunction isRelativePath(path: string) {\n return path.startsWith(\".\");\n}\n\nfunction isAbsolutePath(path: string) {\n return p.isAbsolute(path);\n}\n","import {\n EndAfterOpts,\n EndBeforeOpts,\n EndFeatureOpts,\n EndRuleOpts,\n EndScenarioOpts,\n EndScenarioOutlineOpts,\n EndSetupOpts,\n EndStepOpts,\n EndTeardownOpts,\n EventSubscriber,\n StartAfterOpts,\n StartBeforeOpts,\n StartFeatureOpts,\n StartRuleOpts,\n StartScenarioOpts,\n StartScenarioOutlineOpts,\n StartSetupOpts,\n StartStepOpts,\n StartTeardownOpts,\n} from \"@autometa/events\";\nimport colors from \"colors-cli\";\nexport class GroupLogEvents implements EventSubscriber {\n onFeatureStart({ title }: StartFeatureOpts) {\n console.group(title);\n console.group();\n }\n onFeatureEnd({ title, status }: EndFeatureOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onScenarioStart({ title }: StartScenarioOpts): void {\n console.group(title);\n console.group();\n }\n onScenarioEnd({ title, status }: EndScenarioOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onScenarioOutlineStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n onScenarioOutlineEnd({ title, status }: EndScenarioOutlineOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onRuleStart({ title }: StartRuleOpts): void {\n console.group(title);\n console.group();\n }\n onRuleEnd({ title, status }: EndRuleOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onStepStart({ title }: StartStepOpts) {\n console.group(title);\n console.group();\n }\n onStepEnd({ title, status }: EndStepOpts) {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onBeforeStart({ title, status }: StartBeforeOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onBeforeEnd({ title, status }: EndBeforeOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onAfterStart({ title, status }: StartAfterOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onAfterEnd({ title, status }: EndAfterOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onTeardownStart({ title, status }: StartTeardownOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onTeardownEnd({ title, status }: EndTeardownOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onSetupStart({ title, status }: StartSetupOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.group(title);\n console.group();\n }\n onSetupEnd({ title, status }: EndSetupOpts): void {\n if (status === \"SKIPPED\") {\n return;\n }\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(status, `Ending ${title}`));\n }\n onBeforeFeatureStart(opts: StartFeatureOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeFeatureEnd(opts: EndFeatureOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onAfterFeatureStart(opts: StartFeatureOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterFeatureEnd(opts: EndFeatureOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onBeforeRuleStart(opts: StartRuleOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeRuleEnd(opts: EndRuleOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onAfterRuleStart(opts: StartRuleOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterRuleEnd(opts: EndRuleOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onBeforeScenarioOutlineStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeScenarioOutlineEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onBeforeExamplesStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onBeforeExamplesEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n\n onAfterExamplesStart(opts: StartScenarioOutlineOpts): void {\n console.group(opts.title);\n console.group();\n }\n\n onAfterExamplesEnd(opts: EndScenarioOpts): void {\n console.groupEnd();\n console.groupEnd();\n console.log(colorStatus(opts.status, `Ending ${opts.title}`));\n }\n}\nfunction colorStatus(\n status: \"FAILED\" | \"PASSED\" | \"SKIPPED\" | \"BROKEN\" | undefined,\n text: string\n) {\n switch (status) {\n case \"FAILED\":\n return `${colors.red(\"x\")} ${text}`;\n case \"PASSED\":\n return `${colors.green(\"✔️\")} ${text}`;\n case \"SKIPPED\":\n return `${colors.yellow(\"⊘\")} ${text}`;\n default:\n return text;\n }\n}\n","import { execute } from \"@autometa/jest-executor\";\n\nexport const executor = execute;\n","import \"@autometa/types\";\nimport { AppType as at } from \"@autometa/app\";\nimport { CoordinatorOpts } from \"@autometa/coordinator\";\nexport { AutometaApp, AutometaWorld, App, World } from \"@autometa/app\";\nexport {\n Fixture,\n INJECTION_SCOPE,\n InjectionScope,\n Token,\n Container,\n Constructor,\n Inject,\n} from \"@autometa/injection\";\nexport const OPTS = {} as Record<string, CoordinatorOpts>;\n/**\n * Marks a class as being the `App` of the test framework. The `App` is the\n * entry point for the test framework. The App will be made available as the final\n * argument in the Step Definition Callbacks.\n *\n * ```ts\n *\n * @AppType(World)\n * @Constructor(MyClient)\n * class App {\n * constructor(readonly myCLient: MyClient) {}\n * }\n * ```\n * Or with tokens\n *\n * ```ts\n * import from \"@autometa/runner\";\n * import { World } from \"./default.world\";\n * @AppType(World)\n * @Constructor(HTTP, Token(\"MyClient\"))\n * class App {\n * constructor(readonly http: HTTP, readonly myClient: MyClient) {}\n * }\n * ```\n */\nexport const AppType = at.bind(null, OPTS);\nexport { getApp } from \"@autometa/app\";\nexport { DisposeMethod, DisposeTagFilter } from \"@autometa/injection\";\n"],"mappings":"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","names":["After","AfterExamples","AfterFeature","AfterRule","AfterScenarioOutline","Before","BeforeExamples","BeforeFeature","BeforeRule","BeforeScenarioOutline","Feature","Given","Rule","Scenario","ScenarioOutline","Setup","Teardown","Then","When","dc","import_cucumber_expressions","dpt","colors","p","listener","import_app","import_injection","at","import_scopes","Feature","Scenario","ScenarioOutline","Rule","Given","When","Then","Before","After","Teardown","Setup","BeforeFeature","AfterFeature","BeforeScenarioOutline","AfterScenarioOutline","BeforeExamples","AfterExamples","BeforeRule","AfterRule"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@autometa/runner",
|
|
3
|
-
"version": "0.6.
|
|
3
|
+
"version": "0.6.3",
|
|
4
4
|
"description": "",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -33,25 +33,25 @@
|
|
|
33
33
|
"dependencies": {
|
|
34
34
|
"@cucumber/cucumber-expressions": "^16.1.2",
|
|
35
35
|
"colors-cli": "^1.0.32",
|
|
36
|
-
"@autometa/app": "^0.4.
|
|
37
|
-
"@autometa/asserters": "^0.1.8",
|
|
36
|
+
"@autometa/app": "^0.4.2",
|
|
38
37
|
"@autometa/bind-decorator": "^0.5.1",
|
|
39
|
-
"@autometa/config": "^0.1.
|
|
40
|
-
"@autometa/
|
|
38
|
+
"@autometa/config": "^0.1.27",
|
|
39
|
+
"@autometa/coordinator": "^0.3.32",
|
|
41
40
|
"@autometa/datetime": "^0.1.16",
|
|
42
|
-
"@autometa/
|
|
41
|
+
"@autometa/cucumber-expressions": "^0.4.4",
|
|
42
|
+
"@autometa/events": "^0.3.2",
|
|
43
43
|
"@autometa/errors": "^0.2.2",
|
|
44
|
-
"@autometa/events": "^0.3.1",
|
|
45
44
|
"@autometa/file-proxies": "^0.2.0",
|
|
46
45
|
"@autometa/fixture-proxies": "^0.1.3",
|
|
47
|
-
"@autometa/
|
|
48
|
-
"@autometa/
|
|
49
|
-
"@autometa/
|
|
46
|
+
"@autometa/http": "^1.4.20",
|
|
47
|
+
"@autometa/jest-executor": "^0.6.3",
|
|
48
|
+
"@autometa/gherkin": "^0.7.2",
|
|
49
|
+
"@autometa/asserters": "^0.1.8",
|
|
50
|
+
"@autometa/injection": "^0.1.5",
|
|
50
51
|
"@autometa/phrases": "^0.1.12",
|
|
51
|
-
"@autometa/
|
|
52
|
-
"@autometa/
|
|
53
|
-
"@autometa/test-builder": "^0.4.
|
|
54
|
-
"@autometa/types": "^0.4.1"
|
|
52
|
+
"@autometa/scopes": "^0.7.2",
|
|
53
|
+
"@autometa/types": "^0.4.1",
|
|
54
|
+
"@autometa/test-builder": "^0.4.2"
|
|
55
55
|
},
|
|
56
56
|
"scripts": {
|
|
57
57
|
"test": "vitest run --passWithNoTests",
|