mirror of
https://github.com/hashicorp/setup-terraform.git
synced 2025-12-16 08:32:34 +00:00
Upgrade Nodejs runtime from 12 to 16 (#170)
This updates the NodeJS runtime version from 12 to 16. NodeJS 12 is EOL on 4/30/2022. NodeJS 16 is supported on all Github Actions Runners v2.285.0 or later. Signed-off-by: Rui Chen <rui@chenrui.dev> Co-authored-by: James Pogran <jpogran@outlook.com>
This commit is contained in:
parent
f9adc4c805
commit
d5cbd3fe79
6 changed files with 14024 additions and 2197 deletions
11
.github/workflows/continuous-integration.yml
vendored
11
.github/workflows/continuous-integration.yml
vendored
|
|
@ -15,17 +15,16 @@ jobs:
|
||||||
os: [ubuntu-latest, windows-latest, macos-latest]
|
os: [ubuntu-latest, windows-latest, macos-latest]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- uses: actions/checkout@v3
|
||||||
uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- name: Setup Node.js 12.x
|
- name: Setup Node.js 16.x
|
||||||
uses: actions/setup-node@v1
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: '12.x'
|
node-version: '16.x'
|
||||||
|
|
||||||
- name: Install
|
- name: Install
|
||||||
run: npm clean-install
|
run: npm clean-install
|
||||||
|
|
||||||
- name: Verify
|
- name: Verify
|
||||||
if: runner.os == 'Linux'
|
if: runner.os == 'Linux'
|
||||||
run: |
|
run: |
|
||||||
|
|
|
||||||
134
.github/workflows/setup-terraform.yml
vendored
134
.github/workflows/setup-terraform.yml
vendored
|
|
@ -12,7 +12,7 @@ defaults:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
terraform-versions:
|
terraform-versions:
|
||||||
name: 'Terraform Versions'
|
name: 'Terraform Versions'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
|
|
@ -20,13 +20,13 @@ jobs:
|
||||||
terraform-versions: [0.11.14, latest]
|
terraform-versions: [0.11.14, latest]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform - ${{ matrix['terraform-versions'] }}
|
- name: Setup Terraform - ${{ matrix['terraform-versions'] }}
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
terraform_version: ${{ matrix['terraform-versions'] }}
|
terraform_version: ${{ matrix['terraform-versions'] }}
|
||||||
|
|
||||||
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
||||||
if: ${{ matrix['terraform-versions'] != 'latest' }}
|
if: ${{ matrix['terraform-versions'] != 'latest' }}
|
||||||
run: terraform version | grep ${{ matrix['terraform-versions']}}
|
run: terraform version | grep ${{ matrix['terraform-versions']}}
|
||||||
|
|
@ -34,9 +34,9 @@ jobs:
|
||||||
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
||||||
if: ${{ matrix['terraform-versions'] == 'latest' }}
|
if: ${{ matrix['terraform-versions'] == 'latest' }}
|
||||||
run: terraform version | grep 'Terraform v'
|
run: terraform version | grep 'Terraform v'
|
||||||
|
|
||||||
terraform-versions-no-wrapper:
|
terraform-versions-no-wrapper:
|
||||||
name: 'Terraform Versions No Wrapper'
|
name: 'Terraform Versions No Wrapper'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
|
|
@ -44,8 +44,8 @@ jobs:
|
||||||
terraform-versions: [0.11.14, latest]
|
terraform-versions: [0.11.14, latest]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform (no wrapper) - ${{ matrix['terraform-versions'] }}
|
- name: Setup Terraform (no wrapper) - ${{ matrix['terraform-versions'] }}
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
|
|
@ -59,9 +59,9 @@ jobs:
|
||||||
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
||||||
if: ${{ matrix['terraform-versions'] == 'latest' }}
|
if: ${{ matrix['terraform-versions'] == 'latest' }}
|
||||||
run: terraform version | grep 'Terraform v'
|
run: terraform version | grep 'Terraform v'
|
||||||
|
|
||||||
terraform-versions-constraints:
|
terraform-versions-constraints:
|
||||||
name: 'Terraform Versions Constraints'
|
name: 'Terraform Versions Constraints'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
|
|
@ -69,7 +69,7 @@ jobs:
|
||||||
terraform-versions: [~0.12, 0.12.x, <0.13.0]
|
terraform-versions: [~0.12, 0.12.x, <0.13.0]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform - ${{ matrix['terraform-versions'] }}
|
- name: Setup Terraform - ${{ matrix['terraform-versions'] }}
|
||||||
uses: ./
|
uses: ./
|
||||||
|
|
@ -78,9 +78,9 @@ jobs:
|
||||||
|
|
||||||
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
||||||
run: terraform version | grep 'Terraform v0\.12'
|
run: terraform version | grep 'Terraform v0\.12'
|
||||||
|
|
||||||
terraform-versions-constraints-no-wrapper:
|
terraform-versions-constraints-no-wrapper:
|
||||||
name: 'Terraform Versions Constraints No Wrapper'
|
name: 'Terraform Versions Constraints No Wrapper'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
|
|
@ -88,8 +88,8 @@ jobs:
|
||||||
terraform-versions: [~0.12, 0.12.x, <0.13.0]
|
terraform-versions: [~0.12, 0.12.x, <0.13.0]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform (no wrapper) - ${{ matrix['terraform-versions'] }}
|
- name: Setup Terraform (no wrapper) - ${{ matrix['terraform-versions'] }}
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
|
|
@ -98,9 +98,9 @@ jobs:
|
||||||
|
|
||||||
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
- name: Validate Teraform Version - ${{ matrix['terraform-versions'] }}
|
||||||
run: terraform version | grep 'Terraform v0\.12'
|
run: terraform version | grep 'Terraform v0\.12'
|
||||||
|
|
||||||
terraform-credentials-cloud:
|
terraform-credentials-cloud:
|
||||||
name: 'Terraform Cloud Credentials'
|
name: 'Terraform Cloud Credentials'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
|
|
@ -109,14 +109,14 @@ jobs:
|
||||||
TF_CLOUD_API_TOKEN: 'XXXXXXXXXXXXXX.atlasv1.XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
|
TF_CLOUD_API_TOKEN: 'XXXXXXXXXXXXXX.atlasv1.XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform
|
- name: Setup Terraform
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
cli_config_credentials_token: ${{ env.TF_CLOUD_API_TOKEN }}
|
cli_config_credentials_token: ${{ env.TF_CLOUD_API_TOKEN }}
|
||||||
|
|
||||||
- name: Validate Terraform Credentials (Windows)
|
- name: Validate Terraform Credentials (Windows)
|
||||||
if: runner.os == 'Windows'
|
if: runner.os == 'Windows'
|
||||||
run: |
|
run: |
|
||||||
cat ${APPDATA}/terraform.rc | grep 'credentials "app.terraform.io"'
|
cat ${APPDATA}/terraform.rc | grep 'credentials "app.terraform.io"'
|
||||||
|
|
@ -127,9 +127,9 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
cat ${HOME}/.terraformrc | grep 'credentials "app.terraform.io"'
|
cat ${HOME}/.terraformrc | grep 'credentials "app.terraform.io"'
|
||||||
cat ${HOME}/.terraformrc | grep 'token = "${{ env.TF_CLOUD_API_TOKEN }}"'
|
cat ${HOME}/.terraformrc | grep 'token = "${{ env.TF_CLOUD_API_TOKEN }}"'
|
||||||
|
|
||||||
terraform-credentials-enterprise:
|
terraform-credentials-enterprise:
|
||||||
name: 'Terraform Enterprise Credentials'
|
name: 'Terraform Enterprise Credentials'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
|
|
@ -138,15 +138,15 @@ jobs:
|
||||||
TF_CLOUD_API_TOKEN: 'XXXXXXXXXXXXXX.atlasv1.XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
|
TF_CLOUD_API_TOKEN: 'XXXXXXXXXXXXXX.atlasv1.XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform
|
- name: Setup Terraform
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
cli_config_credentials_hostname: 'terraform.example.com'
|
cli_config_credentials_hostname: 'terraform.example.com'
|
||||||
cli_config_credentials_token: ${{ env.TF_CLOUD_API_TOKEN }}
|
cli_config_credentials_token: ${{ env.TF_CLOUD_API_TOKEN }}
|
||||||
|
|
||||||
- name: Validate Terraform Credentials (Windows)
|
- name: Validate Terraform Credentials (Windows)
|
||||||
if: runner.os == 'Windows'
|
if: runner.os == 'Windows'
|
||||||
run: |
|
run: |
|
||||||
cat ${APPDATA}/terraform.rc | grep 'credentials "terraform.example.com"'
|
cat ${APPDATA}/terraform.rc | grep 'credentials "terraform.example.com"'
|
||||||
|
|
@ -157,96 +157,96 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
cat ${HOME}/.terraformrc | grep 'credentials "terraform.example.com"'
|
cat ${HOME}/.terraformrc | grep 'credentials "terraform.example.com"'
|
||||||
cat ${HOME}/.terraformrc | grep 'token = "${{ env.TF_CLOUD_API_TOKEN }}"'
|
cat ${HOME}/.terraformrc | grep 'token = "${{ env.TF_CLOUD_API_TOKEN }}"'
|
||||||
|
|
||||||
terraform-credentials-none:
|
terraform-credentials-none:
|
||||||
name: 'Terraform No Credentials'
|
name: 'Terraform No Credentials'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
os: [ubuntu-latest, windows-latest, macos-latest]
|
os: [ubuntu-latest, windows-latest, macos-latest]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform
|
- name: Setup Terraform
|
||||||
uses: ./
|
uses: ./
|
||||||
|
|
||||||
- name: Validate Terraform Credentials (Windows)
|
- name: Validate Terraform Credentials (Windows)
|
||||||
if: runner.os == 'Windows'
|
if: runner.os == 'Windows'
|
||||||
run: |
|
run: |
|
||||||
[[ -f ${APPDATA}/terraform.rc ]] || exit 0
|
[[ -f ${APPDATA}/terraform.rc ]] || exit 0
|
||||||
|
|
||||||
- name: Validate Teraform Credentials (Linux & macOS)
|
- name: Validate Teraform Credentials (Linux & macOS)
|
||||||
if: runner.os != 'Windows'
|
if: runner.os != 'Windows'
|
||||||
run: |
|
run: |
|
||||||
[[ -f ${HOME}/.terraformrc ]] || exit 0
|
[[ -f ${HOME}/.terraformrc ]] || exit 0
|
||||||
|
|
||||||
terraform-arguments:
|
terraform-arguments:
|
||||||
name: 'Terraform Arguments'
|
name: 'Terraform Arguments'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
os: [ubuntu-latest, windows-latest, macos-latest]
|
os: [ubuntu-latest, windows-latest, macos-latest]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform
|
- name: Setup Terraform
|
||||||
uses: ./
|
uses: ./
|
||||||
|
|
||||||
- name: Check No Arguments
|
- name: Check No Arguments
|
||||||
run: terraform || exit 0
|
run: terraform || exit 0
|
||||||
|
|
||||||
- name: Check Single Argument
|
- name: Check Single Argument
|
||||||
run: terraform help || exit 0
|
run: terraform help || exit 0
|
||||||
|
|
||||||
- name: Check Single Argument Hyphen
|
- name: Check Single Argument Hyphen
|
||||||
run: terraform -help
|
run: terraform -help
|
||||||
|
|
||||||
- name: Check Single Argument Double Hyphen
|
- name: Check Single Argument Double Hyphen
|
||||||
run: terraform --help
|
run: terraform --help
|
||||||
|
|
||||||
- name: Check Single Argument Subcommand
|
- name: Check Single Argument Subcommand
|
||||||
run: terraform fmt -check
|
run: terraform fmt -check
|
||||||
|
|
||||||
- name: Check Multiple Arguments Subcommand
|
- name: Check Multiple Arguments Subcommand
|
||||||
run: terraform fmt -check -list=true -no-color
|
run: terraform fmt -check -list=true -no-color
|
||||||
|
|
||||||
terraform-arguments-no-wrapper:
|
terraform-arguments-no-wrapper:
|
||||||
name: 'Terraform Arguments No Wrapper'
|
name: 'Terraform Arguments No Wrapper'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
os: [ubuntu-latest, windows-latest, macos-latest]
|
os: [ubuntu-latest, windows-latest, macos-latest]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform
|
- name: Setup Terraform
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
terraform_wrapper: false
|
terraform_wrapper: false
|
||||||
|
|
||||||
- name: Check No Arguments
|
- name: Check No Arguments
|
||||||
run: terraform || exit 0
|
run: terraform || exit 0
|
||||||
|
|
||||||
- name: Check Single Argument
|
- name: Check Single Argument
|
||||||
run: terraform help || exit 0
|
run: terraform help || exit 0
|
||||||
|
|
||||||
- name: Check Single Argument Hyphen
|
- name: Check Single Argument Hyphen
|
||||||
run: terraform -help
|
run: terraform -help
|
||||||
|
|
||||||
- name: Check Single Argument Double Hyphen
|
- name: Check Single Argument Double Hyphen
|
||||||
run: terraform --help
|
run: terraform --help
|
||||||
|
|
||||||
- name: Check Single Argument Subcommand
|
- name: Check Single Argument Subcommand
|
||||||
run: terraform fmt -check
|
run: terraform fmt -check
|
||||||
|
|
||||||
- name: Check Multiple Arguments Subcommand
|
- name: Check Multiple Arguments Subcommand
|
||||||
run: terraform fmt -check -list=true -no-color
|
run: terraform fmt -check -list=true -no-color
|
||||||
|
|
||||||
terraform-run-local:
|
terraform-run-local:
|
||||||
name: 'Terraform Run Local'
|
name: 'Terraform Run Local'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
|
|
@ -256,30 +256,30 @@ jobs:
|
||||||
working-directory: ./.github/workflows/data/local
|
working-directory: ./.github/workflows/data/local
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform
|
- name: Setup Terraform
|
||||||
uses: ./
|
uses: ./
|
||||||
|
|
||||||
- name: Terraform Init
|
- name: Terraform Init
|
||||||
shell: bash
|
shell: bash
|
||||||
run: terraform init
|
run: terraform init
|
||||||
|
|
||||||
- name: Terraform Format
|
- name: Terraform Format
|
||||||
shell: bash
|
shell: bash
|
||||||
run: terraform fmt -check
|
run: terraform fmt -check
|
||||||
|
|
||||||
- name: Terraform Plan
|
- name: Terraform Plan
|
||||||
id: plan
|
id: plan
|
||||||
shell: bash
|
shell: bash
|
||||||
run: terraform plan
|
run: terraform plan
|
||||||
|
|
||||||
- name: Print Terraform Plan
|
- name: Print Terraform Plan
|
||||||
shell: bash
|
shell: bash
|
||||||
run: echo "${{ steps.plan.outputs.stdout }}"
|
run: echo "${{ steps.plan.outputs.stdout }}"
|
||||||
|
|
||||||
terraform-run-local-no-wrapper:
|
terraform-run-local-no-wrapper:
|
||||||
name: 'Terraform Run Local No Wrapper'
|
name: 'Terraform Run Local No Wrapper'
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
|
|
@ -289,22 +289,22 @@ jobs:
|
||||||
working-directory: ./.github/workflows/data/local
|
working-directory: ./.github/workflows/data/local
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup Terraform
|
- name: Setup Terraform
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
terraform_wrapper: false
|
terraform_wrapper: false
|
||||||
|
|
||||||
- name: Terraform Init
|
- name: Terraform Init
|
||||||
shell: bash
|
shell: bash
|
||||||
run: terraform init
|
run: terraform init
|
||||||
|
|
||||||
- name: Terraform Format
|
- name: Terraform Format
|
||||||
shell: bash
|
shell: bash
|
||||||
run: terraform fmt -check
|
run: terraform fmt -check
|
||||||
|
|
||||||
- name: Terraform Plan
|
- name: Terraform Plan
|
||||||
id: plan
|
id: plan
|
||||||
shell: bash
|
shell: bash
|
||||||
run: terraform plan
|
run: terraform plan
|
||||||
|
|
|
||||||
|
|
@ -18,7 +18,7 @@ inputs:
|
||||||
default: 'true'
|
default: 'true'
|
||||||
required: false
|
required: false
|
||||||
runs:
|
runs:
|
||||||
using: 'node12'
|
using: 'node16'
|
||||||
main: 'dist/index.js'
|
main: 'dist/index.js'
|
||||||
branding:
|
branding:
|
||||||
icon: 'terminal'
|
icon: 'terminal'
|
||||||
|
|
|
||||||
2587
dist/index.js
vendored
2587
dist/index.js
vendored
File diff suppressed because it is too large
Load diff
7310
package-lock.json
generated
7310
package-lock.json
generated
File diff suppressed because it is too large
Load diff
6177
wrapper/package-lock.json
generated
6177
wrapper/package-lock.json
generated
File diff suppressed because it is too large
Load diff
Loading…
Add table
Add a link
Reference in a new issue