Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

remove support for generators #1725

Merged
merged 9 commits into from
Jul 17, 2021
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .mocharc.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@ colors: true
file:
- test/test_helper.ts
full-trace: true
forbid-only: true
forbid-pending: true
recursive: true
reporter: dot
require: 'ts-node/register'
7 changes: 5 additions & 2 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,13 @@ Please see [CONTRIBUTING.md](https://github.com/cucumber/cucumber/blob/master/CO
----
## [Unreleased] (In Git)

See the [migration guide](./docs/migration.md) for details of how to migrate from 7.x.x to 8.x.x

### Breaking changes

* Drop support for Node.js 10 and 15, add support for Node.js 16
* Remove deprecated `--retryTagFilter` option (the correct option is `--retry-tag-filter`)
* Remove deprecated `--retryTagFilter` option (the correct option is `--retry-tag-filter`)
* Remove `setDefinitionFunctionWrapper` and step definition option `wrapperOptions`

### Added

Expand All @@ -25,7 +28,7 @@ Please see [CONTRIBUTING.md](https://github.com/cucumber/cucumber/blob/master/CO
### Fixed

* Prevent duplicate scenario execution where the same feature is targeted in multiple line expressions ([#1706](https://github.com/cucumber/cucumber-js/issues/1706))
* Fixed reports banner to point to [new docs](https://cucumber.io/docs/cucumber/environment-variables/) about environment variables
* Fixed reports banner to point to [new docs](https://cucumber.io/docs/cucumber/environment-variables/) about environment variables

## [7.3.0] (2021-06-17)

Expand Down
1 change: 0 additions & 1 deletion dependency-lint.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@ ignoreErrors:
- '@typescript-eslint/eslint-plugin' # peer dependency of standard-with-typescript
- '@typescript-eslint/parser' # peer dependency of @typescript-eslint/eslint-plugin
- '@types/*' # type definitions
- bluebird # features/generator_step_definitions.feature
- coffeescript # features/compiler.feature
- eslint-config-prettier # .eslintrc.yml - extends - prettier
- eslint-config-standard-with-typescript # .eslintrc.yml - extends - standard-with-typescript
Expand Down
16 changes: 12 additions & 4 deletions docs/migration.md
Original file line number Diff line number Diff line change
@@ -1,14 +1,22 @@
# Migrating to cucumber-js 7.x.x
# Migrating from 7.x.x to 8.x.x

## Removal of setDefinitionFunctionWrapper

If this was used to wrap generator functions, please transition to using async / await.
If this was used to wrap step definitions, please use `BeforeStep` / `AfterStep` hooks instead.
If you had other use cases, please create an issue.

# Migrating from 6.x.x to 7.x.x

## Package Name

cucumber-js is now published at `@cucumber/cucumber` instead of `cucumber`. To upgrade, you'll need to remove the old package and add the new one:

```shell
$ npm rm cucumber
$ npm install --save-dev @cucumber/cucumber
```
```

You'll need to update any `import`/`require` statements in your support code to use the new package name.

(The executable is still `cucumber-js` though.)
Expand Down
32 changes: 0 additions & 32 deletions docs/support_files/api_reference.md
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,6 @@ Aliases: `Given`, `When`, `Then`.
* `pattern`: A regex or string pattern to match against a gherkin step.
* `options`: An object with the following keys:
- `timeout`: A step-specific timeout, to override the default timeout.
- `wrapperOptions`: Step-specific options that are passed to the definition function wrapper.
* `fn`: A function, which should be defined as follows:
- Should have one argument for each capture in the regular expression.
- May have an additional argument if the gherkin step has a docstring or data table.
Expand All @@ -132,37 +131,6 @@ Set the default timeout for asynchronous steps. Defaults to `5000` milliseconds.

---

#### `setDefinitionFunctionWrapper(wrapper)`

Set a function used to wrap step / hook definitions.

The `wrapper` function is expected to take 2 arguments:

- `fn` is the original function defined for the step - needs to be called in order for the step to be run.
- `options` is the step specific `wrapperOptions` and may be undefined.

A common use case is attaching a screenshot on step failure - this would typically look something like (for a promise-based setup):

```javascript
setDefinitionFunctionWrapper(function(fn, options) {
return function(...args) {
// call original function with correct `this` and arguments
// ensure return value of function is returned
return fn.apply(this, args)
.catch(error => {
// call a method on world
this.doScreenshot();
// rethrow error to avoid swallowing failure
throw error;
});
}
})
```

When used, the result is wrapped again to ensure it has the same length of the original step / hook definition.

---

#### `setWorldConstructor(constructor)`

Set a custom world constructor, to override the default world constructor:
Expand Down
30 changes: 0 additions & 30 deletions docs/support_files/step_definitions.md
Original file line number Diff line number Diff line change
Expand Up @@ -69,36 +69,6 @@ When(/^I view my profile$/, function () {
});
```


## Definition function wrapper

If you would like to wrap step or hook definitions in with some additional logic you can use `setDefinitionFunctionWrapper(fn)`. The definitions will be wrapped after they have all been loaded but before the tests begin to run. One example usage is wrapping generator functions to return promises. Cucumber will do an additional stage of wrapping to ensure the function retains its original length.

```javascript
// features/step_definitions/file_steps.js
const { Then } = require('@cucumber/cucumber');
const assert = require('assert');
const mzFs = require('mz/fs');

Then(/^the file named (.*) is empty$/, function *(fileName) {
contents = yield mzFs.readFile(fileName, 'utf8');
assert.equal(contents, '');
});

// features/support/setup.js
const { setDefinitionFunctionWrapper } = require('@cucumber/cucumber');
const isGenerator = require('is-generator');
const Promise = require('bluebird');

setDefinitionFunctionWrapper(function (fn) {
if (isGenerator.fn(fn)) {
return Promise.coroutine(fn);
} else {
return fn;
}
});
```

## Pending steps

Each interface has its own way of marking a step as pending
Expand Down
61 changes: 0 additions & 61 deletions features/generator_step_definitions.feature

This file was deleted.

35 changes: 0 additions & 35 deletions features/step_wrapper_with_options.feature

This file was deleted.

4 changes: 0 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -176,7 +176,6 @@
"@cucumber/messages": "^16.0.1",
"@cucumber/tag-expressions": "^3.0.1",
"assertion-error-formatter": "^3.0.0",
"bluebird": "^3.7.2",
"capital-case": "^1.0.4",
"cli-table3": "^0.6.0",
"colors": "^1.4.0",
Expand All @@ -187,7 +186,6 @@
"figures": "^3.2.0",
"glob": "^7.1.6",
"indent-string": "^4.0.0",
"is-generator": "^1.0.3",
"is-stream": "^2.0.0",
"knuth-shuffle-seeded": "^1.0.6",
"mz": "^2.7.0",
Expand All @@ -198,15 +196,13 @@
"stacktrace-js": "^2.0.2",
"string-argv": "^0.3.1",
"tmp": "^0.2.1",
"util-arity": "^1.1.0",
"verror": "^1.10.0"
},
"devDependencies": {
"@cucumber/compatibility-kit": "7.0.0",
"@cucumber/message-streams": "2.1.0",
"@cucumber/query": "10.1.0",
"@sinonjs/fake-timers": "7.1.2",
"@types/bluebird": "3.5.35",
"@types/chai": "4.2.19",
"@types/dirty-chai": "2.0.2",
"@types/express": "4.17.12",
Expand Down
8 changes: 0 additions & 8 deletions src/cli/helpers_spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,6 @@ describe('helpers', () => {
stepDefinitions: [
new StepDefinition({
code: noopFunction,
unwrappedCode: noopFunction,
id: '0',
line: 9,
options: {},
Expand Down Expand Up @@ -173,7 +172,6 @@ describe('helpers', () => {
stepDefinitions: [
new StepDefinition({
code: noopFunction,
unwrappedCode: noopFunction,
id: '0',
line: 9,
options: {},
Expand Down Expand Up @@ -211,7 +209,6 @@ describe('helpers', () => {
beforeTestCaseHookDefinitions: [
new TestCaseHookDefinition({
code: noopFunction,
unwrappedCode: noopFunction,
id: '0',
line: 3,
options: {
Expand All @@ -223,15 +220,13 @@ describe('helpers', () => {
afterTestCaseHookDefinitions: [
new TestCaseHookDefinition({
code: noopFunction,
unwrappedCode: noopFunction,
id: '1',
line: 7,
options: {},
uri: 'features/support/hooks.js',
}),
new TestCaseHookDefinition({
code: noopFunction,
unwrappedCode: noopFunction,
id: '2',
line: 11,
options: {},
Expand Down Expand Up @@ -285,7 +280,6 @@ describe('helpers', () => {
beforeTestRunHookDefinitions: [
new TestRunHookDefinition({
code: noopFunction,
unwrappedCode: noopFunction,
id: '0',
line: 3,
options: {},
Expand All @@ -295,15 +289,13 @@ describe('helpers', () => {
afterTestRunHookDefinitions: [
new TestRunHookDefinition({
code: noopFunction,
unwrappedCode: noopFunction,
id: '1',
line: 7,
options: {},
uri: 'features/support/run-hooks.js',
}),
new TestRunHookDefinition({
code: noopFunction,
unwrappedCode: noopFunction,
id: '2',
line: 11,
options: {},
Expand Down
2 changes: 1 addition & 1 deletion src/formatter/helpers/usage_helpers/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ function buildEmptyMapping(
const mapping: Record<string, IUsage> = {}
stepDefinitions.forEach((stepDefinition) => {
mapping[stepDefinition.id] = {
code: stepDefinition.unwrappedCode.toString(),
code: stepDefinition.code.toString(),
line: stepDefinition.line,
pattern: stepDefinition.expression.source,
patternType: stepDefinition.expression.constructor.name,
Expand Down
Loading