vitest-cucumber-plugin 0.5.6 → 0.6.2
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/RELEASE_NOTES.md +3 -0
- package/dist/config.d.ts +11 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +2 -0
- package/dist/config.js.map +1 -0
- package/dist/generate/example.d.ts +5 -0
- package/dist/generate/example.d.ts.map +1 -0
- package/dist/generate/example.js +18 -0
- package/dist/generate/example.js.map +1 -0
- package/dist/generate/examples.d.ts +5 -0
- package/dist/generate/examples.d.ts.map +1 -0
- package/dist/generate/examples.js +46 -0
- package/dist/generate/examples.js.map +1 -0
- package/dist/generate/feature.d.ts +10 -0
- package/dist/generate/feature.d.ts.map +1 -0
- package/dist/generate/feature.js +77 -0
- package/dist/generate/feature.js.map +1 -0
- package/dist/generate/index.d.ts +3 -0
- package/dist/generate/index.d.ts.map +1 -0
- package/dist/generate/index.js +3 -0
- package/dist/generate/index.js.map +1 -0
- package/dist/generate/rule.d.ts +5 -0
- package/dist/generate/rule.d.ts.map +1 -0
- package/dist/generate/rule.js +19 -0
- package/dist/generate/rule.js.map +1 -0
- package/dist/generate/scenario-outline.d.ts +5 -0
- package/dist/generate/scenario-outline.d.ts.map +1 -0
- package/dist/generate/scenario-outline.js +18 -0
- package/dist/generate/scenario-outline.js.map +1 -0
- package/dist/generate/tests.d.ts +4 -0
- package/dist/generate/tests.d.ts.map +1 -0
- package/{src → dist}/generate/tests.js +10 -10
- package/dist/generate/tests.js.map +1 -0
- package/dist/generate/util.d.ts +6 -0
- package/dist/generate/util.d.ts.map +1 -0
- package/dist/generate/util.js +9 -0
- package/dist/generate/util.js.map +1 -0
- package/dist/gherkin-languages.json +3790 -0
- package/dist/gherkin-lexer-shared.d.ts +6 -0
- package/dist/gherkin-lexer-shared.d.ts.map +1 -0
- package/dist/gherkin-lexer-shared.js +4 -0
- package/dist/gherkin-lexer-shared.js.map +1 -0
- package/dist/gherkin-lexer.d.ts +4 -0
- package/dist/gherkin-lexer.d.ts.map +1 -0
- package/dist/gherkin-lexer.js +68 -0
- package/dist/gherkin-lexer.js.map +1 -0
- package/{src → dist}/gherkin.js +24 -31
- package/{src → dist}/gherkin.umd.js +23 -31
- package/dist/hooks.d.ts +25 -0
- package/dist/hooks.d.ts.map +1 -0
- package/dist/hooks.js +94 -0
- package/dist/hooks.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/logger.d.ts +5 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +8 -0
- package/dist/logger.js.map +1 -0
- package/dist/parameterize.d.ts +3 -0
- package/dist/parameterize.d.ts.map +1 -0
- package/dist/parameterize.js +8 -0
- package/dist/parameterize.js.map +1 -0
- package/dist/parse.d.ts +3 -0
- package/dist/parse.d.ts.map +1 -0
- package/dist/parse.js +28 -0
- package/dist/parse.js.map +1 -0
- package/dist/state.d.ts +4 -0
- package/dist/state.d.ts.map +1 -0
- package/dist/state.js +2 -0
- package/dist/state.js.map +1 -0
- package/dist/statement.d.ts +71 -0
- package/dist/statement.d.ts.map +1 -0
- package/dist/statement.js +10 -0
- package/dist/statement.js.map +1 -0
- package/dist/steps.d.ts +20 -0
- package/dist/steps.d.ts.map +1 -0
- package/{src → dist}/steps.js +17 -24
- package/dist/steps.js.map +1 -0
- package/dist/tags.d.ts +5 -0
- package/dist/tags.d.ts.map +1 -0
- package/{src → dist}/tags.js +20 -33
- package/dist/tags.js.map +1 -0
- package/dist/vitest-cucumber-plugin.d.ts +13 -0
- package/dist/vitest-cucumber-plugin.d.ts.map +1 -0
- package/dist/vitest-cucumber-plugin.js +69 -0
- package/dist/vitest-cucumber-plugin.js.map +1 -0
- package/package.json +64 -34
- package/generate-parsers +0 -6
- package/rollup-gherkin.js +0 -10
- package/rollup-tags-expression.js +0 -10
- package/run-tests +0 -9
- package/src/generate/example.js +0 -21
- package/src/generate/examples.js +0 -49
- package/src/generate/feature.js +0 -72
- package/src/generate/index.js +0 -15
- package/src/generate/rule.js +0 -22
- package/src/generate/scenario-outline.js +0 -21
- package/src/generate/util.js +0 -9
- package/src/gherkin.ne +0 -217
- package/src/hooks.js +0 -78
- package/src/index.js +0 -92
- package/src/logger.js +0 -14
- package/src/parameterize.js +0 -7
- package/src/parse.js +0 -21
- package/src/tags-expression.ne +0 -43
- package/tests/background/features/background.feature +0 -25
- package/tests/background/features/step_definitions/steps.js +0 -30
- package/tests/background/features/support/hooks.js +0 -3
- package/tests/background/package-lock.json +0 -1204
- package/tests/background/package.json +0 -11
- package/tests/background/vite.config.js +0 -13
- package/tests/comments/features/is-it-friday.feature +0 -10
- package/tests/comments/features/step_definitions/stepdefs.js +0 -15
- package/tests/comments/package-lock.json +0 -1933
- package/tests/comments/package.json +0 -11
- package/tests/comments/vite.config.js +0 -9
- package/tests/data-tables/features/data-tables-escaping.feature +0 -27
- package/tests/data-tables/features/data-tables.feature +0 -44
- package/tests/data-tables/features/step_definitions/data-tables.js +0 -21
- package/tests/data-tables/package-lock.json +0 -1933
- package/tests/data-tables/package.json +0 -11
- package/tests/data-tables/vite.config.js +0 -13
- package/tests/doc-strings/features/doc-strings.feature +0 -21
- package/tests/doc-strings/features/step_definitions/doc-strings.js +0 -15
- package/tests/doc-strings/package-lock.json +0 -1933
- package/tests/doc-strings/package.json +0 -11
- package/tests/doc-strings/vite.config.js +0 -13
- package/tests/hooks/features/after-all.feature +0 -5
- package/tests/hooks/features/after.feature +0 -5
- package/tests/hooks/features/before-all.feature +0 -14
- package/tests/hooks/features/before-step.feature +0 -6
- package/tests/hooks/features/before.feature +0 -14
- package/tests/hooks/features/step_definitions/steps.js +0 -28
- package/tests/hooks/features/support/hooks.js +0 -75
- package/tests/hooks/features/support/tags-hooks.js +0 -11
- package/tests/hooks/features/tags.feature +0 -14
- package/tests/hooks/package-lock.json +0 -1204
- package/tests/hooks/package.json +0 -11
- package/tests/hooks/vite.config.js +0 -13
- package/tests/is-it-friday/features/is-it-friday.feature +0 -7
- package/tests/is-it-friday/features/step_definitions/stepdefs.js +0 -15
- package/tests/is-it-friday/package-lock.json +0 -1933
- package/tests/is-it-friday/package.json +0 -11
- package/tests/is-it-friday/vite.config.js +0 -13
- package/tests/is-it-friday-scenario-outline/features/is-it-friday.feature +0 -13
- package/tests/is-it-friday-scenario-outline/features/step_definitions/stepdefs.js +0 -15
- package/tests/is-it-friday-scenario-outline/package-lock.json +0 -1933
- package/tests/is-it-friday-scenario-outline/package.json +0 -11
- package/tests/is-it-friday-scenario-outline/vite.config.js +0 -9
- package/tests/is-it-friday-two-scenarios/features/is-it-friday.feature +0 -12
- package/tests/is-it-friday-two-scenarios/features/step_definitions/stepdefs.js +0 -19
- package/tests/is-it-friday-two-scenarios/package-lock.json +0 -1933
- package/tests/is-it-friday-two-scenarios/package.json +0 -11
- package/tests/is-it-friday-two-scenarios/vite.config.js +0 -9
- package/tests/is-it-friday-two-scenarios-multiple-feature-files/features/friday.feature +0 -7
- package/tests/is-it-friday-two-scenarios-multiple-feature-files/features/step_definitions/stepdefs.js +0 -19
- package/tests/is-it-friday-two-scenarios-multiple-feature-files/features/sunday.feature +0 -8
- package/tests/is-it-friday-two-scenarios-multiple-feature-files/package-lock.json +0 -1933
- package/tests/is-it-friday-two-scenarios-multiple-feature-files/package.json +0 -11
- package/tests/is-it-friday-two-scenarios-multiple-feature-files/vite.config.js +0 -9
- package/tests/keyword-aliases/features/scenario-outline.feature +0 -20
- package/tests/keyword-aliases/features/scenario.feature +0 -14
- package/tests/keyword-aliases/features/step_definitions/steps.js +0 -30
- package/tests/keyword-aliases/features/steps.feature +0 -28
- package/tests/keyword-aliases/features/support/hooks.js +0 -6
- package/tests/keyword-aliases/package-lock.json +0 -1933
- package/tests/keyword-aliases/package.json +0 -11
- package/tests/keyword-aliases/vite.config.js +0 -9
- package/tests/rule/features/rule.feature +0 -14
- package/tests/rule/features/step_definitions/stepdefs.js +0 -19
- package/tests/rule/package-lock.json +0 -1933
- package/tests/rule/package.json +0 -11
- package/tests/rule/vite.config.js +0 -9
- package/tests/tags/features/skip.feature +0 -9
- package/tests/tags/features/step_definitions/steps.js +0 -30
- package/tests/tags/features/support/hooks.js +0 -6
- package/tests/tags/features/tags-scenario-outline.feature +0 -37
- package/tests/tags/features/tags.feature +0 -26
- package/tests/tags/package-lock.json +0 -1204
- package/tests/tags/package.json +0 -11
- package/tests/tags/vite.config.js +0 -12
- package/tests/vue/features/step_definitions/test.js +0 -25
- package/tests/vue/features/support/components.js +0 -19
- package/tests/vue/features/test.feature +0 -10
- package/tests/vue/package-lock.json +0 -2164
- package/tests/vue/package.json +0 -18
- package/tests/vue/src/test.vue +0 -10
- package/tests/vue/vite.config.js +0 -15
- /package/{src → dist}/tags-expression.js +0 -0
- /package/{src → dist}/tags-expression.umd.js +0 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
function isStatementType(statement, kind) {
|
|
2
|
+
return statement.type.type === kind;
|
|
3
|
+
}
|
|
4
|
+
function resolveStatementType(statement, kind) {
|
|
5
|
+
if (isStatementType(statement, kind)) {
|
|
6
|
+
return statement;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
export { isStatementType, resolveStatementType, };
|
|
10
|
+
//# sourceMappingURL=statement.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"statement.js","sourceRoot":"","sources":["../src/statement.ts"],"names":[],"mappings":"AA0FA,SAAS,eAAe,CAA+B,SAAoB,EAAE,IAAO;IAChF,OAAO,SAAS,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC;AACxC,CAAC;AAED,SAAS,oBAAoB,CACzB,SAAoB,EACpB,IAAO;IAEP,IAAI,eAAe,CAAC,SAAS,EAAE,IAAI,CAAC,EAAE,CAAC;QACnC,OAAO,SAAS,CAAC;IACrB,CAAC;AACL,CAAC;AAED,OAAO,EACH,eAAe,EACf,oBAAoB,GAavB,CAAC"}
|
package/dist/steps.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Expression } from '@cucumber/cucumber-expressions';
|
|
2
|
+
import { State } from './state.js';
|
|
3
|
+
import { StepStatement } from './statement.js';
|
|
4
|
+
type MaybePromise<T> = T | Promise<T>;
|
|
5
|
+
type StepFunction<S extends State = State, R extends State | undefined = undefined, A extends any[] = any> = [
|
|
6
|
+
R
|
|
7
|
+
] extends [undefined] ? (state: S, args: A, data?: Array<Array<string>> | string) => MaybePromise<void | object> : (state: S, args: A, data?: Array<Array<string>> | string) => MaybePromise<R>;
|
|
8
|
+
interface StepDefinition<S extends State = State, R extends State | undefined = undefined, A extends any[] = any> {
|
|
9
|
+
expression: string;
|
|
10
|
+
f: StepFunction<S, R, A>;
|
|
11
|
+
cucumberExpression: Expression;
|
|
12
|
+
}
|
|
13
|
+
declare const addStepDefinition: <S extends State = State, R extends State | undefined = undefined, A extends any[] = any>(expression: string, f: StepFunction<S, R, A>) => void;
|
|
14
|
+
interface StepDefinitionMatch {
|
|
15
|
+
stepDefinition: StepDefinition;
|
|
16
|
+
parameters: any[];
|
|
17
|
+
}
|
|
18
|
+
declare const findStepDefinitionMatch: (step: StepStatement) => StepDefinitionMatch;
|
|
19
|
+
export { addStepDefinition, findStepDefinitionMatch, StepDefinitionMatch };
|
|
20
|
+
//# sourceMappingURL=steps.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"steps.d.ts","sourceRoot":"","sources":["../src/steps.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4C,UAAU,EAAY,MAAM,gCAAgC,CAAC;AAGhH,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,KAAK,YAAY,CAAC,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAEtC,KAAK,YAAY,CAAC,CAAC,SAAS,KAAK,GAAG,KAAK,EAAE,CAAC,SAAS,KAAK,GAAG,SAAS,GAAG,SAAS,EAAE,CAAC,SAAS,GAAG,EAAE,GAAG,GAAG,IAAI;IACzG,CAAC;CACJ,SAAS,CAAC,SAAS,CAAC,GACf,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,MAAM,KAAK,YAAY,CAAC,IAAI,GAAG,MAAM,CAAC,GACxF,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,MAAM,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC;AAEnF,UAAU,cAAc,CAAC,CAAC,SAAS,KAAK,GAAG,KAAK,EAAE,CAAC,SAAS,KAAK,GAAG,SAAS,GAAG,SAAS,EAAE,CAAC,SAAS,GAAG,EAAE,GAAG,GAAG;IAC5G,UAAU,EAAE,MAAM,CAAC;IACnB,CAAC,EAAE,YAAY,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IACzB,kBAAkB,EAAE,UAAU,CAAC;CAClC;AAYD,QAAA,MAAM,iBAAiB,EAAE,CAAC,CAAC,SAAS,KAAK,GAAG,KAAK,EAAE,CAAC,SAAS,KAAK,GAAG,SAAS,GAAG,SAAS,EAAE,CAAC,SAAS,GAAG,EAAE,GAAG,GAAG,EAC7G,UAAU,EAAE,MAAM,EAClB,CAAC,EAAE,YAAY,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KACvB,IAIJ,CAAC;AAEF,UAAU,mBAAmB;IACzB,cAAc,EAAE,cAAc,CAAC;IAC/B,UAAU,EAAE,GAAG,EAAE,CAAC;CACrB;AAmBD,QAAA,MAAM,uBAAuB,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,mBAmBvD,CAAC;AAEF,OAAO,EAAE,iBAAiB,EAAE,uBAAuB,EAAE,mBAAmB,EAAE,CAAC"}
|
package/{src → dist}/steps.js
RENAMED
|
@@ -1,42 +1,35 @@
|
|
|
1
1
|
import { ExpressionFactory, ParameterTypeRegistry } from '@cucumber/cucumber-expressions';
|
|
2
2
|
import _ from 'lodash/fp.js';
|
|
3
3
|
import { log } from './logger.js';
|
|
4
|
-
|
|
5
4
|
var steps = [];
|
|
6
|
-
|
|
7
5
|
const typeName = {
|
|
8
|
-
given
|
|
9
|
-
then
|
|
10
|
-
when
|
|
6
|
+
given: 'Given',
|
|
7
|
+
then: 'Then',
|
|
8
|
+
when: 'When',
|
|
11
9
|
};
|
|
12
|
-
|
|
13
10
|
const expressionFactory = new ExpressionFactory(new ParameterTypeRegistry());
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
log.debug('addStepDefinition expression: '+JSON.stringify(expression));
|
|
11
|
+
const addStepDefinition = (expression, f) => {
|
|
12
|
+
log.debug({ expression }, 'addStepDefinition expression');
|
|
17
13
|
const cucumberExpression = expressionFactory.createExpression(expression);
|
|
18
|
-
steps = _.concat(steps,{ expression, f, cucumberExpression });
|
|
19
|
-
}
|
|
20
|
-
|
|
14
|
+
steps = _.concat(steps, { expression, f, cucumberExpression });
|
|
15
|
+
};
|
|
21
16
|
const findStepDefinitionMatches = (step) => {
|
|
22
|
-
const matchesMapper = _.map((match) => match.getValue());
|
|
23
|
-
const reducer = _.reduce((accumulator,stepDefinition) => {
|
|
17
|
+
const matchesMapper = _.map((match) => match.getValue(undefined));
|
|
18
|
+
const reducer = _.reduce((accumulator, stepDefinition) => {
|
|
24
19
|
const matches = stepDefinition.cucumberExpression.match(step.text);
|
|
25
20
|
if (matches) {
|
|
26
21
|
//console.log(accumulator,stepDefinition,matches);
|
|
27
|
-
return _.concat(accumulator,{ stepDefinition, parameters
|
|
28
|
-
}
|
|
22
|
+
return _.concat(accumulator, { stepDefinition, parameters: matchesMapper(matches) });
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
29
25
|
return accumulator;
|
|
30
26
|
}
|
|
31
27
|
});
|
|
32
|
-
|
|
33
28
|
return reducer([])(steps);
|
|
34
29
|
};
|
|
35
|
-
|
|
36
|
-
export const findStepDefinitionMatch = (step) => {
|
|
30
|
+
const findStepDefinitionMatch = (step) => {
|
|
37
31
|
const stepDefinitionMatches = findStepDefinitionMatches(step);
|
|
38
|
-
|
|
39
|
-
if (!stepDefinitionMatches || (stepDefinitionMatches.length == 0)) {
|
|
32
|
+
if (!stepDefinitionMatches || stepDefinitionMatches.length == 0) {
|
|
40
33
|
throw new Error(`Undefined. Implement with the following snippet:
|
|
41
34
|
|
|
42
35
|
${typeName[step.type.type]}('${step.text}', (state,params,data) => {
|
|
@@ -46,10 +39,10 @@ export const findStepDefinitionMatch = (step) => {
|
|
|
46
39
|
});
|
|
47
40
|
`);
|
|
48
41
|
}
|
|
49
|
-
|
|
50
42
|
if (stepDefinitionMatches.length > 1) {
|
|
51
|
-
throw new Error(
|
|
43
|
+
throw new Error("More than one step which matches: '" + step.type.name + ' ' + step.text + "'");
|
|
52
44
|
}
|
|
53
|
-
|
|
54
45
|
return stepDefinitionMatches[0];
|
|
55
46
|
};
|
|
47
|
+
export { addStepDefinition, findStepDefinitionMatch };
|
|
48
|
+
//# sourceMappingURL=steps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"steps.js","sourceRoot":"","sources":["../src/steps.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAwB,MAAM,gCAAgC,CAAC;AAChH,OAAO,CAAC,MAAM,cAAc,CAAC;AAC7B,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;AAkBlC,IAAI,KAAK,GAAyC,EAAE,CAAC;AAErD,MAAM,QAAQ,GAAG;IACb,KAAK,EAAE,OAAO;IACd,IAAI,EAAE,MAAM;IACZ,IAAI,EAAE,MAAM;CACf,CAAC;AAEF,MAAM,iBAAiB,GAAG,IAAI,iBAAiB,CAAC,IAAI,qBAAqB,EAAE,CAAC,CAAC;AAE7E,MAAM,iBAAiB,GAGX,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE;IAC1B,GAAG,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,EAAE,8BAA8B,CAAC,CAAC;IAC1D,MAAM,kBAAkB,GAAG,iBAAiB,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;IAC1E,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,kBAAkB,EAAE,CAAC,CAAC;AACnE,CAAC,CAAC;AAOF,MAAM,yBAAyB,GAAmD,CAAC,IAAI,EAAE,EAAE;IACvF,MAAM,aAAa,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,KAAe,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC;IAC5E,MAAM,OAAO,GAAG,CAAC,CAAC,MAAM,CACpB,CAAC,WAAkC,EAAE,cAA8B,EAAE,EAAE;QACnE,MAAM,OAAO,GAAG,cAAc,CAAC,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnE,IAAI,OAAO,EAAE,CAAC;YACV,kDAAkD;YAClD,OAAO,CAAC,CAAC,MAAM,CAAC,WAAW,EAAE,EAAE,cAAc,EAAE,UAAU,EAAE,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACzF,CAAC;aAAM,CAAC;YACJ,OAAO,WAAW,CAAC;QACvB,CAAC;IACL,CAAC,CACJ,CAAC;IAEF,OAAO,OAAO,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;AAC9B,CAAC,CAAC;AAEF,MAAM,uBAAuB,GAAiD,CAAC,IAAI,EAAE,EAAE;IACnF,MAAM,qBAAqB,GAAG,yBAAyB,CAAC,IAAI,CAAC,CAAC;IAE9D,IAAI,CAAC,qBAAqB,IAAI,qBAAqB,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;QAC9D,MAAM,IAAI,KAAK,CAAC;;MAElB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI;;;;;CAK3C,CAAC,CAAC;IACC,CAAC;IAED,IAAI,qBAAqB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,qCAAqC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC;IACpG,CAAC;IAED,OAAO,qBAAqB,CAAC,CAAC,CAAC,CAAC;AACpC,CAAC,CAAC;AAEF,OAAO,EAAE,iBAAiB,EAAE,uBAAuB,EAAuB,CAAC"}
|
package/dist/tags.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tags.d.ts","sourceRoot":"","sources":["../src/tags.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAuCtC,KAAK,YAAY,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,KAAK,OAAO,CAAC;AAqC7C,QAAA,MAAM,kBAAkB,EAAE,CAAC,cAAc,CAAC,EAAE,MAAM,KAAK,YAQtD,CAAC;AAEF,OAAO,EAAE,kBAAkB,EAAE,YAAY,EAAE,CAAC"}
|
package/{src → dist}/tags.js
RENAMED
|
@@ -2,67 +2,54 @@ import _ from 'lodash/fp.js';
|
|
|
2
2
|
import nearley from 'nearley';
|
|
3
3
|
import tagsExpressionParser from './tags-expression.js';
|
|
4
4
|
import { log } from './logger.js';
|
|
5
|
-
|
|
6
5
|
const parseTagsExpression = (tagsExpression) => {
|
|
7
6
|
const parser = new nearley.Parser(nearley.Grammar.fromCompiled(tagsExpressionParser));
|
|
8
|
-
|
|
9
7
|
tagsExpression += '\n';
|
|
10
8
|
parser.feed(tagsExpression);
|
|
11
|
-
log.debug(
|
|
12
|
-
|
|
9
|
+
log.debug({ results: parser.results }, `parseTagsExpression expression: '${tagsExpression}'`);
|
|
13
10
|
if (parser.results.length == 0) {
|
|
14
11
|
throw new Error('Unexpected end of expression');
|
|
15
12
|
}
|
|
16
|
-
log.debug('parsing result: '+JSON.stringify(parser.results,null,2));
|
|
13
|
+
log.debug('parsing result: ' + JSON.stringify(parser.results, null, 2));
|
|
17
14
|
if (parser.results.length > 1) {
|
|
18
|
-
throw new Error('Ambiguous parsing: '+parser.results.length);
|
|
15
|
+
throw new Error('Ambiguous parsing: ' + parser.results.length);
|
|
19
16
|
}
|
|
20
|
-
|
|
21
17
|
return parser.results[0];
|
|
22
|
-
}
|
|
23
|
-
|
|
18
|
+
};
|
|
24
19
|
const createFunction = (e) => {
|
|
25
20
|
if (_.isString(e)) {
|
|
26
|
-
log.debug(
|
|
21
|
+
log.debug(`createFunction tag: ${e}`);
|
|
27
22
|
return (tags) => {
|
|
28
|
-
const result = _.find((tag) => tag == e,tags);
|
|
29
|
-
log.debug(
|
|
30
|
-
return result;
|
|
31
|
-
}
|
|
23
|
+
const result = _.find((tag) => tag == e, tags);
|
|
24
|
+
log.debug(`tagsExpression tag: ${e} tags: ${JSON.stringify(tags)} match? ${result}`);
|
|
25
|
+
return result ? true : false;
|
|
26
|
+
};
|
|
32
27
|
}
|
|
33
|
-
|
|
34
|
-
if (!_.has('operator',e)) {
|
|
28
|
+
if (!_.has('operator', e)) {
|
|
35
29
|
throw new Error('Missing operator.');
|
|
36
30
|
}
|
|
37
|
-
|
|
38
31
|
if (e.operator == 'not') {
|
|
39
|
-
log.debug(
|
|
32
|
+
log.debug(`createFunction not ${JSON.stringify(e.expression)}`);
|
|
40
33
|
const f = createFunction(e.expression);
|
|
41
34
|
return (tags) => !f(tags);
|
|
42
35
|
}
|
|
43
|
-
|
|
44
|
-
log.debug('createFunction '+JSON.stringify(e.left)+' '+e.operator+' '+JSON.stringify(e.right));
|
|
36
|
+
log.debug(`createFunction ${JSON.stringify(e.left)} ${e.operator} ${JSON.stringify(e.right)}`);
|
|
45
37
|
const l = createFunction(e.left);
|
|
46
38
|
const r = createFunction(e.right);
|
|
47
|
-
|
|
48
39
|
if (e.operator == 'and') {
|
|
49
|
-
return (tags) =>
|
|
40
|
+
return (tags) => l(tags) && r(tags);
|
|
50
41
|
}
|
|
51
|
-
|
|
52
|
-
|
|
53
42
|
if (e.operator == 'or') {
|
|
54
|
-
return (tags) =>
|
|
43
|
+
return (tags) => l(tags) || r(tags);
|
|
55
44
|
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
export const tagsFunction = (tagsExpression) => {
|
|
45
|
+
throw new Error("Couldn't parse tags expression");
|
|
46
|
+
};
|
|
47
|
+
const createTagsFunction = (tagsExpression) => {
|
|
61
48
|
if (!tagsExpression) {
|
|
62
49
|
return (tags) => true;
|
|
63
50
|
}
|
|
64
|
-
|
|
65
51
|
const parsedTagsExpression = parseTagsExpression(tagsExpression);
|
|
66
|
-
|
|
67
52
|
return createFunction(parsedTagsExpression);
|
|
68
|
-
}
|
|
53
|
+
};
|
|
54
|
+
export { createTagsFunction };
|
|
55
|
+
//# sourceMappingURL=tags.js.map
|
package/dist/tags.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tags.js","sourceRoot":"","sources":["../src/tags.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Vite } from 'vitest/node';
|
|
2
|
+
import { log, logConfig } from './logger.js';
|
|
3
|
+
import { BeforeAll, applyBeforeAllHooks, Before, applyBeforeHooks, AfterAll, applyAfterAllHooks, After, applyAfterHooks, BeforeStep, applyBeforeStepHooks, AfterStep, applyAfterStepHooks } from './hooks.js';
|
|
4
|
+
import { State } from './state.js';
|
|
5
|
+
import { StepStatement } from './statement.js';
|
|
6
|
+
declare const Given: <S extends State = State, R extends State | undefined = undefined, A extends any[] = any>(expression: string, f: [R] extends [undefined] ? (state: S, args: A, data?: Array<Array<string>> | string) => void | object | Promise<void | object> : (state: S, args: A, data?: Array<Array<string>> | string) => R | Promise<R>) => void;
|
|
7
|
+
declare const When: <S extends State = State, R extends State | undefined = undefined, A extends any[] = any>(expression: string, f: [R] extends [undefined] ? (state: S, args: A, data?: Array<Array<string>> | string) => void | object | Promise<void | object> : (state: S, args: A, data?: Array<Array<string>> | string) => R | Promise<R>) => void;
|
|
8
|
+
declare const Then: <S extends State = State, R extends State | undefined = undefined, A extends any[] = any>(expression: string, f: [R] extends [undefined] ? (state: S, args: A, data?: Array<Array<string>> | string) => void | object | Promise<void | object> : (state: S, args: A, data?: Array<Array<string>> | string) => R | Promise<R>) => void;
|
|
9
|
+
declare const Test: (state: State, step: StepStatement) => State;
|
|
10
|
+
declare const DataTable: (dataTable: Array<Array<string>>) => Array<Record<string, string>>;
|
|
11
|
+
declare const vitestCucumberPlugin: () => Vite.Plugin;
|
|
12
|
+
export { Given, When, Then, Test, log, logConfig, applyBeforeAllHooks, applyBeforeHooks, applyAfterAllHooks, applyAfterHooks, applyBeforeStepHooks, applyAfterStepHooks, BeforeAll, Before, AfterAll, After, BeforeStep, AfterStep, DataTable, vitestCucumberPlugin, State, };
|
|
13
|
+
//# sourceMappingURL=vitest-cucumber-plugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vitest-cucumber-plugin.d.ts","sourceRoot":"","sources":["../src/vitest-cucumber-plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAInC,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAG7C,OAAO,EACH,SAAS,EACT,mBAAmB,EACnB,MAAM,EACN,gBAAgB,EAChB,QAAQ,EACR,kBAAkB,EAClB,KAAK,EACL,eAAe,EACf,UAAU,EACV,oBAAoB,EACpB,SAAS,EACT,mBAAmB,EACtB,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAoB/C,QAAA,MAAM,KAAK,uUAAoB,CAAC;AAChC,QAAA,MAAM,IAAI,uUAAoB,CAAC;AAC/B,QAAA,MAAM,IAAI,uUAAoB,CAAC;AAE/B,QAAA,MAAM,IAAI,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,aAAa,KAAK,KAkBlD,CAAC;AAEF,QAAA,MAAM,SAAS,EAAE,CAAC,SAAS,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAUjF,CAAC;AAEF,QAAA,MAAM,oBAAoB,EAAE,MAAM,IAAI,CAAC,MAqCtC,CAAC;AAEF,OAAO,EACH,KAAK,EACL,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,SAAS,EACT,mBAAmB,EACnB,gBAAgB,EAChB,kBAAkB,EAClB,eAAe,EACf,oBAAoB,EACpB,mBAAmB,EACnB,SAAS,EACT,MAAM,EACN,QAAQ,EACR,KAAK,EACL,UAAU,EACV,SAAS,EACT,SAAS,EACT,oBAAoB,EACpB,KAAK,GACR,CAAC"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import _ from 'lodash/fp.js';
|
|
2
|
+
import { addStepDefinition, findStepDefinitionMatch } from './steps.js';
|
|
3
|
+
import { generateFeature } from './generate/index.js';
|
|
4
|
+
import { log, logConfig } from './logger.js';
|
|
5
|
+
import { parse } from './parse.js';
|
|
6
|
+
import { createTagsFunction } from './tags.js';
|
|
7
|
+
import { BeforeAll, applyBeforeAllHooks, Before, applyBeforeHooks, AfterAll, applyAfterAllHooks, After, applyAfterHooks, BeforeStep, applyBeforeStepHooks, AfterStep, applyAfterStepHooks, } from './hooks.js';
|
|
8
|
+
import { gherkinLexerConfig } from './gherkin-lexer.js';
|
|
9
|
+
const featureRegex = /\.feature$/;
|
|
10
|
+
const compileFeatureToJs = async (options) => {
|
|
11
|
+
const { config, featureSource, featurePath } = options;
|
|
12
|
+
const feature = await parse(featureSource);
|
|
13
|
+
const code = await generateFeature({ config, feature, featurePath });
|
|
14
|
+
return code;
|
|
15
|
+
};
|
|
16
|
+
const Given = addStepDefinition;
|
|
17
|
+
const When = addStepDefinition;
|
|
18
|
+
const Then = addStepDefinition;
|
|
19
|
+
const Test = (state, step) => {
|
|
20
|
+
log.debug({ step, state }, 'Test step');
|
|
21
|
+
const stepDefinitionMatch = findStepDefinitionMatch(step);
|
|
22
|
+
const extraData = step.dataTable ? step.dataTable : step.docString ? step.docString.text : undefined;
|
|
23
|
+
const newState = stepDefinitionMatch.stepDefinition.f(state, stepDefinitionMatch.parameters, extraData);
|
|
24
|
+
log.info({ state, newState, extraData, parameters: stepDefinitionMatch.parameters }, `${step.type.name}('${stepDefinitionMatch.stepDefinition.expression}')`);
|
|
25
|
+
log.debug({ newState }, 'Test newState');
|
|
26
|
+
if (newState === undefined) {
|
|
27
|
+
return state;
|
|
28
|
+
}
|
|
29
|
+
return newState;
|
|
30
|
+
};
|
|
31
|
+
const DataTable = (dataTable) => {
|
|
32
|
+
const parameters = _.first(dataTable);
|
|
33
|
+
if (!parameters) {
|
|
34
|
+
throw new Error('Data table was empty.');
|
|
35
|
+
}
|
|
36
|
+
const rows = _.tail(dataTable);
|
|
37
|
+
return _.map((row) => _.zipObject(parameters, row))(rows);
|
|
38
|
+
};
|
|
39
|
+
const vitestCucumberPlugin = () => {
|
|
40
|
+
let config;
|
|
41
|
+
return {
|
|
42
|
+
name: 'vitest-cucumber-transform',
|
|
43
|
+
configResolved: (resolvedConfig) => {
|
|
44
|
+
config = _.defaults({
|
|
45
|
+
root: resolvedConfig.root,
|
|
46
|
+
log: { level: 'warn' },
|
|
47
|
+
language: 'en',
|
|
48
|
+
stepDefinitions: { include: 'features/**/*.[jt]s' },
|
|
49
|
+
}, _.get('test.cucumber', resolvedConfig));
|
|
50
|
+
logConfig(config.log);
|
|
51
|
+
config = _.set('tagsFunction', createTagsFunction(_.get('tags', config)), config);
|
|
52
|
+
log.debug({ config }, 'config');
|
|
53
|
+
// Nearley has no mechanism for passing user data into the parser so need to do some hacky stuff here
|
|
54
|
+
// and setup some globals to get around the limitations.
|
|
55
|
+
gherkinLexerConfig(config);
|
|
56
|
+
},
|
|
57
|
+
transform: async (src, id) => {
|
|
58
|
+
if (featureRegex.test(id)) {
|
|
59
|
+
const code = await compileFeatureToJs({ config, featureSource: src, featurePath: id });
|
|
60
|
+
log.debug(`transform ${id} -> ${code}`);
|
|
61
|
+
return {
|
|
62
|
+
code,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
};
|
|
68
|
+
export { Given, When, Then, Test, log, logConfig, applyBeforeAllHooks, applyBeforeHooks, applyAfterAllHooks, applyAfterHooks, applyBeforeStepHooks, applyAfterStepHooks, BeforeAll, Before, AfterAll, After, BeforeStep, AfterStep, DataTable, vitestCucumberPlugin, };
|
|
69
|
+
//# sourceMappingURL=vitest-cucumber-plugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vitest-cucumber-plugin.js","sourceRoot":"","sources":["../src/vitest-cucumber-plugin.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,35 +1,65 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
"
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
"
|
|
35
|
-
|
|
2
|
+
"name": "vitest-cucumber-plugin",
|
|
3
|
+
"version": "0.6.2",
|
|
4
|
+
"description": "Plugin for Vitest which allows for tests to be written in Cucumber format.",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"vite",
|
|
7
|
+
"vitest",
|
|
8
|
+
"cucumber"
|
|
9
|
+
],
|
|
10
|
+
"homepage": "https://github.com/samuel-ziegler/vitest-cucumber-plugin#readme",
|
|
11
|
+
"bugs": {
|
|
12
|
+
"url": "https://github.com/samuel-ziegler/vitest-cucumber-plugin/issues"
|
|
13
|
+
},
|
|
14
|
+
"license": "MIT",
|
|
15
|
+
"main": "src/index.js",
|
|
16
|
+
"type": "module",
|
|
17
|
+
"exports": {
|
|
18
|
+
".": {
|
|
19
|
+
"types": "./dist/index.d.ts",
|
|
20
|
+
"import": "./dist/index.js",
|
|
21
|
+
"default": "./dist/index.js"
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
"files": [
|
|
25
|
+
"dist",
|
|
26
|
+
"README.md",
|
|
27
|
+
"CONTRIBUTING.md",
|
|
28
|
+
"LICENSE",
|
|
29
|
+
"RELEASE_NOTES.md"
|
|
30
|
+
],
|
|
31
|
+
"scripts": {
|
|
32
|
+
"dev": "tsx src/index.ts",
|
|
33
|
+
"clean": "rm -r dist/ || true",
|
|
34
|
+
"build": "yarn tsc && cpy \"src/**/*.{json,js}\" dist --parents",
|
|
35
|
+
"watch": "yarn tsc --watch",
|
|
36
|
+
"nearley": "./generate-parsers",
|
|
37
|
+
"test": "./run-tests"
|
|
38
|
+
},
|
|
39
|
+
"prettier": {
|
|
40
|
+
"tabWidth": 4,
|
|
41
|
+
"singleQuote": true,
|
|
42
|
+
"printWidth": 120
|
|
43
|
+
},
|
|
44
|
+
"dependencies": {
|
|
45
|
+
"@cucumber/cucumber-expressions": "^16.1.2",
|
|
46
|
+
"glob": "^13.0.6",
|
|
47
|
+
"lodash": "^4.17.23",
|
|
48
|
+
"moo": "^0.5.3",
|
|
49
|
+
"nearley": "^2.20.1",
|
|
50
|
+
"pino": "^10.3.1",
|
|
51
|
+
"vitest": "^4.1.0"
|
|
52
|
+
},
|
|
53
|
+
"devDependencies": {
|
|
54
|
+
"@rollup/plugin-commonjs": "^24.1.0",
|
|
55
|
+
"@types/lodash": "^4.17.24",
|
|
56
|
+
"@types/nearley": "^2.11.5",
|
|
57
|
+
"@types/node": "^25.5.0",
|
|
58
|
+
"cpy-cli": "^7.0.0",
|
|
59
|
+
"rollup": "^3.20.7",
|
|
60
|
+
"tsx": "^4.21.0",
|
|
61
|
+
"typescript": "^5.9.3"
|
|
62
|
+
},
|
|
63
|
+
"repository": "https://github.com/samuel-ziegler/vitest-cucumber-plugin.git",
|
|
64
|
+
"packageManager": "yarn@4.13.0"
|
|
65
|
+
}
|
package/generate-parsers
DELETED
package/rollup-gherkin.js
DELETED
package/run-tests
DELETED
package/src/generate/example.js
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { escape, shouldSkip } from './util.js';
|
|
2
|
-
import { generateTests } from './tests.js';
|
|
3
|
-
import _ from 'lodash/fp.js';
|
|
4
|
-
import { log } from '../logger.js';
|
|
5
|
-
|
|
6
|
-
export const generateExample = (config,example) => {
|
|
7
|
-
log.debug('generateExample config: '+JSON.stringify(config)+' example: '+JSON.stringify(example));
|
|
8
|
-
var tests = '';
|
|
9
|
-
|
|
10
|
-
const steps = _.has('background.steps',example) ? _.concat(example.background.steps,example.steps) : example.steps;
|
|
11
|
-
|
|
12
|
-
tests += generateTests(steps,{},example.tags);
|
|
13
|
-
|
|
14
|
-
const skip = shouldSkip(config,example.tags) ? '.skip' : '';
|
|
15
|
-
|
|
16
|
-
const code = ` // tags : ${JSON.stringify(example.tags)}
|
|
17
|
-
describe${skip}('${escape(example.type.name)}: ${escape(example.name)}', () => {${tests}
|
|
18
|
-
});
|
|
19
|
-
`;
|
|
20
|
-
return code;
|
|
21
|
-
}
|
package/src/generate/examples.js
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { escape, shouldSkip } from './util.js';
|
|
2
|
-
import { generateTests } from './tests.js';
|
|
3
|
-
import _ from 'lodash/fp.js';
|
|
4
|
-
import { log } from '../logger.js';
|
|
5
|
-
|
|
6
|
-
const createParameterMap = (parameters,values) => {
|
|
7
|
-
const parameterMap = _.reduce((parameterMap,value) => {
|
|
8
|
-
return {
|
|
9
|
-
map : _.set(parameters[parameterMap.index],value,parameterMap.map),
|
|
10
|
-
index : parameterMap.index + 1
|
|
11
|
-
};
|
|
12
|
-
},{ map : {}, index : 0 })(values);
|
|
13
|
-
|
|
14
|
-
return parameterMap.map;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
const generateAllTests = (steps,parameters,parameterValues,tags) => {
|
|
18
|
-
const allTests = _.reduce((allTests,values) => {
|
|
19
|
-
const parameterMap = createParameterMap(parameters,values);
|
|
20
|
-
log.debug('parameterMap : '+JSON.stringify(parameterMap));
|
|
21
|
-
|
|
22
|
-
const tests = generateTests(steps,parameterMap,tags,' ');
|
|
23
|
-
|
|
24
|
-
return { tests : allTests.tests + `
|
|
25
|
-
describe('${allTests.index}',() => {${tests}
|
|
26
|
-
});`, index : allTests.index + 1 };
|
|
27
|
-
},{ tests : '', index : 0})(parameterValues);
|
|
28
|
-
|
|
29
|
-
return allTests.tests;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export const generateExamples = (config,steps,examplesStatement) => {
|
|
33
|
-
log.debug('generateExamples steps:'+JSON.stringify(steps)+' examples: '+JSON.stringify(examplesStatement));
|
|
34
|
-
|
|
35
|
-
const parameters = _.head(examplesStatement.dataTable);
|
|
36
|
-
const parameterValues = _.tail(examplesStatement.dataTable);
|
|
37
|
-
|
|
38
|
-
log.debug('generateExamples parameters:'+JSON.stringify(parameters)+' parameterValues: '+
|
|
39
|
-
JSON.stringify(parameterValues));
|
|
40
|
-
|
|
41
|
-
const skip = shouldSkip(config,examplesStatement.tags) ? '.skip' : '';
|
|
42
|
-
|
|
43
|
-
const allTests = generateAllTests(steps,parameters,parameterValues,examplesStatement.tags);
|
|
44
|
-
const code = `
|
|
45
|
-
// tags : ${JSON.stringify(examplesStatement.tags)}
|
|
46
|
-
describe${skip}('${escape(examplesStatement.type.name)}: ${escape(examplesStatement.name)}', () => {${allTests}
|
|
47
|
-
});`;
|
|
48
|
-
return code;
|
|
49
|
-
}
|
package/src/generate/feature.js
DELETED
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import _ from 'lodash/fp.js';
|
|
2
|
-
import { log } from '../logger.js';
|
|
3
|
-
import { generateExample, generateScenarioOutline, generateRule } from './index.js';
|
|
4
|
-
import { escape, shouldSkip } from './util.js';
|
|
5
|
-
import { glob } from 'glob';
|
|
6
|
-
|
|
7
|
-
const findJsFiles = async () => glob('features/**/*.js');
|
|
8
|
-
|
|
9
|
-
export const generateFeature = async (config,feature) => {
|
|
10
|
-
const name = feature.name;
|
|
11
|
-
const statements = feature.statements;
|
|
12
|
-
|
|
13
|
-
const testStatements = _.reduce((testStatements,statement) => {
|
|
14
|
-
if (feature.background) {
|
|
15
|
-
statement = _.set('background',feature.background,statement);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
statement = _.set('tags',_.concat(feature.tags,statement.tags),statement);
|
|
19
|
-
|
|
20
|
-
if (statement.type.type === 'example') {
|
|
21
|
-
return testStatements + generateExample(config,statement);
|
|
22
|
-
} else if (statement.type.type === 'scenarioOutline') {
|
|
23
|
-
return testStatements + generateScenarioOutline(config,statement);
|
|
24
|
-
} else if (statement.type.type === 'rule') {
|
|
25
|
-
return testStatements + generateRule(config,statement);
|
|
26
|
-
}
|
|
27
|
-
},'')(statements);
|
|
28
|
-
|
|
29
|
-
const skip = shouldSkip(config,feature.tags) ? '.skip' : '';
|
|
30
|
-
const configStr = JSON.stringify(config);
|
|
31
|
-
const tagsStr = JSON.stringify(feature.tags);
|
|
32
|
-
|
|
33
|
-
const jsFilesImportReducer = (imports,file) => {
|
|
34
|
-
file = file.slice('features/'.length);
|
|
35
|
-
return imports+`
|
|
36
|
-
import './${file}';`;
|
|
37
|
-
};
|
|
38
|
-
const jsFiles = await findJsFiles();
|
|
39
|
-
const jsFilesImport = _.reduce(jsFilesImportReducer,'',jsFiles);
|
|
40
|
-
|
|
41
|
-
const code = `import { expect, test, describe, beforeAll, afterAll, beforeEach, afterEach } from 'vitest';
|
|
42
|
-
import {
|
|
43
|
-
Test,
|
|
44
|
-
applyBeforeAllHooks,
|
|
45
|
-
applyBeforeHooks,
|
|
46
|
-
applyBeforeStepHooks,
|
|
47
|
-
applyAfterAllHooks,
|
|
48
|
-
applyAfterHooks,
|
|
49
|
-
applyAfterStepHooks,
|
|
50
|
-
} from 'vitest-cucumber-plugin';
|
|
51
|
-
import { readdir } from 'node:fs/promises';
|
|
52
|
-
import { log, logConfig } from 'vitest-cucumber-plugin';${jsFilesImport}
|
|
53
|
-
|
|
54
|
-
logConfig(${JSON.stringify(config.log)});
|
|
55
|
-
|
|
56
|
-
var state = {};
|
|
57
|
-
|
|
58
|
-
beforeAll(async () => {
|
|
59
|
-
state = await applyBeforeAllHooks(state,${tagsStr});
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
afterAll(async () => {
|
|
63
|
-
state = await applyAfterAllHooks(state,${tagsStr});
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
// tags : ${tagsStr}
|
|
67
|
-
describe${skip}('${escape(feature.type.name)}: ${escape(name)}', () => {
|
|
68
|
-
${testStatements}});
|
|
69
|
-
`;
|
|
70
|
-
|
|
71
|
-
return code;
|
|
72
|
-
}
|
package/src/generate/index.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { generateTests } from './tests.js';
|
|
2
|
-
import { generateExample } from './example.js';
|
|
3
|
-
import { generateExamples } from './examples.js';
|
|
4
|
-
import { generateScenarioOutline } from './scenario-outline.js';
|
|
5
|
-
import { generateFeature } from './feature.js';
|
|
6
|
-
import { generateRule } from './rule.js';
|
|
7
|
-
|
|
8
|
-
export {
|
|
9
|
-
generateTests,
|
|
10
|
-
generateExample,
|
|
11
|
-
generateExamples,
|
|
12
|
-
generateScenarioOutline,
|
|
13
|
-
generateFeature,
|
|
14
|
-
generateRule,
|
|
15
|
-
};
|