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.
- package/.github/workflows/release.yml +68 -0
- package/.github/workflows/{node.js.yml → test.yml} +22 -18
- package/.github/workflows/update.yml +30 -0
- package/CHANGELOG.md +11 -0
- package/README.md +1 -1
- package/build/index.js +29 -20
- package/package.json +1 -1
|
@@ -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:
|
|
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: [
|
|
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@
|
|
28
|
+
- uses: actions/checkout@v3
|
|
28
29
|
- name: Use Node.js ${{ matrix.node-version }}
|
|
29
|
-
uses: actions/setup-node@
|
|
30
|
+
uses: actions/setup-node@v3
|
|
30
31
|
with:
|
|
31
32
|
node-version: ${{ matrix.node-version }}
|
|
32
|
-
- run: npm
|
|
33
|
-
- run: npm
|
|
33
|
+
- run: npm i -g npm@latest
|
|
34
|
+
- run: npm ci --ignore-scripts
|
|
34
35
|
- run: npm run build --if-present
|
|
35
|
-
- run: npm
|
|
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: [
|
|
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@
|
|
46
|
+
- uses: actions/checkout@v3
|
|
45
47
|
- name: Use Node.js ${{ matrix.node-version }}
|
|
46
|
-
uses: actions/setup-node@
|
|
48
|
+
uses: actions/setup-node@v3
|
|
47
49
|
with:
|
|
48
50
|
node-version: ${{ matrix.node-version }}
|
|
49
|
-
- run: npm
|
|
50
|
-
- run: npm
|
|
51
|
+
- run: npm i -g npm@latest
|
|
52
|
+
- run: npm ci --ignore-scripts
|
|
51
53
|
- run: npm run build --if-present
|
|
52
|
-
- run: npm
|
|
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
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
|
|
25
|
-
this.rerunDataDir = rerunDataDir
|
|
26
|
-
this.rerunScriptPath = rerunScriptPath
|
|
27
|
-
this.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
|
|
58
|
-
const
|
|
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
|
|
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))) {
|
|
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 =
|
|
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.
|
|
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",
|