vitest-cucumber-plugin 0.6.0 → 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 +2 -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/{src → dist}/generate/example.js +7 -10
- 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/{src → dist}/generate/rule.js +9 -12
- 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 +9 -9
- 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/{src → dist}/generate/util.js +5 -5
- package/dist/generate/util.js.map +1 -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 +1 -1
- package/{src → dist}/gherkin.umd.js +1 -1
- 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/{src → dist}/parse.js +5 -9
- 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 +16 -23
- 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 +15 -28
- 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 -12
- package/rollup-tags-expression.js +0 -11
- package/run-tests +0 -9
- package/src/generate/examples.js +0 -48
- package/src/generate/feature.js +0 -72
- package/src/generate/index.js +0 -15
- package/src/generate/scenario-outline.js +0 -21
- package/src/gherkin-lexer-shared.cjs +0 -4
- package/src/gherkin-lexer.js +0 -63
- package/src/gherkin.ne +0 -211
- package/src/hooks.js +0 -77
- package/src/index.js +0 -95
- package/src/logger.js +0 -14
- package/src/parameterize.js +0 -7
- 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/languages/features/en.feature +0 -8
- package/tests/languages/features/no.feature +0 -10
- package/tests/languages/features/step_definitions/en.js +0 -15
- package/tests/languages/features/step_definitions/no.js +0 -21
- package/tests/languages/package-lock.json +0 -1204
- package/tests/languages/package.json +0 -11
- package/tests/languages/vite.config.js +0 -13
- 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}/gherkin-languages.json +0 -0
- /package/{src → dist}/tags-expression.js +0 -0
- /package/{src → dist}/tags-expression.umd.js +0 -0
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { defineConfig } from 'vitest/config'
|
|
2
|
-
import vitestCucumberPlugin from 'vitest-cucumber-plugin';
|
|
3
|
-
|
|
4
|
-
export default defineConfig(({ mode }) => {
|
|
5
|
-
const logLevel = (mode === 'test-debug') ? 'info' : 'warn';
|
|
6
|
-
return {
|
|
7
|
-
plugins: [vitestCucumberPlugin()],
|
|
8
|
-
test: {
|
|
9
|
-
include : [ '**/*.feature' ],
|
|
10
|
-
cucumber : { logLevel },
|
|
11
|
-
},
|
|
12
|
-
}
|
|
13
|
-
});
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
Feature: BeforeAll hooks
|
|
2
|
-
Scenario: BeforeAll hooks are run once
|
|
3
|
-
Given nothing
|
|
4
|
-
When nothing happens
|
|
5
|
-
Then the "beforeAll" property is an array with the values:
|
|
6
|
-
| beforeAll1 |
|
|
7
|
-
| beforeAll2 |
|
|
8
|
-
|
|
9
|
-
Scenario: BeforeAll hooks should be the same this time
|
|
10
|
-
Given nothing
|
|
11
|
-
When nothing happens
|
|
12
|
-
Then the "beforeAll" property is an array with the values:
|
|
13
|
-
| beforeAll1 |
|
|
14
|
-
| beforeAll2 |
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
Feature: Before hooks
|
|
2
|
-
Scenario: The Before hooks should have been run
|
|
3
|
-
Given nothing
|
|
4
|
-
When nothing happens
|
|
5
|
-
Then the "before" property is an array with the values:
|
|
6
|
-
| before1 |
|
|
7
|
-
| before2 |
|
|
8
|
-
|
|
9
|
-
Scenario: The After hooks should have cleared out the before property
|
|
10
|
-
Given nothing
|
|
11
|
-
When nothing happens
|
|
12
|
-
Then the "before" property is an array with the values:
|
|
13
|
-
| before1 |
|
|
14
|
-
| before2 |
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { Given, When, Then, DataTable } from 'vitest-cucumber-plugin';
|
|
2
|
-
import { expect } from 'vitest'
|
|
3
|
-
import _ from 'lodash/fp';
|
|
4
|
-
|
|
5
|
-
Given('nothing',(state) => state);
|
|
6
|
-
Then('nothing happens',(state) => state);
|
|
7
|
-
When('the {string} property is an array with the values:',(state,[ propertyName ],dataTable) => {
|
|
8
|
-
const values = _.flatten(dataTable);
|
|
9
|
-
expect(state[propertyName]).toEqual(values);
|
|
10
|
-
return state;
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
When('the {string} property is an array with the integer values:',(state,[ propertyName ],dataTable) => {
|
|
14
|
-
let values = _.flatten(dataTable);
|
|
15
|
-
values = _.map(parseInt)(values);
|
|
16
|
-
expect(state[propertyName]).toEqual(values);
|
|
17
|
-
return state;
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
When('the {string} property does not exist',(state,[propertyName]) => {
|
|
21
|
-
expect(_.has('propertyName',state)).toBeFalsy();
|
|
22
|
-
return state;
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
When('the {string} property is an empty array',(state,[ propertyName ]) => {
|
|
26
|
-
expect(state[propertyName]).toEqual([]);
|
|
27
|
-
return state;
|
|
28
|
-
});
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import { BeforeAll, AfterAll, Before, After, BeforeStep, AfterStep } from 'vitest-cucumber-plugin';
|
|
2
|
-
import _ from 'lodash/fp.js';
|
|
3
|
-
|
|
4
|
-
BeforeAll('add beforeAll1',(state) => {
|
|
5
|
-
return _.set('beforeAll',_.concat(_.getOr([],'beforeAll',state),'beforeAll1'),state);
|
|
6
|
-
});
|
|
7
|
-
|
|
8
|
-
BeforeAll('add beforeAll2',(state) => {
|
|
9
|
-
return _.set('beforeAll',_.concat(_.getOr([],'beforeAll',state),'beforeAll2'),state);
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
AfterAll('check that BeforeAll happened',(state) => {
|
|
13
|
-
if (!_.isEqual(state.beforeAll,['beforeAll1','beforeAll2'])) {
|
|
14
|
-
throw new Error('beforeAll is wrong!');
|
|
15
|
-
}
|
|
16
|
-
return state;
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
AfterAll('add afterAll1',(state) => {
|
|
20
|
-
return _.set('afterAll',_.concat(_.getOr([],'afterAll',state),'afterAll1'),state);
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
AfterAll('add afterAll2',(state) => {
|
|
24
|
-
return _.set('afterAll',_.concat(_.getOr([],'afterAll',state),'afterAll2'),state);
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
AfterAll('check that AfterAll happened',(state) => {
|
|
28
|
-
if (!_.isEqual(state.afterAll,['afterAll1','afterAll2'])) {
|
|
29
|
-
throw new Error('afterAll is wrong!');
|
|
30
|
-
}
|
|
31
|
-
return state;
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
Before('add before1',(state) => {
|
|
35
|
-
return _.set('before',_.concat(_.getOr([],'before',state),'before1'),state);
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
Before('add before2',(state) => {
|
|
39
|
-
return _.set('before',_.concat(_.getOr([],'before',state),'before2'),state);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
After('check that Before happened',(state) => {
|
|
43
|
-
if (!_.isEqual(state.before,['before1','before2'])) {
|
|
44
|
-
throw new Error('before is wrong!');
|
|
45
|
-
}
|
|
46
|
-
return state;
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
After('add after1',(state) => {
|
|
50
|
-
return _.set('after',_.concat(_.getOr([],'after',state),'after1'),state);
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
After('add after2',(state) => {
|
|
54
|
-
return _.set('after',_.concat(_.getOr([],'after',state),'after2'),state);
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
After('check that After happened',(state) => {
|
|
58
|
-
if (!_.isEqual(state.after,['after1','after2'])) {
|
|
59
|
-
throw new Error('after is wrong!');
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
state = _.set('after',[],state);
|
|
63
|
-
state = _.set('before',[],state);
|
|
64
|
-
return state;
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
BeforeStep('add index to beforeStep',(state) => {
|
|
68
|
-
const beforeStep = _.getOr([],'beforeStep',state);
|
|
69
|
-
return _.set('beforeStep',_.concat(beforeStep.length,beforeStep),state)
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
AfterStep('remove index from beforeStep',(state) => {
|
|
73
|
-
const beforeStep = _.getOr([],'beforeStep',state);
|
|
74
|
-
return _.set('beforeStep',_.tail(1,beforeStep),state)
|
|
75
|
-
});
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { BeforeAll, AfterAll, Before, After, BeforeStep, AfterStep } from 'vitest-cucumber-plugin';
|
|
2
|
-
import _ from 'lodash/fp.js';
|
|
3
|
-
|
|
4
|
-
Before({ tags : '@hooks and not @nobefore', name: 'add before' },(state) => {
|
|
5
|
-
return _.set('beforeTags',_.concat(_.getOr([],'beforeTags',state),'beforeTags'),state);
|
|
6
|
-
});
|
|
7
|
-
|
|
8
|
-
After({ tags : '@hooks', name : 'clear beforeTags' },(state) => {
|
|
9
|
-
state = _.set('beforeTags',[],state);
|
|
10
|
-
return state;
|
|
11
|
-
});
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
@hooks
|
|
2
|
-
Feature: Hooks can be selectively used with tags
|
|
3
|
-
Scenario: The Before hooks should have been run
|
|
4
|
-
Given nothing
|
|
5
|
-
When nothing happens
|
|
6
|
-
Then the "beforeTags" property is an array with the values:
|
|
7
|
-
| beforeTags |
|
|
8
|
-
|
|
9
|
-
# Disable the Before hook for this Scenario
|
|
10
|
-
@nobefore
|
|
11
|
-
Scenario:
|
|
12
|
-
Given nothing
|
|
13
|
-
When nothing happens
|
|
14
|
-
Then the "beforeTags" property is an empty array
|