mirror of
https://github.com/nick-fields/retry.git
synced 2026-02-10 07:05:29 +00:00
Compare commits
34 Commits
v2.5.0
...
anthonyc/m
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8e4fe2b191 | ||
|
|
676683ec60 | ||
|
|
772a768088 | ||
|
|
6e8635d64a | ||
|
|
2d8f74008e | ||
|
|
4d604b1776 | ||
|
|
29e1861bc1 | ||
|
|
f2eb0f4f8a | ||
|
|
2762157955 | ||
|
|
ce44dab6c9 | ||
|
|
40cf3886b8 | ||
|
|
db59b2620d | ||
|
|
02a3f09f15 | ||
|
|
6b1204d918 | ||
|
|
8629cc7c0b | ||
|
|
e88a9994b0 | ||
|
|
e4acf08f18 | ||
|
|
51e448da7c | ||
|
|
5f63400863 | ||
|
|
c0687a0dcd | ||
|
|
102f21a736 | ||
|
|
752366eac8 | ||
|
|
a3da592761 | ||
|
|
7c5cca7536 | ||
|
|
f227091f2e | ||
|
|
6183d5c3dd | ||
|
|
71062288b7 | ||
|
|
afe1ef9058 | ||
|
|
e53cf64f16 | ||
|
|
7f8f3d9f0f | ||
|
|
bf1736e338 | ||
|
|
f7cf641580 | ||
|
|
002ef572db | ||
|
|
e80198a9da |
162
.github/workflows/ci_cd.yml
vendored
162
.github/workflows/ci_cd.yml
vendored
@@ -1,8 +1,7 @@
|
|||||||
name: CI/CD
|
name: CI/CD
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
|
||||||
- '**'
|
|
||||||
jobs:
|
jobs:
|
||||||
# runs on branch pushes only
|
# runs on branch pushes only
|
||||||
ci:
|
ci:
|
||||||
@@ -15,7 +14,7 @@ jobs:
|
|||||||
- name: Setup Node.js
|
- name: Setup Node.js
|
||||||
uses: actions/setup-node@v1
|
uses: actions/setup-node@v1
|
||||||
with:
|
with:
|
||||||
node-version: 12
|
node-version: 16
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: npm ci
|
run: npm ci
|
||||||
|
|
||||||
@@ -60,6 +59,15 @@ jobs:
|
|||||||
actual: ${{ steps.sad_path_wait_sec.outputs.exit_error }}
|
actual: ${{ steps.sad_path_wait_sec.outputs.exit_error }}
|
||||||
comparison: contains
|
comparison: contains
|
||||||
|
|
||||||
|
- name: new-command-on-retry
|
||||||
|
id: new-command-on-retry
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
timeout_minutes: 1
|
||||||
|
max_attempts: 3
|
||||||
|
command: node -e "process.exit(1)"
|
||||||
|
new_command_on_retry: node -e "console.log('this is the new command on retry')"
|
||||||
|
|
||||||
- name: on-retry-cmd
|
- name: on-retry-cmd
|
||||||
id: on-retry-cmd
|
id: on-retry-cmd
|
||||||
uses: ./
|
uses: ./
|
||||||
@@ -70,6 +78,42 @@ jobs:
|
|||||||
command: node -e "process.exit(1)"
|
command: node -e "process.exit(1)"
|
||||||
on_retry_command: node -e "console.log('this is a retry command')"
|
on_retry_command: node -e "console.log('this is a retry command')"
|
||||||
|
|
||||||
|
- name: retry_on_exit_code (with expected error code)
|
||||||
|
id: retry_on_exit_code_expected
|
||||||
|
uses: ./
|
||||||
|
continue-on-error: true
|
||||||
|
with:
|
||||||
|
timeout_minutes: 1
|
||||||
|
retry_on_exit_code: 2
|
||||||
|
max_attempts: 3
|
||||||
|
command: node -e "process.exit(2)"
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: failure
|
||||||
|
actual: ${{ steps.retry_on_exit_code_expected.outcome }}
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 3
|
||||||
|
actual: ${{ steps.retry_on_exit_code_expected.outputs.total_attempts }}
|
||||||
|
|
||||||
|
- name: retry_on_exit_code (with unexpected error code)
|
||||||
|
id: retry_on_exit_code_unexpected
|
||||||
|
uses: ./
|
||||||
|
continue-on-error: true
|
||||||
|
with:
|
||||||
|
timeout_minutes: 1
|
||||||
|
retry_on_exit_code: 2
|
||||||
|
max_attempts: 3
|
||||||
|
command: node -e "process.exit(1)"
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: failure
|
||||||
|
actual: ${{ steps.retry_on_exit_code_unexpected.outcome }}
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 1
|
||||||
|
actual: ${{ steps.retry_on_exit_code_unexpected.outputs.total_attempts }}
|
||||||
|
|
||||||
- name: on-retry-cmd (on-retry fails)
|
- name: on-retry-cmd (on-retry fails)
|
||||||
id: on-retry-cmd-fails
|
id: on-retry-cmd-fails
|
||||||
uses: ./
|
uses: ./
|
||||||
@@ -269,6 +313,114 @@ jobs:
|
|||||||
expected: failure
|
expected: failure
|
||||||
actual: ${{ steps.wrong_shell.outcome }}
|
actual: ${{ steps.wrong_shell.outcome }}
|
||||||
|
|
||||||
|
ci_multiline_tests:
|
||||||
|
name: Run Tests (Multiline)
|
||||||
|
if: startsWith(github.ref, 'refs/heads')
|
||||||
|
runs-on: ubuntu-18.04
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v1
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
- name: Install dependencies
|
||||||
|
run: npm ci
|
||||||
|
|
||||||
|
- name: Multi-line 2 commands non existent first command
|
||||||
|
id: multi_line_2_commands_non_existent_first_command
|
||||||
|
uses: ./
|
||||||
|
continue-on-error: true
|
||||||
|
with:
|
||||||
|
shell: bash
|
||||||
|
timeout_seconds: 1
|
||||||
|
max_attempts: 2
|
||||||
|
command: |
|
||||||
|
i-do-not-exist && \
|
||||||
|
echo "i-exist"
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 2
|
||||||
|
actual: ${{ steps.multi_line_2_commands_non_existent_first_command.outputs.total_attempts }}
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 'Final attempt failed'
|
||||||
|
actual: ${{ steps.multi_line_2_commands_non_existent_first_command.outputs.exit_error }}
|
||||||
|
comparison: contains
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
# The 127 error code indicates “command not found”.
|
||||||
|
expected: '127'
|
||||||
|
actual: ${{ steps.multi_line_2_commands_non_existent_first_command.outputs.exit_code }}
|
||||||
|
comparison: contains
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 'i-exist'
|
||||||
|
actual: ${{ steps.multi_line_2_commands_non_existent_first_command.outputs.exit_error }}
|
||||||
|
comparison: notContains
|
||||||
|
|
||||||
|
- name: Multi-line 2 commands happy path test
|
||||||
|
id: multi_line_2_commands_happy_path
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
shell: bash
|
||||||
|
timeout_seconds: 1
|
||||||
|
max_attempts: 2
|
||||||
|
command: |
|
||||||
|
echo "foo" && \
|
||||||
|
echo "bar"
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 1
|
||||||
|
actual: ${{ steps.multi_line_2_commands_happy_path.outputs.total_attempts }}
|
||||||
|
|
||||||
|
- name: Conventional multi-line non existent first command
|
||||||
|
id: conventional_multi_line_non_existent_first_command
|
||||||
|
uses: ./
|
||||||
|
continue-on-error: true
|
||||||
|
with:
|
||||||
|
shell: bash
|
||||||
|
timeout_seconds: 1
|
||||||
|
max_attempts: 2
|
||||||
|
command: |
|
||||||
|
i-do-not-exist
|
||||||
|
echo "i-exist"
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 2
|
||||||
|
actual: ${{ steps.conventional_multi_line_non_existent_first_command.outputs.total_attempts }}
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 'Final attempt failed'
|
||||||
|
actual: ${{ steps.conventional_multi_line_non_existent_first_command.outputs.exit_error }}
|
||||||
|
comparison: contains
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
# The 127 error code indicates “command not found”.
|
||||||
|
expected: '127'
|
||||||
|
actual: ${{ steps.conventional_multi_line_non_existent_first_command.outputs.exit_code }}
|
||||||
|
comparison: contains
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 'i-exist'
|
||||||
|
actual: ${{ steps.conventional_multi_line_non_existent_first_command.outputs.exit_error }}
|
||||||
|
comparison: notContains
|
||||||
|
|
||||||
|
- name: Conventional multi-line happy path test
|
||||||
|
id: conventional_multi_line_happy_path
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
shell: bash
|
||||||
|
timeout_seconds: 1
|
||||||
|
max_attempts: 2
|
||||||
|
command: |
|
||||||
|
echo "foo"
|
||||||
|
echo "bar"
|
||||||
|
- uses: nick-invision/assert-action@v1
|
||||||
|
with:
|
||||||
|
expected: 1
|
||||||
|
actual: ${{ steps.conventional_multi_line_happy_path.outputs.total_attempts }}
|
||||||
|
|
||||||
ci_windows:
|
ci_windows:
|
||||||
name: Run Windows Tests
|
name: Run Windows Tests
|
||||||
if: startsWith(github.ref, 'refs/heads')
|
if: startsWith(github.ref, 'refs/heads')
|
||||||
@@ -279,7 +431,7 @@ jobs:
|
|||||||
- name: Setup Node.js
|
- name: Setup Node.js
|
||||||
uses: actions/setup-node@v1
|
uses: actions/setup-node@v1
|
||||||
with:
|
with:
|
||||||
node-version: 12
|
node-version: 16
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: npm ci
|
run: npm ci
|
||||||
- name: Powershell test
|
- name: Powershell test
|
||||||
@@ -333,7 +485,7 @@ jobs:
|
|||||||
- name: Setup Node.js
|
- name: Setup Node.js
|
||||||
uses: actions/setup-node@v1
|
uses: actions/setup-node@v1
|
||||||
with:
|
with:
|
||||||
node-version: 12
|
node-version: 16
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: npm ci
|
run: npm ci
|
||||||
- name: Release
|
- name: Release
|
||||||
|
|||||||
59
README.md
59
README.md
@@ -2,6 +2,10 @@
|
|||||||
|
|
||||||
Retries an Action step on failure or timeout. This is currently intended to replace the `run` step for moody commands.
|
Retries an Action step on failure or timeout. This is currently intended to replace the `run` step for moody commands.
|
||||||
|
|
||||||
|
**NOTE:** Ownership of this project was transferred to my personal account `nick-fields` from my work account `nick-invision`. Details [here](#Ownership)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
## Inputs
|
## Inputs
|
||||||
|
|
||||||
### `timeout_minutes`
|
### `timeout_minutes`
|
||||||
@@ -44,10 +48,18 @@ Retries an Action step on failure or timeout. This is currently intended to repl
|
|||||||
|
|
||||||
**Optional** Command to run before a retry (such as a cleanup script). Any error thrown from retry command is caught and surfaced as a warning.
|
**Optional** Command to run before a retry (such as a cleanup script). Any error thrown from retry command is caught and surfaced as a warning.
|
||||||
|
|
||||||
|
### `new_command_on_retry`
|
||||||
|
|
||||||
|
**Optional** Command to run if the first attempt fails. This command will be called on all subsequent attempts.
|
||||||
|
|
||||||
### `continue_on_error`
|
### `continue_on_error`
|
||||||
|
|
||||||
**Optional** Exit successfully even if an error occurs. Same as native continue-on-error behavior, but for use in composite actions. Defaults to `false`
|
**Optional** Exit successfully even if an error occurs. Same as native continue-on-error behavior, but for use in composite actions. Defaults to `false`
|
||||||
|
|
||||||
|
### `retry_on_exit_code`
|
||||||
|
|
||||||
|
**Optional** Specific exit code to retry on. This will only retry for the given error code and fail immediately other error codes.
|
||||||
|
|
||||||
## Outputs
|
## Outputs
|
||||||
|
|
||||||
### `total_attempts`
|
### `total_attempts`
|
||||||
@@ -67,7 +79,7 @@ The final error returned by the command
|
|||||||
### Shell
|
### Shell
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
uses: nick-invision/retry@v2
|
uses: nick-fields/retry@v2
|
||||||
with:
|
with:
|
||||||
timeout_minutes: 10
|
timeout_minutes: 10
|
||||||
max_attempts: 3
|
max_attempts: 3
|
||||||
@@ -78,7 +90,7 @@ with:
|
|||||||
### Timeout in minutes
|
### Timeout in minutes
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
uses: nick-invision/retry@v2
|
uses: nick-fields/retry@v2
|
||||||
with:
|
with:
|
||||||
timeout_minutes: 10
|
timeout_minutes: 10
|
||||||
max_attempts: 3
|
max_attempts: 3
|
||||||
@@ -88,7 +100,7 @@ with:
|
|||||||
### Timeout in seconds
|
### Timeout in seconds
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
uses: nick-invision/retry@v2
|
uses: nick-fields/retry@v2
|
||||||
with:
|
with:
|
||||||
timeout_seconds: 15
|
timeout_seconds: 15
|
||||||
max_attempts: 3
|
max_attempts: 3
|
||||||
@@ -98,7 +110,7 @@ with:
|
|||||||
### Only retry after timeout
|
### Only retry after timeout
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
uses: nick-invision/retry@v2
|
uses: nick-fields/retry@v2
|
||||||
with:
|
with:
|
||||||
timeout_seconds: 15
|
timeout_seconds: 15
|
||||||
max_attempts: 3
|
max_attempts: 3
|
||||||
@@ -109,7 +121,7 @@ with:
|
|||||||
### Only retry after error
|
### Only retry after error
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
uses: nick-invision/retry@v2
|
uses: nick-fields/retry@v2
|
||||||
with:
|
with:
|
||||||
timeout_seconds: 15
|
timeout_seconds: 15
|
||||||
max_attempts: 3
|
max_attempts: 3
|
||||||
@@ -120,20 +132,20 @@ with:
|
|||||||
### Retry using continue_on_error input (in composite action) but allow failure and do something with output
|
### Retry using continue_on_error input (in composite action) but allow failure and do something with output
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- uses: nick-invision/retry@v2
|
- uses: nick-fields/retry@v2
|
||||||
id: retry
|
id: retry
|
||||||
with:
|
with:
|
||||||
timeout_seconds: 15
|
timeout_seconds: 15
|
||||||
max_attempts: 3
|
max_attempts: 3
|
||||||
continue-on-error: true
|
continue_on_error: true
|
||||||
command: node -e 'process.exit(99);'
|
command: node -e 'process.exit(99);'
|
||||||
- name: Assert that step succeeded (despite failing command)
|
- name: Assert that step succeeded (despite failing command)
|
||||||
uses: nick-invision/assert-action@v1
|
uses: nick-fields/assert-action@v1
|
||||||
with:
|
with:
|
||||||
expected: success
|
expected: success
|
||||||
actual: ${{ steps.retry.outcome }}
|
actual: ${{ steps.retry.outcome }}
|
||||||
- name: Assert that action exited with expected exit code
|
- name: Assert that action exited with expected exit code
|
||||||
uses: nick-invision/assert-action@v1
|
uses: nick-fields/assert-action@v1
|
||||||
with:
|
with:
|
||||||
expected: 99
|
expected: 99
|
||||||
actual: ${{ steps.retry.outputs.exit_code }}
|
actual: ${{ steps.retry.outputs.exit_code }}
|
||||||
@@ -142,7 +154,7 @@ with:
|
|||||||
### Retry using continue-on-error built-in command (in workflow action) but allow failure and do something with output
|
### Retry using continue-on-error built-in command (in workflow action) but allow failure and do something with output
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- uses: nick-invision/retry@v2
|
- uses: nick-fields/retry@v2
|
||||||
id: retry
|
id: retry
|
||||||
# see https://docs.github.com/en/free-pro-team@latest/actions/reference/workflow-syntax-for-github-actions#jobsjob_idcontinue-on-error
|
# see https://docs.github.com/en/free-pro-team@latest/actions/reference/workflow-syntax-for-github-actions#jobsjob_idcontinue-on-error
|
||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
@@ -152,17 +164,17 @@ with:
|
|||||||
retry_on: error
|
retry_on: error
|
||||||
command: node -e 'process.exit(99);'
|
command: node -e 'process.exit(99);'
|
||||||
- name: Assert that action failed
|
- name: Assert that action failed
|
||||||
uses: nick-invision/assert-action@v1
|
uses: nick-fields/assert-action@v1
|
||||||
with:
|
with:
|
||||||
expected: failure
|
expected: failure
|
||||||
actual: ${{ steps.retry.outcome }}
|
actual: ${{ steps.retry.outcome }}
|
||||||
- name: Assert that action exited with expected exit code
|
- name: Assert that action exited with expected exit code
|
||||||
uses: nick-invision/assert-action@v1
|
uses: nick-fields/assert-action@v1
|
||||||
with:
|
with:
|
||||||
expected: 99
|
expected: 99
|
||||||
actual: ${{ steps.retry.outputs.exit_code }}
|
actual: ${{ steps.retry.outputs.exit_code }}
|
||||||
- name: Assert that action made expected number of attempts
|
- name: Assert that action made expected number of attempts
|
||||||
uses: nick-invision/assert-action@v1
|
uses: nick-fields/assert-action@v1
|
||||||
with:
|
with:
|
||||||
expected: 3
|
expected: 3
|
||||||
actual: ${{ steps.retry.outputs.total_attempts }}
|
actual: ${{ steps.retry.outputs.total_attempts }}
|
||||||
@@ -171,7 +183,7 @@ with:
|
|||||||
### Run script after failure but before retry
|
### Run script after failure but before retry
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
uses: nick-invision/retry@v2
|
uses: nick-fields/retry@v2
|
||||||
with:
|
with:
|
||||||
timeout_seconds: 15
|
timeout_seconds: 15
|
||||||
max_attempts: 3
|
max_attempts: 3
|
||||||
@@ -179,6 +191,17 @@ with:
|
|||||||
on_retry_command: npm run cleanup-flaky-script-output
|
on_retry_command: npm run cleanup-flaky-script-output
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Run different command after first failure
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
uses: nick-fields/retry@v2
|
||||||
|
with:
|
||||||
|
timeout_seconds: 15
|
||||||
|
max_attempts: 3
|
||||||
|
command: npx jest
|
||||||
|
new_command_on_retry: npx jest --onlyFailures
|
||||||
|
```
|
||||||
|
|
||||||
### Run multi-line, multi-command script
|
### Run multi-line, multi-command script
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
@@ -209,3 +232,11 @@ with:
|
|||||||
## Requirements
|
## Requirements
|
||||||
|
|
||||||
NodeJS is required for this action to run. This runs without issue on all GitHub hosted runners but if you are running into issues with this on self hosted runners ensure NodeJS is installed.
|
NodeJS is required for this action to run. This runs without issue on all GitHub hosted runners but if you are running into issues with this on self hosted runners ensure NodeJS is installed.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## **Ownership**
|
||||||
|
|
||||||
|
As of 2022/02/15 ownership of this project has been transferred to my personal account `nick-fields` from my work account `nick-invision` due to me leaving InVision. I am the author and have been the primary maintainer since day one and will continue to maintain this as needed.
|
||||||
|
|
||||||
|
Existing workflow references to `nick-invision/retry@<whatever>` no longer work and must be updated to `nick-fields/retry@<whatever>`.
|
||||||
|
|||||||
@@ -36,6 +36,12 @@ inputs:
|
|||||||
continue_on_error:
|
continue_on_error:
|
||||||
description: Exits successfully even if an error occurs. Same as native continue-on-error behavior, but for use in composite actions. Default is false
|
description: Exits successfully even if an error occurs. Same as native continue-on-error behavior, but for use in composite actions. Default is false
|
||||||
default: false
|
default: false
|
||||||
|
new_command_on_retry:
|
||||||
|
description: Command to run if the first attempt fails. This command will be called on all subsequent attempts.
|
||||||
|
required: false
|
||||||
|
retry_on_exit_code:
|
||||||
|
description: Specific exit code to retry on. This will only retry for the given error code and fail immediately other error codes.
|
||||||
|
required: false
|
||||||
outputs:
|
outputs:
|
||||||
total_attempts:
|
total_attempts:
|
||||||
description: The final number of attempts made
|
description: The final number of attempts made
|
||||||
|
|||||||
1534
dist/index.js
vendored
1534
dist/index.js
vendored
File diff suppressed because it is too large
Load Diff
13975
package-lock.json
generated
13975
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
16
package.json
16
package.json
@@ -11,28 +11,28 @@
|
|||||||
"url": "git+https://github.com/nick-invision/retry.git"
|
"url": "git+https://github.com/nick-invision/retry.git"
|
||||||
},
|
},
|
||||||
"keywords": [],
|
"keywords": [],
|
||||||
"author": "",
|
"author": "Nick Fields",
|
||||||
"license": "ISC",
|
"license": "ISC",
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/nick-invision/retry/issues"
|
"url": "https://github.com/nick-invision/retry/issues"
|
||||||
},
|
},
|
||||||
"homepage": "https://github.com/nick-invision/retry#readme",
|
"homepage": "https://github.com/nick-invision/retry#readme",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@actions/core": "^1.5.0",
|
"@actions/core": "^1.8.2",
|
||||||
"milliseconds": "^1.0.3",
|
"milliseconds": "^1.0.3",
|
||||||
"tree-kill": "^1.2.2"
|
"tree-kill": "^1.2.2"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@commitlint/cli": "11.0.0",
|
"@commitlint/cli": "^16.2.3",
|
||||||
"@commitlint/config-conventional": "11.0.0",
|
"@commitlint/config-conventional": "^16.2.1",
|
||||||
"@semantic-release/changelog": "5.0.1",
|
"@semantic-release/changelog": "^6.0.1",
|
||||||
"@semantic-release/git": "9.0.0",
|
"@semantic-release/git": "^10.0.1",
|
||||||
"@types/milliseconds": "0.0.30",
|
"@types/milliseconds": "0.0.30",
|
||||||
"@types/node": "14.14.7",
|
"@types/node": "14.14.7",
|
||||||
"@zeit/ncc": "^0.20.5",
|
"@zeit/ncc": "^0.20.5",
|
||||||
"dotenv": "8.2.0",
|
"dotenv": "8.2.0",
|
||||||
"husky": "4.3.0",
|
"husky": "^4.3.8",
|
||||||
"semantic-release": "17.2.3",
|
"semantic-release": "19.0.3",
|
||||||
"ts-node": "9.0.0",
|
"ts-node": "9.0.0",
|
||||||
"typescript": "4.0.5"
|
"typescript": "4.0.5"
|
||||||
},
|
},
|
||||||
|
|||||||
22
src/index.ts
22
src/index.ts
@@ -17,6 +17,8 @@ const RETRY_ON = getInput('retry_on') || 'any';
|
|||||||
const WARNING_ON_RETRY = getInput('warning_on_retry').toLowerCase() === 'true';
|
const WARNING_ON_RETRY = getInput('warning_on_retry').toLowerCase() === 'true';
|
||||||
const ON_RETRY_COMMAND = getInput('on_retry_command');
|
const ON_RETRY_COMMAND = getInput('on_retry_command');
|
||||||
const CONTINUE_ON_ERROR = getInputBoolean('continue_on_error');
|
const CONTINUE_ON_ERROR = getInputBoolean('continue_on_error');
|
||||||
|
const NEW_COMMAND_ON_RETRY = getInput('new_command_on_retry');
|
||||||
|
const RETRY_ON_EXIT_CODE = getInputNumber('retry_on_exit_code', false);
|
||||||
|
|
||||||
const OS = process.platform;
|
const OS = process.platform;
|
||||||
const OUTPUT_TOTAL_ATTEMPTS_KEY = 'total_attempts';
|
const OUTPUT_TOTAL_ATTEMPTS_KEY = 'total_attempts';
|
||||||
@@ -76,12 +78,16 @@ function getTimeout(): number {
|
|||||||
|
|
||||||
function getExecutable(): string {
|
function getExecutable(): string {
|
||||||
if (!SHELL) {
|
if (!SHELL) {
|
||||||
return OS === 'win32' ? 'powershell' : 'bash';
|
return OS === 'win32' ? 'powershell' : 'bash -e';
|
||||||
}
|
}
|
||||||
|
|
||||||
let executable: string;
|
let executable: string;
|
||||||
switch (SHELL) {
|
switch (SHELL) {
|
||||||
case "bash":
|
case "bash": {
|
||||||
|
// -e to not ignore errors, but exit with non-zero code.
|
||||||
|
executable = "bash -e";
|
||||||
|
break;
|
||||||
|
}
|
||||||
case "python":
|
case "python":
|
||||||
case "pwsh": {
|
case "pwsh": {
|
||||||
executable = SHELL;
|
executable = SHELL;
|
||||||
@@ -122,15 +128,17 @@ async function runRetryCmd(): Promise<void> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function runCmd() {
|
async function runCmd(attempt: number) {
|
||||||
const end_time = Date.now() + getTimeout();
|
const end_time = Date.now() + getTimeout();
|
||||||
const executable = getExecutable();
|
const executable = getExecutable();
|
||||||
|
|
||||||
exit = 0;
|
exit = 0;
|
||||||
done = false;
|
done = false;
|
||||||
|
|
||||||
debug(`Running command ${COMMAND} on ${OS} using shell ${executable}`)
|
debug(`Running command ${COMMAND} on ${OS} using shell "${executable}"`)
|
||||||
var child = exec(COMMAND, { 'shell': executable });
|
var child = attempt > 1 && NEW_COMMAND_ON_RETRY
|
||||||
|
? exec(NEW_COMMAND_ON_RETRY, { 'shell': executable })
|
||||||
|
: exec(COMMAND, { 'shell': executable });
|
||||||
|
|
||||||
child.stdout?.on('data', (data) => {
|
child.stdout?.on('data', (data) => {
|
||||||
process.stdout.write(data);
|
process.stdout.write(data);
|
||||||
@@ -175,7 +183,7 @@ async function runAction() {
|
|||||||
try {
|
try {
|
||||||
// just keep overwriting attempts output
|
// just keep overwriting attempts output
|
||||||
setOutput(OUTPUT_TOTAL_ATTEMPTS_KEY, attempt);
|
setOutput(OUTPUT_TOTAL_ATTEMPTS_KEY, attempt);
|
||||||
await runCmd();
|
await runCmd(attempt);
|
||||||
info(`Command completed after ${attempt} attempt(s).`);
|
info(`Command completed after ${attempt} attempt(s).`);
|
||||||
break;
|
break;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
@@ -184,6 +192,8 @@ async function runAction() {
|
|||||||
} else if (!done && RETRY_ON === 'error') {
|
} else if (!done && RETRY_ON === 'error') {
|
||||||
// error: timeout
|
// error: timeout
|
||||||
throw error;
|
throw error;
|
||||||
|
} else if (RETRY_ON_EXIT_CODE && RETRY_ON_EXIT_CODE !== exit){
|
||||||
|
throw error;
|
||||||
} else if (exit > 0 && RETRY_ON === 'timeout') {
|
} else if (exit > 0 && RETRY_ON === 'timeout') {
|
||||||
// error: error
|
// error: error
|
||||||
throw error;
|
throw error;
|
||||||
|
|||||||
Reference in New Issue
Block a user