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.
Files changed (192) hide show
  1. package/RELEASE_NOTES.md +3 -0
  2. package/dist/config.d.ts +11 -0
  3. package/dist/config.d.ts.map +1 -0
  4. package/dist/config.js +2 -0
  5. package/dist/config.js.map +1 -0
  6. package/dist/generate/example.d.ts +5 -0
  7. package/dist/generate/example.d.ts.map +1 -0
  8. package/dist/generate/example.js +18 -0
  9. package/dist/generate/example.js.map +1 -0
  10. package/dist/generate/examples.d.ts +5 -0
  11. package/dist/generate/examples.d.ts.map +1 -0
  12. package/dist/generate/examples.js +46 -0
  13. package/dist/generate/examples.js.map +1 -0
  14. package/dist/generate/feature.d.ts +10 -0
  15. package/dist/generate/feature.d.ts.map +1 -0
  16. package/dist/generate/feature.js +77 -0
  17. package/dist/generate/feature.js.map +1 -0
  18. package/dist/generate/index.d.ts +3 -0
  19. package/dist/generate/index.d.ts.map +1 -0
  20. package/dist/generate/index.js +3 -0
  21. package/dist/generate/index.js.map +1 -0
  22. package/dist/generate/rule.d.ts +5 -0
  23. package/dist/generate/rule.d.ts.map +1 -0
  24. package/dist/generate/rule.js +19 -0
  25. package/dist/generate/rule.js.map +1 -0
  26. package/dist/generate/scenario-outline.d.ts +5 -0
  27. package/dist/generate/scenario-outline.d.ts.map +1 -0
  28. package/dist/generate/scenario-outline.js +18 -0
  29. package/dist/generate/scenario-outline.js.map +1 -0
  30. package/dist/generate/tests.d.ts +4 -0
  31. package/dist/generate/tests.d.ts.map +1 -0
  32. package/{src → dist}/generate/tests.js +10 -10
  33. package/dist/generate/tests.js.map +1 -0
  34. package/dist/generate/util.d.ts +6 -0
  35. package/dist/generate/util.d.ts.map +1 -0
  36. package/dist/generate/util.js +9 -0
  37. package/dist/generate/util.js.map +1 -0
  38. package/dist/gherkin-languages.json +3790 -0
  39. package/dist/gherkin-lexer-shared.d.ts +6 -0
  40. package/dist/gherkin-lexer-shared.d.ts.map +1 -0
  41. package/dist/gherkin-lexer-shared.js +4 -0
  42. package/dist/gherkin-lexer-shared.js.map +1 -0
  43. package/dist/gherkin-lexer.d.ts +4 -0
  44. package/dist/gherkin-lexer.d.ts.map +1 -0
  45. package/dist/gherkin-lexer.js +68 -0
  46. package/dist/gherkin-lexer.js.map +1 -0
  47. package/{src → dist}/gherkin.js +24 -31
  48. package/{src → dist}/gherkin.umd.js +23 -31
  49. package/dist/hooks.d.ts +25 -0
  50. package/dist/hooks.d.ts.map +1 -0
  51. package/dist/hooks.js +94 -0
  52. package/dist/hooks.js.map +1 -0
  53. package/dist/index.d.ts +4 -0
  54. package/dist/index.d.ts.map +1 -0
  55. package/dist/index.js +4 -0
  56. package/dist/index.js.map +1 -0
  57. package/dist/logger.d.ts +5 -0
  58. package/dist/logger.d.ts.map +1 -0
  59. package/dist/logger.js +8 -0
  60. package/dist/logger.js.map +1 -0
  61. package/dist/parameterize.d.ts +3 -0
  62. package/dist/parameterize.d.ts.map +1 -0
  63. package/dist/parameterize.js +8 -0
  64. package/dist/parameterize.js.map +1 -0
  65. package/dist/parse.d.ts +3 -0
  66. package/dist/parse.d.ts.map +1 -0
  67. package/dist/parse.js +28 -0
  68. package/dist/parse.js.map +1 -0
  69. package/dist/state.d.ts +4 -0
  70. package/dist/state.d.ts.map +1 -0
  71. package/dist/state.js +2 -0
  72. package/dist/state.js.map +1 -0
  73. package/dist/statement.d.ts +71 -0
  74. package/dist/statement.d.ts.map +1 -0
  75. package/dist/statement.js +10 -0
  76. package/dist/statement.js.map +1 -0
  77. package/dist/steps.d.ts +20 -0
  78. package/dist/steps.d.ts.map +1 -0
  79. package/{src → dist}/steps.js +17 -24
  80. package/dist/steps.js.map +1 -0
  81. package/dist/tags.d.ts +5 -0
  82. package/dist/tags.d.ts.map +1 -0
  83. package/{src → dist}/tags.js +20 -33
  84. package/dist/tags.js.map +1 -0
  85. package/dist/vitest-cucumber-plugin.d.ts +13 -0
  86. package/dist/vitest-cucumber-plugin.d.ts.map +1 -0
  87. package/dist/vitest-cucumber-plugin.js +69 -0
  88. package/dist/vitest-cucumber-plugin.js.map +1 -0
  89. package/package.json +64 -34
  90. package/generate-parsers +0 -6
  91. package/rollup-gherkin.js +0 -10
  92. package/rollup-tags-expression.js +0 -10
  93. package/run-tests +0 -9
  94. package/src/generate/example.js +0 -21
  95. package/src/generate/examples.js +0 -49
  96. package/src/generate/feature.js +0 -72
  97. package/src/generate/index.js +0 -15
  98. package/src/generate/rule.js +0 -22
  99. package/src/generate/scenario-outline.js +0 -21
  100. package/src/generate/util.js +0 -9
  101. package/src/gherkin.ne +0 -217
  102. package/src/hooks.js +0 -78
  103. package/src/index.js +0 -92
  104. package/src/logger.js +0 -14
  105. package/src/parameterize.js +0 -7
  106. package/src/parse.js +0 -21
  107. package/src/tags-expression.ne +0 -43
  108. package/tests/background/features/background.feature +0 -25
  109. package/tests/background/features/step_definitions/steps.js +0 -30
  110. package/tests/background/features/support/hooks.js +0 -3
  111. package/tests/background/package-lock.json +0 -1204
  112. package/tests/background/package.json +0 -11
  113. package/tests/background/vite.config.js +0 -13
  114. package/tests/comments/features/is-it-friday.feature +0 -10
  115. package/tests/comments/features/step_definitions/stepdefs.js +0 -15
  116. package/tests/comments/package-lock.json +0 -1933
  117. package/tests/comments/package.json +0 -11
  118. package/tests/comments/vite.config.js +0 -9
  119. package/tests/data-tables/features/data-tables-escaping.feature +0 -27
  120. package/tests/data-tables/features/data-tables.feature +0 -44
  121. package/tests/data-tables/features/step_definitions/data-tables.js +0 -21
  122. package/tests/data-tables/package-lock.json +0 -1933
  123. package/tests/data-tables/package.json +0 -11
  124. package/tests/data-tables/vite.config.js +0 -13
  125. package/tests/doc-strings/features/doc-strings.feature +0 -21
  126. package/tests/doc-strings/features/step_definitions/doc-strings.js +0 -15
  127. package/tests/doc-strings/package-lock.json +0 -1933
  128. package/tests/doc-strings/package.json +0 -11
  129. package/tests/doc-strings/vite.config.js +0 -13
  130. package/tests/hooks/features/after-all.feature +0 -5
  131. package/tests/hooks/features/after.feature +0 -5
  132. package/tests/hooks/features/before-all.feature +0 -14
  133. package/tests/hooks/features/before-step.feature +0 -6
  134. package/tests/hooks/features/before.feature +0 -14
  135. package/tests/hooks/features/step_definitions/steps.js +0 -28
  136. package/tests/hooks/features/support/hooks.js +0 -75
  137. package/tests/hooks/features/support/tags-hooks.js +0 -11
  138. package/tests/hooks/features/tags.feature +0 -14
  139. package/tests/hooks/package-lock.json +0 -1204
  140. package/tests/hooks/package.json +0 -11
  141. package/tests/hooks/vite.config.js +0 -13
  142. package/tests/is-it-friday/features/is-it-friday.feature +0 -7
  143. package/tests/is-it-friday/features/step_definitions/stepdefs.js +0 -15
  144. package/tests/is-it-friday/package-lock.json +0 -1933
  145. package/tests/is-it-friday/package.json +0 -11
  146. package/tests/is-it-friday/vite.config.js +0 -13
  147. package/tests/is-it-friday-scenario-outline/features/is-it-friday.feature +0 -13
  148. package/tests/is-it-friday-scenario-outline/features/step_definitions/stepdefs.js +0 -15
  149. package/tests/is-it-friday-scenario-outline/package-lock.json +0 -1933
  150. package/tests/is-it-friday-scenario-outline/package.json +0 -11
  151. package/tests/is-it-friday-scenario-outline/vite.config.js +0 -9
  152. package/tests/is-it-friday-two-scenarios/features/is-it-friday.feature +0 -12
  153. package/tests/is-it-friday-two-scenarios/features/step_definitions/stepdefs.js +0 -19
  154. package/tests/is-it-friday-two-scenarios/package-lock.json +0 -1933
  155. package/tests/is-it-friday-two-scenarios/package.json +0 -11
  156. package/tests/is-it-friday-two-scenarios/vite.config.js +0 -9
  157. package/tests/is-it-friday-two-scenarios-multiple-feature-files/features/friday.feature +0 -7
  158. package/tests/is-it-friday-two-scenarios-multiple-feature-files/features/step_definitions/stepdefs.js +0 -19
  159. package/tests/is-it-friday-two-scenarios-multiple-feature-files/features/sunday.feature +0 -8
  160. package/tests/is-it-friday-two-scenarios-multiple-feature-files/package-lock.json +0 -1933
  161. package/tests/is-it-friday-two-scenarios-multiple-feature-files/package.json +0 -11
  162. package/tests/is-it-friday-two-scenarios-multiple-feature-files/vite.config.js +0 -9
  163. package/tests/keyword-aliases/features/scenario-outline.feature +0 -20
  164. package/tests/keyword-aliases/features/scenario.feature +0 -14
  165. package/tests/keyword-aliases/features/step_definitions/steps.js +0 -30
  166. package/tests/keyword-aliases/features/steps.feature +0 -28
  167. package/tests/keyword-aliases/features/support/hooks.js +0 -6
  168. package/tests/keyword-aliases/package-lock.json +0 -1933
  169. package/tests/keyword-aliases/package.json +0 -11
  170. package/tests/keyword-aliases/vite.config.js +0 -9
  171. package/tests/rule/features/rule.feature +0 -14
  172. package/tests/rule/features/step_definitions/stepdefs.js +0 -19
  173. package/tests/rule/package-lock.json +0 -1933
  174. package/tests/rule/package.json +0 -11
  175. package/tests/rule/vite.config.js +0 -9
  176. package/tests/tags/features/skip.feature +0 -9
  177. package/tests/tags/features/step_definitions/steps.js +0 -30
  178. package/tests/tags/features/support/hooks.js +0 -6
  179. package/tests/tags/features/tags-scenario-outline.feature +0 -37
  180. package/tests/tags/features/tags.feature +0 -26
  181. package/tests/tags/package-lock.json +0 -1204
  182. package/tests/tags/package.json +0 -11
  183. package/tests/tags/vite.config.js +0 -12
  184. package/tests/vue/features/step_definitions/test.js +0 -25
  185. package/tests/vue/features/support/components.js +0 -19
  186. package/tests/vue/features/test.feature +0 -10
  187. package/tests/vue/package-lock.json +0 -2164
  188. package/tests/vue/package.json +0 -18
  189. package/tests/vue/src/test.vue +0 -10
  190. package/tests/vue/vite.config.js +0 -15
  191. /package/{src → dist}/tags-expression.js +0 -0
  192. /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"}
@@ -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"}
@@ -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 : 'Given',
9
- then : 'Then',
10
- when : 'When',
6
+ given: 'Given',
7
+ then: 'Then',
8
+ when: 'When',
11
9
  };
12
-
13
10
  const expressionFactory = new ExpressionFactory(new ParameterTypeRegistry());
14
-
15
- export const addStepDefinition = (expression,f) => {
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 : matchesMapper(matches) });
28
- } else {
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('More than one step which matches: \''+step.type.name+' '+step.text+'\'');
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,5 @@
1
+ import { Tags } from './statement.js';
2
+ type TagsFunction = (tags?: Tags) => boolean;
3
+ declare const createTagsFunction: (tagsExpression?: string) => TagsFunction;
4
+ export { createTagsFunction, TagsFunction };
5
+ //# sourceMappingURL=tags.d.ts.map
@@ -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"}
@@ -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('parseTagsExpression expression: \''+tagsExpression+'\' results: '+JSON.stringify(parser.results));
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('createFunction tag: '+e);
21
+ log.debug(`createFunction tag: ${e}`);
27
22
  return (tags) => {
28
- const result = _.find((tag) => tag == e,tags);
29
- log.debug('tagsExpression tag: '+e+' tags: '+JSON.stringify(tags)+' match? '+result);
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('createFunction not '+JSON.stringify(e.expression));
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) => (l(tags) && r(tags));
40
+ return (tags) => l(tags) && r(tags);
50
41
  }
51
-
52
-
53
42
  if (e.operator == 'or') {
54
- return (tags) => (l(tags) || r(tags));
43
+ return (tags) => l(tags) || r(tags);
55
44
  }
56
-
57
- throw new Error('Couldn\'t parse tags expression');
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
@@ -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
- "name": "vitest-cucumber-plugin",
3
- "version": "0.5.6",
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
- "scripts": {
18
- "nearley": "./generate-parsers",
19
- "test": "./run-tests"
20
- },
21
- "dependencies": {
22
- "@cucumber/cucumber-expressions": "^16.1.2",
23
- "glob": "^10.2.2",
24
- "lodash": "^4.17.21",
25
- "moo": "^0.5.2",
26
- "nearley": "^2.20.1",
27
- "pino": "^8.11.0"
28
- },
29
- "devDependencies": {
30
- "@rollup/plugin-commonjs": "^24.1.0",
31
- "@types/lodash": "^4.14.194",
32
- "rollup": "^3.20.7"
33
- },
34
- "repository": "https://github.com/samuel-ziegler/vitest-cucumber-plugin.git"
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
@@ -1,6 +0,0 @@
1
- #!/bin/bash
2
-
3
- nearleyc src/gherkin.ne -o src/gherkin.umd.js || exit 1
4
- nearleyc src/tags-expression.ne -o src/tags-expression.umd.js || exit 1
5
- rollup -c rollup-gherkin.js || exit 1
6
- rollup -c rollup-tags-expression.js || exit 1
package/rollup-gherkin.js DELETED
@@ -1,10 +0,0 @@
1
- import commonjs from "@rollup/plugin-commonjs";
2
-
3
- export default {
4
- input: "src/gherkin.umd.js",
5
- output: {
6
- file: "src/gherkin.js",
7
- format: "es",
8
- },
9
- plugins: [commonjs()],
10
- };
@@ -1,10 +0,0 @@
1
- import commonjs from "@rollup/plugin-commonjs";
2
-
3
- export default {
4
- input: "src/tags-expression.umd.js",
5
- output: {
6
- file: "src/tags-expression.js",
7
- format: "es",
8
- },
9
- plugins: [commonjs()],
10
- };
package/run-tests DELETED
@@ -1,9 +0,0 @@
1
- #!/usr/bin/bash
2
-
3
- for i in `ls tests`; do
4
- echo $i
5
- pushd tests/$i
6
- npm install || exit 1
7
- npm test || exit 1
8
- popd
9
- done
@@ -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
- }
@@ -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
- }
@@ -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
- }
@@ -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
- };