wdio-rerun-service 1.7.7 → 1.7.8

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.
@@ -0,0 +1,68 @@
1
+ name: Manual NPM Publish
2
+
3
+ on:
4
+ workflow_dispatch:
5
+ inputs:
6
+ releaseType:
7
+ description: "Release type - major, minor or patch"
8
+ required: true
9
+ type: choice
10
+ default: "patch"
11
+ options:
12
+ - patch
13
+ - minor
14
+ - major
15
+ distTag:
16
+ description: 'NPM tag (e.g. use "next --preRelease=alpha --github.preRelease" to release a test version)'
17
+ required: true
18
+ default: 'latest'
19
+ preRelease:
20
+ description: If latest release was a pre-release (e.g. X.X.X-alpha.0) and you want to push another one, pick "yes"
21
+ required: true
22
+ type: choice
23
+ default: "no"
24
+ options:
25
+ - "yes"
26
+ - "no"
27
+
28
+ env:
29
+ NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
30
+
31
+ jobs:
32
+ release:
33
+ runs-on: ubuntu-latest
34
+ steps:
35
+ - uses: actions/checkout@v3
36
+ with:
37
+ ref: v7
38
+ fetch-depth: 0
39
+ - uses: actions/setup-node@v3
40
+ with:
41
+ node-version: 18.x
42
+ - name: NPM Setup
43
+ run: |
44
+ npm set registry "https://registry.npmjs.org/"
45
+ npm set //registry.npmjs.org/:_authToken $NPM_TOKEN
46
+ npm whoami
47
+ - name: Git Setup
48
+ run: |
49
+ git config --global user.email "bot@webdriver.io"
50
+ git config --global user.name "WebdriverIO Release Bot"
51
+ - name: Install Dependencies
52
+ run: npm ci --ignore-scripts
53
+ - name: Build Project
54
+ run: npm run build --if-present
55
+ env:
56
+ NODE_ENV: production
57
+ - name: Release
58
+ run: npx release-it ${{github.event.inputs.releaseType}} --github.release --ci --npm.skipChecks --no-git.requireCleanWorkingDir --npm.tag=${{github.event.inputs.distTag}}
59
+ env:
60
+ NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
61
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
62
+ if: ${{ github.event.inputs.preRelease == 'no' }}
63
+ - name: Pre-Release
64
+ run: npx release-it ${{github.event.inputs.releaseType}} --github.release --ci --npm.skipChecks --no-git.requireCleanWorkingDir --preRelease=alpha --github.preRelease --npm.tag=next
65
+ env:
66
+ NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
67
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
68
+ if: ${{ github.event.inputs.preRelease == 'yes' }}
@@ -1,52 +1,56 @@
1
1
  # This workflow will do a clean install of node dependencies, build the source code and run tests across different versions of node
2
2
  # For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions
3
3
 
4
- name: wdio-rerun-service CI
4
+ name: Test
5
5
 
6
6
  on:
7
7
  push:
8
8
  branches:
9
- - master
10
9
  - main
11
10
  - v7
12
11
  - lts
13
12
  pull_request:
14
13
  branches:
15
- - master
16
14
  - main
17
15
  - v7
18
16
  - lts
17
+
18
+ permissions:
19
+ contents: read # to fetch code (actions/checkout)
20
+
19
21
  jobs:
20
22
  build:
21
23
  runs-on: ubuntu-latest
22
24
  strategy:
23
25
  matrix:
24
- node-version: [12.x, 13.x, 14.x]
25
- # See supported Node.js release schedule at https://nodejs.org/en/about/releases/
26
+ node-version: [16.x, 18.x]
26
27
  steps:
27
- - uses: actions/checkout@v2
28
+ - uses: actions/checkout@v3
28
29
  - name: Use Node.js ${{ matrix.node-version }}
29
- uses: actions/setup-node@v1
30
+ uses: actions/setup-node@v3
30
31
  with:
31
32
  node-version: ${{ matrix.node-version }}
32
- - run: npm ci
33
- - run: npm install -g eslint
33
+ - run: npm i -g npm@latest
34
+ - run: npm ci --ignore-scripts
34
35
  - run: npm run build --if-present
35
- - run: npm run test
36
-
36
+ - run: npm test
37
+ env:
38
+ CI: true
39
+
37
40
  build-windows:
38
41
  runs-on: windows-latest
39
42
  strategy:
40
43
  matrix:
41
- node-version: [12.x]
42
- # See supported Node.js release schedule at https://nodejs.org/en/about/releases/
44
+ node-version: [16.x]
43
45
  steps:
44
- - uses: actions/checkout@v2
46
+ - uses: actions/checkout@v3
45
47
  - name: Use Node.js ${{ matrix.node-version }}
46
- uses: actions/setup-node@v1
48
+ uses: actions/setup-node@v3
47
49
  with:
48
50
  node-version: ${{ matrix.node-version }}
49
- - run: npm ci
50
- - run: npm install -g eslint
51
+ - run: npm i -g npm@latest
52
+ - run: npm ci --ignore-scripts
51
53
  - run: npm run build --if-present
52
- - run: npm run test
54
+ - run: npm test
55
+ env:
56
+ CI: true
@@ -0,0 +1,30 @@
1
+ # this workflow merges requests from Dependabot if tests are passing
2
+ name: Merge me!
3
+
4
+ on:
5
+ workflow_run:
6
+ workflows:
7
+ - Test
8
+ types:
9
+ - completed
10
+
11
+ jobs:
12
+ merge-me:
13
+ name: Merge me!
14
+ runs-on: ubuntu-latest
15
+ steps:
16
+ - name: Merge me!
17
+ if: ${{ github.event.workflow_run.conclusion == 'success' }}
18
+ uses: ridedott/merge-me-action@v2
19
+ with:
20
+ # Depending on branch prodtection rules, a manually populated
21
+ # `GITHUB_TOKEN_WORKAROUND` secret with permissions to push to
22
+ # a protected branch must be used.
23
+ #
24
+ # When using a custom token, it is recommended to leave the following
25
+ # comment for other developers to be aware of the reasoning behind it:
26
+ #
27
+ # This must be used as GitHub Actions token does not support pushing
28
+ # to protected branches.
29
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
30
+ PRESET: DEPENDABOT_MINOR
package/CHANGELOG.md CHANGED
@@ -11,6 +11,17 @@
11
11
 
12
12
  _Note: Gaps between patch versions are faulty, broken or test releases._
13
13
 
14
+ ## v1.7.8 (2023-01-18)
15
+ #### :bug: Bug Fix
16
+ * Service release; no new features/fixes
17
+
18
+ ## v1.7.7 (2023-01-18)
19
+ #### :bug: Bug Fix
20
+ * [[#53]](https://github.com/webdriverio-community/wdio-rerun-service/pull/53) Generate failure line number at Example data line rather than the Scenario Outline line ([@wenzhhu](https://github.com/wenzhhu))
21
+
22
+ #### Committers: 1
23
+ - [@wenzhhu](https://github.com/wenzhhu)
24
+
14
25
  ---
15
26
  ## v1.7.6 (2022-09-13)
16
27
  #### :bug: Bug Fix
package/README.md CHANGED
@@ -32,7 +32,7 @@ The easiest way is to add `wdio-rerun-service` to `devDependencies` in your `pac
32
32
  ```json
33
33
  {
34
34
  "devDependencies": {
35
- "wdio-rerun-service": "^1.7.6"
35
+ "wdio-rerun-service": "^1.7.8"
36
36
  }
37
37
  }
38
38
  ```
package/build/index.js CHANGED
@@ -1,7 +1,5 @@
1
1
  "use strict";
2
2
 
3
- require("source-map-support/register");
4
-
5
3
  const fs = require('fs');
6
4
 
7
5
  const path = require('path');
@@ -17,14 +15,16 @@ class RerunService {
17
15
  ignoredTags,
18
16
  rerunDataDir,
19
17
  rerunScriptPath,
20
- commandPrefix
18
+ commandPrefix,
19
+ customParameters
21
20
  } = {}) {
22
21
  this.nonPassingItems = [];
23
22
  this.serviceWorkerId;
24
- this.ignoredTags = ignoredTags ? ignoredTags : [];
25
- this.rerunDataDir = rerunDataDir ? rerunDataDir : "./results/rerun";
26
- this.rerunScriptPath = rerunScriptPath ? rerunScriptPath : "./rerun.sh";
27
- this.commandPrefix = commandPrefix ? commandPrefix : "";
23
+ this.ignoredTags = ignoredTags || [];
24
+ this.rerunDataDir = rerunDataDir || "./results/rerun";
25
+ this.rerunScriptPath = rerunScriptPath || "./rerun.sh";
26
+ this.commandPrefix = commandPrefix || "";
27
+ this.customParameters = customParameters || "";
28
28
  this.specFile = "";
29
29
  }
30
30
 
@@ -53,20 +53,35 @@ class RerunService {
53
53
  }
54
54
  }
55
55
 
56
- afterScenario(world) {
57
- const status = world.result.status;
58
- const scenarioLineNumber = world.gherkinDocument.feature.children.filter(child => {
56
+ afterScenario(world, result, context) {
57
+ const CUCUMBER_STATUS_MAP = ['UNKNOWN', 'PASSED', 'SKIPPED', 'PENDING', 'UNDEFINED', 'AMBIGUOUS', 'FAILED'];
58
+ const status = typeof world.result.status === 'number' ? CUCUMBER_STATUS_MAP[world.result.status || 0] : world.result.status;
59
+ const scenario = world.gherkinDocument.feature.children.filter(child => {
59
60
  if (child.scenario) {
60
61
  return child.scenario && world.pickle.astNodeIds.includes(child.scenario.id.toString());
61
62
  }
62
- })[0].scenario.location.line;
63
+ })[0].scenario;
64
+ let scenarioLineNumber = scenario.location.line;
65
+
66
+ if (scenario.examples && scenario.examples.length > 0) {
67
+ let exampleLineNumber = 0;
68
+ scenario.examples.find(example => example.tableBody.find(row => {
69
+ if (row.id === world.pickle.astNodeIds[1]) {
70
+ exampleLineNumber = row.location.line;
71
+ return true;
72
+ } else {
73
+ return false;
74
+ }
75
+ }));
76
+ scenarioLineNumber = exampleLineNumber;
77
+ }
63
78
 
64
79
  if (browser.config.framework === 'cucumber' && status !== 'PASSED' && status !== 'SKIPPED') {
65
80
  const scenarioLocation = `${world.pickle.uri}:${scenarioLineNumber}`;
66
81
  const tagsList = world.pickle.tags.map(tag => tag.name);
67
82
  const service = this;
68
83
 
69
- if (this.ignoredTags && tagsList.some(ignoredTag => service.ignoredTags.includes(ignoredTag))) {} else {
84
+ if (this.ignoredTags && !tagsList.some(ignoredTag => service.ignoredTags.includes(ignoredTag))) {
70
85
  this.nonPassingItems.push({
71
86
  location: scenarioLocation,
72
87
  failure: world.result.message
@@ -88,12 +103,7 @@ class RerunService {
88
103
  const rerunFiles = fs.readdirSync(directoryPath);
89
104
 
90
105
  if (rerunFiles.length > 0) {
91
- let rerunCommand = `DISABLE_RERUN=true node_modules/.bin/wdio ${argv._[0]} `;
92
-
93
- if (this.commandPrefix) {
94
- rerunCommand = `${this.commandPrefix} ${rerunCommand}`;
95
- }
96
-
106
+ let rerunCommand = `${this.commandPrefix} DISABLE_RERUN=true node_modules/.bin/wdio ${argv._[0]} ${this.customParameters} `;
97
107
  let failureLocations = [];
98
108
  rerunFiles.forEach(file => {
99
109
  const json = JSON.parse(fs.readFileSync(`${this.rerunDataDir}/${file}`));
@@ -113,5 +123,4 @@ class RerunService {
113
123
  }
114
124
 
115
125
  ;
116
- module.exports = RerunService;
117
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["fs","require","path","v5","uuidv5","argv","process","slice","RerunService","constructor","ignoredTags","rerunDataDir","rerunScriptPath","commandPrefix","nonPassingItems","serviceWorkerId","specFile","before","capabilities","specs","mkdirSync","recursive","Date","now","afterTest","test","context","error","result","duration","passed","retries","browser","config","framework","message","push","location","failure","afterScenario","world","status","scenarioLineNumber","gherkinDocument","feature","children","filter","child","scenario","pickle","astNodeIds","includes","id","toString","line","scenarioLocation","uri","tagsList","tags","map","tag","name","service","some","ignoredTag","after","length","writeFileSync","JSON","stringify","onComplete","exitCode","results","directoryPath","join","cwd","existsSync","rerunFiles","readdirSync","rerunCommand","_","failureLocations","forEach","file","json","parse","readFileSync","replace","failureLocationsUnique","Set","failureLocation","module","exports"],"mappings":"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","sourcesContent":["const fs = require('fs');\nconst path = require('path');\nconst { v5: uuidv5 } = require('uuid');\n\nconst argv = require('minimist')(process.argv.slice(2));\n\nclass RerunService {\n\n    constructor({ ignoredTags, rerunDataDir, rerunScriptPath, commandPrefix } = {}) {\n        this.nonPassingItems = [];\n        this.serviceWorkerId;\n        this.ignoredTags = ignoredTags ? ignoredTags : [];\n        this.rerunDataDir = rerunDataDir ? rerunDataDir : \"./results/rerun\";\n        this.rerunScriptPath = rerunScriptPath ? rerunScriptPath : \"./rerun.sh\";\n        this.commandPrefix = commandPrefix ? commandPrefix : \"\";\n        this.specFile = \"\";\n    }\n\n    before(capabilities, specs) {\n        this.specFile = specs[0];\n        // console.log(`Re-run service is activated. Data directory: ${this.rerunDataDir}`);\n        fs.mkdirSync(this.rerunDataDir, { recursive: true });\n        // INFO: `namespace` below copied from: https://github.com/kelektiv/node-uuid/blob/master//lib/v35.js#L54:16\n        this.serviceWorkerId = uuidv5(`${Date.now()}`, '6ba7b810-9dad-11d1-80b4-00c04fd430c8');\n    }\n\n    afterTest(test, context, { error, result, duration, passed, retries }) {\n        if (browser.config.framework !== 'cucumber' && !passed) {\n            // console.log(`Re-run service is inspecting non-passing test.`);\n            // console.log(`Test location: ${this.specFile}`);\n            if (error && error.message) {\n                this.nonPassingItems.push({ location: this.specFile, failure: error.message });\n            } else {\n                // console.log(\"The non-passing test did not contain any error message, it could not be added for re-run.\")\n            }\n        }\n    }\n\n    // Executed after a Cucumber scenario ends.\n    afterScenario(world) {\n        const status = world.result.status;\n        const scenarioLineNumber = world.gherkinDocument.feature.children.filter((child) => {\n            if(child.scenario){\n                return child.scenario && world.pickle.astNodeIds.includes(child.scenario.id.toString());\n            }\n        })[0].scenario.location.line;\n\n        if (browser.config.framework === 'cucumber' && (status !== 'PASSED' && status !== 'SKIPPED')) {\n            // console.log(`Re-run service is inspecting non-passing scenario.`);\n            const scenarioLocation = `${world.pickle.uri}:${scenarioLineNumber}`;\n            // console.log(`Scenario location: ${scenarioLocation}`);\n            const tagsList = world.pickle.tags.map(tag => tag.name);\n            // console.log(`Scenario tags: ${tagsList}`);\n            const service = this;\n            if (this.ignoredTags && tagsList.some(ignoredTag => service.ignoredTags.includes(ignoredTag))) {\n                // console.log(`Re-run service will ignore the current scenario since it includes one of the ignored tags: ${this.ignoredTags}`);\n            } else {\n                this.nonPassingItems.push({ location: scenarioLocation, failure: world.result.message });\n            }\n        }\n    }\n\n    after(result, capabilities, specs) {\n        if (this.nonPassingItems.length > 0) {\n            fs.writeFileSync(`${this.rerunDataDir}/rerun-${this.serviceWorkerId}.json`, JSON.stringify(this.nonPassingItems));\n        } else {\n            // console.log('Re-run service did not detect any non-passing scenarios or tests.');\n        }\n    }\n\n    onComplete(exitCode, config, capabilities, results) {\n        const directoryPath = path.join(process.cwd(), `${this.rerunDataDir}`);\n        if (fs.existsSync(directoryPath)) {\n            const rerunFiles = fs.readdirSync(directoryPath);\n            if (rerunFiles.length > 0) {\n                let rerunCommand = `DISABLE_RERUN=true node_modules/.bin/wdio ${argv._[0]} `;\n                if (this.commandPrefix) {\n                    rerunCommand = `${this.commandPrefix} ${rerunCommand}`;\n                }\n                let failureLocations = [];\n                rerunFiles.forEach(file => {\n                    const json = JSON.parse(fs.readFileSync(`${this.rerunDataDir}/${file}`));\n                    json.forEach(failure => {\n                        failureLocations.push(failure.location.replace(/\\\\/g, \"/\"));\n                    });\n                });\n                const failureLocationsUnique = [...new Set(failureLocations)];\n                failureLocationsUnique.forEach(failureLocation => {\n                    rerunCommand += ` --spec=${failureLocation}`;\n                });\n                fs.writeFileSync(this.rerunScriptPath, rerunCommand);\n                // console.log(`Re-run script has been generated @ ${this.rerunScriptPath}`);\n            }\n        }\n    }\n};\n\nmodule.exports = RerunService;\n"]}
126
+ module.exports = RerunService;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "wdio-rerun-service",
3
- "version": "1.7.7",
3
+ "version": "1.7.8",
4
4
  "description": "A WebdriverIO service to track and prepare for re-running failing or flaky Jasmine/Mocha tests or Cucumber Scenarios.",
5
5
  "author": "Mike Salvia <msalvia@jwplayer.com>",
6
6
  "homepage": "https://github.com/webdriverio-community/wdio-rerun-service",