wdio-rerun-service 1.7.0 → 1.7.3

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.
@@ -5,16 +5,16 @@ name: wdio-rerun-service CI
5
5
 
6
6
  on:
7
7
  push:
8
- branches: [ master ]
8
+ branches: [ master, main ]
9
9
  pull_request:
10
- branches: [ master ]
10
+ branches: [ master, main ]
11
11
 
12
12
  jobs:
13
13
  build:
14
14
  runs-on: ubuntu-latest
15
15
  strategy:
16
16
  matrix:
17
- node-version: [12.x]
17
+ node-version: [12.x, 13.x, 14.x]
18
18
  # See supported Node.js release schedule at https://nodejs.org/en/about/releases/
19
19
  steps:
20
20
  - uses: actions/checkout@v2
@@ -25,6 +25,7 @@ jobs:
25
25
  - run: npm ci
26
26
  - run: npm install -g eslint
27
27
  - run: npm run build --if-present
28
+ - run: npm run test
28
29
 
29
30
  build-windows:
30
31
  runs-on: windows-latest
@@ -41,3 +42,4 @@ jobs:
41
42
  - run: npm ci
42
43
  - run: npm install -g eslint
43
44
  - run: npm run build --if-present
45
+ - run: npm run test
package/CHANGELOG.md CHANGED
@@ -12,6 +12,37 @@
12
12
  _Note: Gaps between patch versions are faulty, broken or test releases._
13
13
 
14
14
  ---
15
+ ## v1.7.3 (2022-04-19)
16
+ #### :bug: Bug Fix
17
+ * [[#31]](https://github.com/jwplayer/wdio-rerun-service/pull/31) Fixing WDIO v7 status code usage ([@ccristobal-skillz](https://github.com/ccristobal-skillz))
18
+ * [[#26]](https://github.com/jwplayer/wdio-rerun-service/pull/26) Ensure element contains scenario inside filter function ([@yopasa94](https://github.com/yopasa94))
19
+
20
+ #### :nail_care: Polish
21
+ * [[#32]](https://github.com/jwplayer/wdio-rerun-service/pull/32) Update dependencies, move to fixed static versions ([@esaari](https://github.com/esaari))
22
+
23
+ #### Committers: 3
24
+ - [@ccristobal-skillz](https://github.com/ccristobal-skillz)
25
+ - [@yopasa94](https://github.com/yopasa94)
26
+ - [@esaari](https://github.com/esaari)
27
+
28
+
29
+ ## v1.7.2 (2021-06-24)
30
+
31
+ #### :nail_care: Polish
32
+ * Service release; no new features or fixes
33
+
34
+ #### Committers: 1
35
+ - [@esaari](https://github.com/esaari)
36
+
37
+ ## v1.7.1 (2021-06-24)
38
+
39
+ #### :nail_care: Polish
40
+ * [[#20]](https://github.com/jwplayer/wdio-rerun-service/pull/20) Use lockfileVersion:2 ([@esaari](https://github.com/esaari))
41
+ * [[#20]](https://github.com/jwplayer/wdio-rerun-service/pull/20) Update `package.json` URLs to reflect webdriverio-community location ([@esaari](https://github.com/esaari))
42
+ * [[#20]](https://github.com/jwplayer/wdio-rerun-service/pull/20) Dependency bumps ([@esaari](https://github.com/esaari))
43
+
44
+ #### Committers: 1
45
+ - [@esaari](https://github.com/esaari)
15
46
 
16
47
  ## v1.7.0 (2021-03-01)
17
48
 
package/LICENSE-MIT ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2021 by JW Player DBA Longtail Ad Solutions
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md CHANGED
@@ -1,9 +1,14 @@
1
1
  WebdriverIO Re-run Service
2
2
  ==========================
3
3
 
4
+ [![wdio-rerun-service CI](https://github.com/webdriverio-community/wdio-rerun-service/actions/workflows/node.js.yml/badge.svg)](https://github.com/webdriverio-community/wdio-rerun-service/actions/workflows/node.js.yml)
5
+ ![npm](https://img.shields.io/npm/dm/wdio-rerun-service)
6
+ ![npm bundle size](https://img.shields.io/bundlephobia/min/wdio-rerun-service)
7
+ ![GitHub issues](https://img.shields.io/github/issues/webdriverio-community/wdio-rerun-service)
8
+
4
9
  This service tracks failing Mocha or Jasmine tests and Cucumber scenarios executed within the [WebdriverIO](https://webdriver.io) test framework. It will allow failing or unstable tests or scenarios to be re-run.
5
10
 
6
- _NOTE_: Cucumber Framework users running WebdriverIO versions `5.x` and `6.x` should use version `1.6.0`. If you are on the latest major version of `7.x`, use the latest version of this service.
11
+ _NOTE_: Cucumber Framework users running WebdriverIO versions `5.x` and `6.x` should use version `1.6.x`. If you are on the latest major version of `7.x`, use the latest `1.7.x` version of this service.
7
12
 
8
13
  ## Re-run vs. Retry
9
14
 
@@ -27,7 +32,7 @@ The easiest way is to add `wdio-rerun-service` to `devDependencies` in your `pac
27
32
  ```json
28
33
  {
29
34
  "devDependencies": {
30
- "wdio-rerun-service": "^1.7.0"
35
+ "wdio-rerun-service": "^1.7.3"
31
36
  }
32
37
  }
33
38
  ```
@@ -45,8 +50,9 @@ After package installation is complete, add it to `services` array in `wdio.conf
45
50
  const RerunService = require('wdio-rerun-service');
46
51
  export.config = {
47
52
  // ...
48
- services: [RerunService],
49
- // ...
53
+ services: [RerunService, {
54
+ // ...
55
+ }]
50
56
  };
51
57
  ```
52
58
 
@@ -62,7 +68,7 @@ const RerunService = require('wdio-rerun-service');
62
68
  export.config = {
63
69
  // ...
64
70
  services: [
65
- [RerunService], {
71
+ [RerunService, {
66
72
  // Re-run service options here...
67
73
  }]
68
74
  ],
@@ -83,7 +89,7 @@ const RerunService = require('wdio-rerun-service');
83
89
  export.config = {
84
90
  // ...
85
91
  services: [
86
- [RerunService], {
92
+ [RerunService, {
87
93
  rerunDataDir: './custom-rerun-directory'
88
94
  }]
89
95
  ],
@@ -104,7 +110,7 @@ const RerunService = require('wdio-rerun-service');
104
110
  export.config = {
105
111
  // ...
106
112
  services: [
107
- [RerunService], {
113
+ [RerunService, {
108
114
  rerunScriptPath: './custom-path-for-rerun.sh'
109
115
  }]
110
116
  ],
@@ -125,7 +131,7 @@ const RerunService = require('wdio-rerun-service');
125
131
  export.config = {
126
132
  // ...
127
133
  services: [
128
- [RerunService], {
134
+ [RerunService, {
129
135
  ignoredTags: ['@known_bug']
130
136
  }]
131
137
  ],
@@ -146,7 +152,7 @@ const RerunService = require('wdio-rerun-service');
146
152
  export.config = {
147
153
  // ...
148
154
  services: [
149
- [RerunService], {
155
+ [RerunService, {
150
156
  commandPrefix: "VARIABLE=true"
151
157
  }]
152
158
  ],
package/babel.config.js CHANGED
@@ -1,10 +1,10 @@
1
1
  module.exports = {
2
2
  presets: [
3
- ['@babel/preset-env', {
4
- targets: {
5
- node: 8
6
- }
7
- }]
3
+ [
4
+ '@babel/preset-env',
5
+ {targets: {node: 'current'}},
6
+ "@babel/preset-typescript"
7
+ ]
8
8
  ],
9
9
  plugins: [
10
10
  '@babel/plugin-proposal-function-bind',
package/build/index.js CHANGED
@@ -1,101 +1,117 @@
1
+ "use strict";
2
+
3
+ require("source-map-support/register");
4
+
1
5
  const fs = require('fs');
6
+
2
7
  const path = require('path');
3
- const { v5: uuidv5 } = require('uuid');
8
+
9
+ const {
10
+ v5: uuidv5
11
+ } = require('uuid');
12
+
4
13
  const argv = require('minimist')(process.argv.slice(2));
5
14
 
6
15
  class RerunService {
16
+ constructor({
17
+ ignoredTags,
18
+ rerunDataDir,
19
+ rerunScriptPath,
20
+ commandPrefix
21
+ } = {}) {
22
+ this.nonPassingItems = [];
23
+ 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 : "";
28
+ this.specFile = "";
29
+ }
7
30
 
8
- constructor({ ignoredTags, rerunDataDir, rerunScriptPath, commandPrefix }) {
9
- this.nonPassingItems = [];
10
- this.serviceWorkerId;
11
- this.ignoredTags = ignoredTags ? ignoredTags : [];
12
- this.rerunDataDir = rerunDataDir ? rerunDataDir : "./results/rerun";
13
- this.rerunScriptPath = rerunScriptPath ? rerunScriptPath : "./rerun.sh";
14
- this.commandPrefix = commandPrefix ? commandPrefix : "";
15
- this.specFile = "";
16
- }
31
+ before(capabilities, specs) {
32
+ this.specFile = specs[0];
33
+ fs.mkdirSync(this.rerunDataDir, {
34
+ recursive: true
35
+ });
36
+ this.serviceWorkerId = uuidv5(`${Date.now()}`, '6ba7b810-9dad-11d1-80b4-00c04fd430c8');
37
+ }
17
38
 
18
- before(capabilities, specs, browser) {
19
- this.specFile = specs[0];
20
- // console.log(`Re-run service is activated. Data directory: ${this.rerunDataDir}`);
21
- fs.mkdir(this.rerunDataDir, { recursive: true }, err => {
22
- if (err) throw err;
39
+ afterTest(test, context, {
40
+ error,
41
+ result,
42
+ duration,
43
+ passed,
44
+ retries
45
+ }) {
46
+ if (browser.config.framework !== 'cucumber' && !passed) {
47
+ if (error && error.message) {
48
+ this.nonPassingItems.push({
49
+ location: this.specFile,
50
+ failure: error.message
23
51
  });
24
- // INFO: `namespace` below copied from: https://github.com/kelektiv/node-uuid/blob/master//lib/v35.js#L54:16
25
- this.serviceWorkerId = uuidv5(`${Date.now()}`, '6ba7b810-9dad-11d1-80b4-00c04fd430c8');
52
+ } else {}
26
53
  }
54
+ }
27
55
 
28
- // Executed after a test (in Mocha/Jasmine) ends.
29
- afterTest(test, context, { error, result, duration, passed, retries }) {
30
- if (browser.config.framework !== 'cucumber' && !passed) {
31
- console.log(`Re-run service is inspecting non-passing test.`);
32
- console.log(`Test location: ${this.specFile}`);
33
- if (error && error.message) {
34
- this.nonPassingItems.push({ location: this.specFile, failure: error.message });
35
- } else {
36
- // console.log("The non-passing test did not contain any error message, it could not be added for re-run.")
37
- }
38
- }
39
- }
56
+ afterScenario(world) {
57
+ const status = world.result.status;
58
+ const scenarioLineNumber = world.gherkinDocument.feature.children.filter(child => {
59
+ if (child.scenario) {
60
+ return child.scenario && world.pickle.astNodeIds.includes(child.scenario.id.toString());
61
+ }
62
+ })[0].scenario.location.line;
40
63
 
41
- // Executed after a Cucumber scenario ends.
42
- afterScenario(world) {
43
- const CUCUMBER_STATUS_MAP = ['unknown', 'passed', 'skipped', 'pending', 'undefined', 'ambiguous', 'failed'];
44
- const status = CUCUMBER_STATUS_MAP[world.result.status || 0];
45
- const scenarioLineNumber = world.gherkinDocument.feature.children.filter(child => {
46
- return world.pickle.astNodeIds.includes(child.scenario.id);
47
- })[0].scenario.location.line;
48
-
49
- if (browser.config.framework === 'cucumber' && status !== 'passed' && status !== 'skipped') {
50
- // console.log(`Re-run service is inspecting non-passing scenario.`);
51
- const scenarioLocation = `${world.pickle.uri}:${scenarioLineNumber}`;
52
- // console.log(`Scenario location: ${scenarioLocation}`);
53
- const tagsList = world.pickle.tags.map(tag => tag.name);
54
- // console.log(`Scenario tags: ${tagsList}`);
55
- const service = this;
56
- if (this.ignoredTags && tagsList.some(ignoredTag => service.ignoredTags.includes(ignoredTag))) {
57
- // console.log(`Re-run service will ignore the current scenario since it includes one of the ignored tags: ${this.ignoredTags}`);
58
- } else {
59
- this.nonPassingItems.push({ location: scenarioLocation, failure: world.result.message });
60
- }
61
- }
62
- }
64
+ if (browser.config.framework === 'cucumber' && status !== 'PASSED' && status !== 'SKIPPED') {
65
+ const scenarioLocation = `${world.pickle.uri}:${scenarioLineNumber}`;
66
+ const tagsList = world.pickle.tags.map(tag => tag.name);
67
+ const service = this;
63
68
 
64
- after(result, capabilities, specs) {
65
- if (this.nonPassingItems.length > 0) {
66
- fs.writeFileSync(`${this.rerunDataDir}/rerun-${this.serviceWorkerId}.json`, JSON.stringify(this.nonPassingItems));
67
- } else {
68
- // console.log('Re-run service did not detect any non-passing scenarios or tests.');
69
- }
69
+ if (this.ignoredTags && tagsList.some(ignoredTag => service.ignoredTags.includes(ignoredTag))) {} else {
70
+ this.nonPassingItems.push({
71
+ location: scenarioLocation,
72
+ failure: world.result.message
73
+ });
74
+ }
70
75
  }
76
+ }
77
+
78
+ after(result, capabilities, specs) {
79
+ if (this.nonPassingItems.length > 0) {
80
+ fs.writeFileSync(`${this.rerunDataDir}/rerun-${this.serviceWorkerId}.json`, JSON.stringify(this.nonPassingItems));
81
+ } else {}
82
+ }
83
+
84
+ onComplete(exitCode, config, capabilities, results) {
85
+ const directoryPath = path.join(process.cwd(), `${this.rerunDataDir}`);
86
+
87
+ if (fs.existsSync(directoryPath)) {
88
+ const rerunFiles = fs.readdirSync(directoryPath);
71
89
 
72
- onComplete(exitCode, config, capabilities, results) {
73
- const directoryPath = path.join(process.cwd(), `${this.rerunDataDir}`);
74
- if (fs.existsSync(directoryPath)) {
75
- const rerunFiles = fs.readdirSync(directoryPath);
76
- if (rerunFiles.length > 0) {
77
- let rerunCommand = `DISABLE_RERUN=true node_modules/.bin/wdio ${argv._[0]} `;
78
- if (this.commandPrefix) {
79
- rerunCommand = `${this.commandPrefix} ${rerunCommand}`;
80
- }
81
- let failureLocations = [];
82
- rerunFiles.forEach(file => {
83
- const json = JSON.parse(fs.readFileSync(`${this.rerunDataDir}/${file}`));
84
- json.forEach(failure => {
85
- failureLocations.push(failure.location.replace(/\\/g, "/"));
86
- });
87
- });
88
- const failureLocationsUnique = [...new Set(failureLocations)];
89
- failureLocationsUnique.forEach(failureLocation => {
90
- rerunCommand += ` --spec=${failureLocation}`;
91
- });
92
- fs.writeFileSync(this.rerunScriptPath, rerunCommand);
93
- console.log(`Re-run script has been generated @ ${this.rerunScriptPath}`);
94
- }
95
- } else {
96
- console.log('Re-run service did not detect any failing tests during the entire test execution.');
90
+ 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}`;
97
95
  }
96
+
97
+ let failureLocations = [];
98
+ rerunFiles.forEach(file => {
99
+ const json = JSON.parse(fs.readFileSync(`${this.rerunDataDir}/${file}`));
100
+ json.forEach(failure => {
101
+ failureLocations.push(failure.location.replace(/\\/g, "/"));
102
+ });
103
+ });
104
+ const failureLocationsUnique = [...new Set(failureLocations)];
105
+ failureLocationsUnique.forEach(failureLocation => {
106
+ rerunCommand += ` --spec=${failureLocation}`;
107
+ });
108
+ fs.writeFileSync(this.rerunScriptPath, rerunCommand);
109
+ }
98
110
  }
111
+ }
112
+
99
113
  }
100
114
 
101
- module.exports = RerunService;
115
+ ;
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"]}
package/package.json CHANGED
@@ -1,10 +1,10 @@
1
1
  {
2
2
  "name": "wdio-rerun-service",
3
- "version": "1.7.0",
3
+ "version": "1.7.3",
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
- "homepage": "https://github.com/jwplayer/wdio-rerun-service",
7
- "license": "Apache-2.0",
6
+ "homepage": "https://github.com/webdriverio-community/wdio-rerun-service",
7
+ "license": "MIT",
8
8
  "main": "./build/index",
9
9
  "engines": {
10
10
  "node": ">=12.0.0"
@@ -12,18 +12,19 @@
12
12
  "scripts": {
13
13
  "build": "run-s clean compile",
14
14
  "clean": "rimraf ./build",
15
- "compile": "babel src/ -d build/ --config-file ../../babel.config.js",
15
+ "compile": "babel src/ -d build/ --config-file ./babel.config.js",
16
16
  "watch": "npm-watch",
17
17
  "test": "run-s test:*",
18
+ "test:clean": "rimraf ./results ./coverage rerun.sh",
18
19
  "test:eslint": "eslint src tests",
19
- "test:unit": "jest"
20
+ "test:unit": "jest --collectCoverageFrom='[\"src/**/*.{js,jsx,ts,tsx}\"]' --coverage --collectCoverage=true --forceExit --detectOpenHandles tests/.*test.*"
20
21
  },
21
22
  "watch": {
22
23
  "build": "{src,tests}/*.js"
23
24
  },
24
25
  "repository": {
25
26
  "type": "git",
26
- "url": "git://github.com/jwplayer/wdio-rerun-service.git"
27
+ "url": "git://github.com/webdriverio-community/wdio-rerun-service.git"
27
28
  },
28
29
  "keywords": [
29
30
  "webdriver",
@@ -31,44 +32,54 @@
31
32
  "wdio",
32
33
  "wdio-service",
33
34
  "rerun",
35
+ "re-run",
34
36
  "retry",
37
+ "test",
35
38
  "tests",
36
39
  "scenario",
37
40
  "cucumber",
38
41
  "mocha",
39
42
  "jasmine",
40
43
  "flaky",
41
- "selenium"
44
+ "selenium",
45
+ "node",
46
+ "automation",
47
+ "javascript"
42
48
  ],
43
49
  "bugs": {
44
- "url": "https://github.com/jwplayer/wdio-rerun-service/issues"
50
+ "url": "https://github.com/webdriverio-community/wdio-rerun-service/issues"
45
51
  },
46
52
  "dependencies": {
47
- "@wdio/logger": "7.0.0",
48
- "minimist": "^1.2.5",
49
- "npm-watch": "^0.7.0",
50
- "uuid": "^8.3.0"
53
+ "@wdio/logger": "7.19.0",
54
+ "minimist": "1.2.6",
55
+ "npm-watch": "0.11.0",
56
+ "uuid": "8.3.2"
51
57
  },
52
58
  "peerDependencies": {},
53
59
  "publishConfig": {
54
60
  "access": "public"
55
61
  },
56
62
  "devDependencies": {
57
- "@babel/cli": "^7.6.2",
58
- "@babel/core": "^7.6.2",
59
- "@babel/node": "^7.6.2",
60
- "@babel/plugin-proposal-class-properties": "^7.5.5",
61
- "@babel/plugin-proposal-function-bind": "^7.2.0",
62
- "@babel/plugin-proposal-optional-catch-binding": "^7.2.0",
63
- "@babel/plugin-syntax-export-default-from": "^7.2.0",
64
- "@babel/preset-env": "^7.6.2",
65
- "@babel/register": "^7.6.2",
66
- "babel-cli": "^6.26.0",
67
- "babel-core": "^6.26.3",
68
- "babel-eslint": "^10.0.3",
69
- "babel-jest": "^26.0.1",
70
- "babel-plugin-source-map-support": "^2.1.1",
71
- "npm-run-all": "^4.1.5",
72
- "rimraf": "^3.0.2"
63
+ "@babel/cli": "7.17.6",
64
+ "@babel/core": "7.17.9",
65
+ "@babel/node": "7.16.8",
66
+ "@babel/plugin-proposal-class-properties": "7.16.7",
67
+ "@babel/plugin-proposal-function-bind": "7.16.7",
68
+ "@babel/plugin-proposal-optional-catch-binding": "7.16.7",
69
+ "@babel/plugin-syntax-export-default-from": "7.16.7",
70
+ "@babel/preset-env": "7.16.11",
71
+ "@babel/register": "7.17.7",
72
+ "@typescript-eslint/eslint-plugin": "5.20.0",
73
+ "@typescript-eslint/parser": "5.20.0",
74
+ "babel-cli": "6.26.0",
75
+ "babel-core": "6.26.3",
76
+ "babel-eslint": "10.1.0",
77
+ "babel-jest": "27.5.1",
78
+ "babel-plugin-source-map-support": "2.1.3",
79
+ "eslint": "8.13.0",
80
+ "jest": "27.5.1",
81
+ "npm-run-all": "4.1.5",
82
+ "rimraf": "3.0.2",
83
+ "typescript": "4.6.3"
73
84
  }
74
85
  }