You've already forked setup-node
							
							
				mirror of
				https://github.com/actions/setup-node.git
				synced 2025-11-04 08:46:39 +07:00 
			
		
		
		
	Compare commits
	
		
			12 Commits
		
	
	
		
			v4.0.0
			...
			Node-Test-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| eff380dfbc | |||
| c2ac33f2c6 | |||
| 25b062c917 | |||
| 60edb5dd54 | |||
| d86ebcd40b | |||
| b39b52d121 | |||
| 7247617371 | |||
| f3ec4ca66f | |||
| ec97f37504 | |||
| 5ef044f9d0 | |||
| c45882a6ea | |||
| ee36e8b5c0 | 
							
								
								
									
										2
									
								
								.github/workflows/basic-validation.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/basic-validation.yml
									
									
									
									
										vendored
									
									
								
							@ -15,3 +15,5 @@ jobs:
 | 
			
		||||
  call-basic-validation:
 | 
			
		||||
    name: Basic validation
 | 
			
		||||
    uses: actions/reusable-workflows/.github/workflows/basic-validation.yml@main
 | 
			
		||||
    with:
 | 
			
		||||
      node-version: '20.x'
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										2
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							@ -15,3 +15,5 @@ jobs:
 | 
			
		||||
  call-check-dist:
 | 
			
		||||
    name: Check dist/
 | 
			
		||||
    uses: actions/reusable-workflows/.github/workflows/check-dist.yml@main
 | 
			
		||||
    with:
 | 
			
		||||
      node-version: '20.x'
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										18
									
								
								.github/workflows/e2e-cache.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.github/workflows/e2e-cache.yml
									
									
									
									
										vendored
									
									
								
							@ -19,7 +19,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [12, 14, 16]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Clean global cache
 | 
			
		||||
@ -42,7 +42,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [12, 14, 16]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Install pnpm
 | 
			
		||||
@ -75,7 +75,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [14, 16]
 | 
			
		||||
        node-version: [18, 20]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Yarn version
 | 
			
		||||
@ -93,7 +93,7 @@ jobs:
 | 
			
		||||
          node-version: ${{ matrix.node-version }}
 | 
			
		||||
          cache: 'yarn'
 | 
			
		||||
      - name: Install dependencies
 | 
			
		||||
        run: yarn install
 | 
			
		||||
        run: yarn install --ignore-engines
 | 
			
		||||
      - name: Verify node and yarn
 | 
			
		||||
        run: __tests__/verify-node.sh "${{ matrix.node-version }}"
 | 
			
		||||
        shell: bash
 | 
			
		||||
@ -107,7 +107,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [12, 14, 16]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Update yarn
 | 
			
		||||
@ -139,7 +139,7 @@ jobs:
 | 
			
		||||
    name: Test yarn subprojects
 | 
			
		||||
    strategy:
 | 
			
		||||
      matrix:
 | 
			
		||||
        node-version: [12, 14, 16]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
@ -166,7 +166,7 @@ jobs:
 | 
			
		||||
    name: Test yarn subprojects all locally managed
 | 
			
		||||
    strategy:
 | 
			
		||||
      matrix:
 | 
			
		||||
        node-version: [12, 14, 16]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
@ -193,7 +193,7 @@ jobs:
 | 
			
		||||
    name: Test yarn subprojects some locally managed
 | 
			
		||||
    strategy:
 | 
			
		||||
      matrix:
 | 
			
		||||
        node-version: [12, 14, 16]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
@ -220,7 +220,7 @@ jobs:
 | 
			
		||||
    name: Test yarn subprojects managed by git
 | 
			
		||||
    strategy:
 | 
			
		||||
      matrix:
 | 
			
		||||
        node-version: [12, 14, 16]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										46
									
								
								.github/workflows/versions.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										46
									
								
								.github/workflows/versions.yml
									
									
									
									
										vendored
									
									
								
							@ -18,7 +18,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [10, 12, 14]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup Node
 | 
			
		||||
@ -34,7 +34,7 @@ jobs:
 | 
			
		||||
    strategy:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-13]
 | 
			
		||||
        node-version: [lts/dubnium, lts/erbium, lts/fermium, lts/*, lts/-1]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
@ -43,7 +43,7 @@ jobs:
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: ${{ matrix.node-version }}
 | 
			
		||||
          check-latest: true
 | 
			
		||||
      - if: runner.os != 'Windows'
 | 
			
		||||
      - if: runner.os != 'Windows' && runner.os != 'macOS'
 | 
			
		||||
        name: Verify node and npm
 | 
			
		||||
        run: |
 | 
			
		||||
          . "$NVM_DIR/nvm.sh"
 | 
			
		||||
@ -83,7 +83,7 @@ jobs:
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version:
 | 
			
		||||
          [16.0.0-nightly20210420a0261d231c, 17-nightly, 18.0.0-nightly]
 | 
			
		||||
          [20.11.0-nightly202312211a0be537da, 21-nightly, 18.0.0-nightly]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup Node
 | 
			
		||||
@ -103,7 +103,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [16.0.0-rc.1, 18.0.0-rc.2, 19.0.0-rc.0]
 | 
			
		||||
        node-version: [20.0.0-rc.1, 18.0.0-rc.2, 19.0.0-rc.0]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup Node
 | 
			
		||||
@ -123,7 +123,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [10.15, 12.16.0, 14.2.0, 16.3.0]
 | 
			
		||||
        node-version: [18.20.0, 20.10.0, 22.0.0]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup Node
 | 
			
		||||
@ -140,7 +140,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [10, 12, 14]
 | 
			
		||||
        node-version: [18, 20, 22]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup Node and check latest
 | 
			
		||||
@ -162,15 +162,12 @@ jobs:
 | 
			
		||||
          [.nvmrc, .tool-versions, .tool-versions-node, package.json]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Remove volta from package.json
 | 
			
		||||
        shell: bash
 | 
			
		||||
        run: cat <<< "$(jq 'del(.volta)' ./__tests__/data/package.json)" > ./__tests__/data/package.json
 | 
			
		||||
      - name: Setup node from node version file
 | 
			
		||||
        uses: ./
 | 
			
		||||
        with:
 | 
			
		||||
          node-version-file: '__tests__/data/${{ matrix.node-version-file }}'
 | 
			
		||||
      - name: Verify node
 | 
			
		||||
        run: __tests__/verify-node.sh 14
 | 
			
		||||
        run: __tests__/verify-node.sh 20
 | 
			
		||||
 | 
			
		||||
  version-file-volta:
 | 
			
		||||
    runs-on: ${{ matrix.os }}
 | 
			
		||||
@ -183,9 +180,24 @@ jobs:
 | 
			
		||||
      - name: Setup node from node version file
 | 
			
		||||
        uses: ./
 | 
			
		||||
        with:
 | 
			
		||||
          node-version-file: '__tests__/data/package.json'
 | 
			
		||||
          node-version-file: '__tests__/data/package-volta.json'
 | 
			
		||||
      - name: Verify node
 | 
			
		||||
        run: __tests__/verify-node.sh 16
 | 
			
		||||
        run: __tests__/verify-node.sh 20
 | 
			
		||||
 | 
			
		||||
  version-file-volta-extends:
 | 
			
		||||
    runs-on: ${{ matrix.os }}
 | 
			
		||||
    strategy:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup node from node version file
 | 
			
		||||
        uses: ./
 | 
			
		||||
        with:
 | 
			
		||||
          node-version-file: '__tests__/data/package-volta-extends.json'
 | 
			
		||||
      - name: Verify node
 | 
			
		||||
        run: __tests__/verify-node.sh 20
 | 
			
		||||
 | 
			
		||||
  node-dist:
 | 
			
		||||
    runs-on: ${{ matrix.os }}
 | 
			
		||||
@ -193,7 +205,7 @@ jobs:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        node-version: [11, 13]
 | 
			
		||||
        node-version: [17, 19]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup Node from dist
 | 
			
		||||
@ -209,7 +221,7 @@ jobs:
 | 
			
		||||
    strategy:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-latest]
 | 
			
		||||
        os: [ubuntu-latest, windows-latest, macos-13]
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      # test old versions which didn't have npm and layout different
 | 
			
		||||
@ -225,10 +237,10 @@ jobs:
 | 
			
		||||
    runs-on: windows-latest
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup node 14 x86 from dist
 | 
			
		||||
      - name: Setup node 20 x86 from dist
 | 
			
		||||
        uses: ./
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: '14'
 | 
			
		||||
          node-version: '20'
 | 
			
		||||
          architecture: 'x86'
 | 
			
		||||
      - name: Verify node
 | 
			
		||||
        run: __tests__/verify-arch.sh "ia32"
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							@ -1,6 +1,6 @@
 | 
			
		||||
---
 | 
			
		||||
name: "@actions/cache"
 | 
			
		||||
version: 3.2.2
 | 
			
		||||
version: 3.2.4
 | 
			
		||||
type: npm
 | 
			
		||||
summary: Actions cache lib
 | 
			
		||||
homepage: https://github.com/actions/toolkit/tree/main/packages/cache
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										2
									
								
								.licenses/npm/@actions/http-client.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/http-client.dep.yml
									
									
									
										generated
									
									
									
								
							@ -1,6 +1,6 @@
 | 
			
		||||
---
 | 
			
		||||
name: "@actions/http-client"
 | 
			
		||||
version: 2.2.0
 | 
			
		||||
version: 2.2.1
 | 
			
		||||
type: npm
 | 
			
		||||
summary: Actions Http Client
 | 
			
		||||
homepage: https://github.com/actions/toolkit/tree/main/packages/http-client
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										2
									
								
								.licenses/npm/@types/node.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@types/node.dep.yml
									
									
									
										generated
									
									
									
								
							@ -1,6 +1,6 @@
 | 
			
		||||
---
 | 
			
		||||
name: "@types/node"
 | 
			
		||||
version: 20.8.7
 | 
			
		||||
version: 20.11.25
 | 
			
		||||
type: npm
 | 
			
		||||
summary: TypeScript definitions for node
 | 
			
		||||
homepage: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node
 | 
			
		||||
 | 
			
		||||
@ -1,9 +1,9 @@
 | 
			
		||||
---
 | 
			
		||||
name: semver
 | 
			
		||||
version: 7.5.4
 | 
			
		||||
version: 7.6.0
 | 
			
		||||
type: npm
 | 
			
		||||
summary: The semantic version parser used by npm.
 | 
			
		||||
homepage: 
 | 
			
		||||
homepage:
 | 
			
		||||
license: isc
 | 
			
		||||
licenses:
 | 
			
		||||
- sources: LICENSE
 | 
			
		||||
							
								
								
									
										2
									
								
								.licenses/npm/undici-types.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/undici-types.dep.yml
									
									
									
										generated
									
									
									
								
							@ -1,6 +1,6 @@
 | 
			
		||||
---
 | 
			
		||||
name: undici-types
 | 
			
		||||
version: 5.25.3
 | 
			
		||||
version: 5.26.5
 | 
			
		||||
type: npm
 | 
			
		||||
summary: A stand-alone types package for Undici
 | 
			
		||||
homepage: https://undici.nodejs.org
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										2
									
								
								.licenses/npm/undici.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/undici.dep.yml
									
									
									
										generated
									
									
									
								
							@ -1,6 +1,6 @@
 | 
			
		||||
---
 | 
			
		||||
name: undici
 | 
			
		||||
version: 5.26.5
 | 
			
		||||
version: 5.28.3
 | 
			
		||||
type: npm
 | 
			
		||||
summary: An HTTP/1.1 client, written from scratch for Node.js
 | 
			
		||||
homepage: https://undici.nodejs.org
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										24
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								README.md
									
									
									
									
									
								
							@ -18,14 +18,14 @@ See [action.yml](action.yml)
 | 
			
		||||
 | 
			
		||||
<!-- start usage -->
 | 
			
		||||
```yaml
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    # Version Spec of the version to use in SemVer notation.
 | 
			
		||||
    # It also emits such aliases as lts, latest, nightly and canary builds
 | 
			
		||||
    # Examples: 12.x, 10.15.1, >=10.15.0, lts/Hydrogen, 16-nightly, latest, node
 | 
			
		||||
    node-version: ''
 | 
			
		||||
 | 
			
		||||
    # File containing the version Spec of the version to use.  Examples: .nvmrc, .node-version, .tool-versions.
 | 
			
		||||
    # File containing the version Spec of the version to use.  Examples: package.json, .nvmrc, .node-version, .tool-versions.
 | 
			
		||||
    # If node-version and node-version-file are both provided the action will use version from node-version. 
 | 
			
		||||
    node-version-file: ''
 | 
			
		||||
 | 
			
		||||
@ -84,7 +84,7 @@ See [action.yml](action.yml)
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: 18
 | 
			
		||||
- run: npm ci
 | 
			
		||||
@ -103,12 +103,12 @@ The `node-version` input supports the Semantic Versioning Specification, for mor
 | 
			
		||||
 | 
			
		||||
Examples:
 | 
			
		||||
 | 
			
		||||
 - Major versions: `14`, `16`, `18`
 | 
			
		||||
 - Major versions: `18`, `20`
 | 
			
		||||
 - More specific versions: `10.15`, `16.15.1` , `18.4.0`
 | 
			
		||||
 - NVM LTS syntax: `lts/erbium`, `lts/fermium`, `lts/*`, `lts/-n`
 | 
			
		||||
 - Latest release: `*` or `latest`/`current`/`node`
 | 
			
		||||
 | 
			
		||||
**Note:** Like the other values, `*` will get the latest [locally-cached Node.js version](https://github.com/actions/runner-images/blob/main/images/linux/Ubuntu2204-Readme.md#nodejs), or the latest version from [actions/node-versions](https://github.com/actions/node-versions/blob/main/versions-manifest.json), depending on the [`check-latest`](docs/advanced-usage.md#check-latest-version) input.
 | 
			
		||||
**Note:** Like the other values, `*` will get the latest [locally-cached Node.js version](https://github.com/actions/runner-images/blob/main/images/ubuntu/Ubuntu2204-Readme.md#nodejs), or the latest version from [actions/node-versions](https://github.com/actions/node-versions/blob/main/versions-manifest.json), depending on the [`check-latest`](docs/advanced-usage.md#check-latest-version) input.
 | 
			
		||||
 | 
			
		||||
`current`/`latest`/`node` always resolve to the latest [dist version](https://nodejs.org/dist/index.json).
 | 
			
		||||
That version is then downloaded from actions/node-versions if possible, or directly from Node.js if not.
 | 
			
		||||
@ -133,9 +133,9 @@ See the examples of using cache for `yarn`/`pnpm` and `cache-dependency-path` in
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: 16
 | 
			
		||||
    node-version: 20
 | 
			
		||||
    cache: 'npm'
 | 
			
		||||
- run: npm ci
 | 
			
		||||
- run: npm test
 | 
			
		||||
@ -146,9 +146,9 @@ steps:
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: 16
 | 
			
		||||
    node-version: 20
 | 
			
		||||
    cache: 'npm'
 | 
			
		||||
    cache-dependency-path: subdir/package-lock.json
 | 
			
		||||
- run: npm ci
 | 
			
		||||
@ -168,7 +168,7 @@ jobs:
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup node
 | 
			
		||||
        uses: actions/setup-node@v3
 | 
			
		||||
        uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: ${{ matrix.node }}
 | 
			
		||||
      - run: npm ci
 | 
			
		||||
@ -182,10 +182,10 @@ jobs:
 | 
			
		||||
To get a higher rate limit, you can [generate a personal access token on github.com](https://github.com/settings/tokens/new) and pass it as the `token` input for the action:
 | 
			
		||||
 | 
			
		||||
```yaml
 | 
			
		||||
uses: actions/setup-node@v3
 | 
			
		||||
uses: actions/setup-node@v4
 | 
			
		||||
with:
 | 
			
		||||
  token: ${{ secrets.GH_DOTCOM_TOKEN }}
 | 
			
		||||
  node-version: 16
 | 
			
		||||
  node-version: 20
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
If the runner is not able to access github.com, any Nodejs versions requested during a workflow run must come from the runner's tool cache. See "[Setting up the tool cache on self-hosted runners without internet access](https://docs.github.com/en/enterprise-server@3.2/admin/github-actions/managing-access-to-actions-from-githubcom/setting-up-the-tool-cache-on-self-hosted-runners-without-internet-access)" for more information.
 | 
			
		||||
 | 
			
		||||
@ -1 +1 @@
 | 
			
		||||
v14
 | 
			
		||||
v20
 | 
			
		||||
 | 
			
		||||
@ -1 +1 @@
 | 
			
		||||
nodejs 14.0.0
 | 
			
		||||
nodejs 20.0.0
 | 
			
		||||
 | 
			
		||||
@ -1 +1 @@
 | 
			
		||||
node 14.0.0
 | 
			
		||||
node 20.0.0
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										5
									
								
								__tests__/data/package-volta-extends.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								__tests__/data/package-volta-extends.json
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,5 @@
 | 
			
		||||
{
 | 
			
		||||
  "volta": {
 | 
			
		||||
    "extends": "./package-volta.json"
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										8
									
								
								__tests__/data/package-volta.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								__tests__/data/package-volta.json
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,8 @@
 | 
			
		||||
{
 | 
			
		||||
  "engines": {
 | 
			
		||||
    "node": "^14.0.0"
 | 
			
		||||
  },
 | 
			
		||||
  "volta": {
 | 
			
		||||
    "node": "20.0.0"
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
@ -1,8 +1,5 @@
 | 
			
		||||
{
 | 
			
		||||
  "engines": {
 | 
			
		||||
    "node": "^14.0.0"
 | 
			
		||||
  },
 | 
			
		||||
  "volta": {
 | 
			
		||||
    "node": "16.0.0"
 | 
			
		||||
    "node": "^20.0.0"
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -2,6 +2,7 @@ import * as core from '@actions/core';
 | 
			
		||||
import * as exec from '@actions/exec';
 | 
			
		||||
import * as tc from '@actions/tool-cache';
 | 
			
		||||
import * as cache from '@actions/cache';
 | 
			
		||||
import * as io from '@actions/io';
 | 
			
		||||
 | 
			
		||||
import fs from 'fs';
 | 
			
		||||
import path from 'path';
 | 
			
		||||
@ -24,11 +25,13 @@ describe('main tests', () => {
 | 
			
		||||
  let startGroupSpy: jest.SpyInstance;
 | 
			
		||||
  let endGroupSpy: jest.SpyInstance;
 | 
			
		||||
 | 
			
		||||
  let whichSpy: jest.SpyInstance;
 | 
			
		||||
 | 
			
		||||
  let existsSpy: jest.SpyInstance;
 | 
			
		||||
 | 
			
		||||
  let getExecOutputSpy: jest.SpyInstance;
 | 
			
		||||
 | 
			
		||||
  let parseNodeVersionSpy: jest.SpyInstance;
 | 
			
		||||
  let getNodeVersionFromFileSpy: jest.SpyInstance;
 | 
			
		||||
  let cnSpy: jest.SpyInstance;
 | 
			
		||||
  let findSpy: jest.SpyInstance;
 | 
			
		||||
  let isCacheActionAvailable: jest.SpyInstance;
 | 
			
		||||
@ -41,6 +44,7 @@ describe('main tests', () => {
 | 
			
		||||
    // node
 | 
			
		||||
    os = {};
 | 
			
		||||
    console.log('::stop-commands::stoptoken');
 | 
			
		||||
    process.env['GITHUB_WORKSPACE'] = path.join(__dirname, 'data');
 | 
			
		||||
    process.env['GITHUB_PATH'] = ''; // Stub out ENV file functionality so we can verify it writes to standard out
 | 
			
		||||
    process.env['GITHUB_OUTPUT'] = ''; // Stub out ENV file functionality so we can verify it writes to standard out
 | 
			
		||||
    infoSpy = jest.spyOn(core, 'info');
 | 
			
		||||
@ -56,18 +60,18 @@ describe('main tests', () => {
 | 
			
		||||
    inSpy = jest.spyOn(core, 'getInput');
 | 
			
		||||
    inSpy.mockImplementation(name => inputs[name]);
 | 
			
		||||
 | 
			
		||||
    whichSpy = jest.spyOn(io, 'which');
 | 
			
		||||
 | 
			
		||||
    getExecOutputSpy = jest.spyOn(exec, 'getExecOutput');
 | 
			
		||||
 | 
			
		||||
    findSpy = jest.spyOn(tc, 'find');
 | 
			
		||||
 | 
			
		||||
    isCacheActionAvailable = jest.spyOn(cache, 'isFeatureAvailable');
 | 
			
		||||
 | 
			
		||||
    existsSpy = jest.spyOn(fs, 'existsSync');
 | 
			
		||||
 | 
			
		||||
    cnSpy = jest.spyOn(process.stdout, 'write');
 | 
			
		||||
    cnSpy.mockImplementation(line => {
 | 
			
		||||
      // uncomment to debug
 | 
			
		||||
      // process.stderr.write('write:' + line + '\n');
 | 
			
		||||
      process.stderr.write('write:' + line + '\n');
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    setupNodeJsSpy = jest.spyOn(OfficialBuilds.prototype, 'setupNodeJs');
 | 
			
		||||
@ -85,7 +89,7 @@ describe('main tests', () => {
 | 
			
		||||
    jest.restoreAllMocks();
 | 
			
		||||
  }, 100000);
 | 
			
		||||
 | 
			
		||||
  describe('parseNodeVersionFile', () => {
 | 
			
		||||
  describe('getNodeVersionFromFile', () => {
 | 
			
		||||
    each`
 | 
			
		||||
      contents                                     | expected
 | 
			
		||||
      ${'12'}                                      | ${'12'}
 | 
			
		||||
@ -100,9 +104,27 @@ describe('main tests', () => {
 | 
			
		||||
      ${'unknown format'}                          | ${'unknown format'}
 | 
			
		||||
      ${'  14.1.0  '}                              | ${'14.1.0'}
 | 
			
		||||
      ${'{"volta": {"node": ">=14.0.0 <=17.0.0"}}'}| ${'>=14.0.0 <=17.0.0'}
 | 
			
		||||
      ${'{"volta": {"extends": "./package.json"}}'}| ${'18.0.0'}
 | 
			
		||||
      ${'{"engines": {"node": "17.0.0"}}'}         | ${'17.0.0'}
 | 
			
		||||
      ${'{}'}                                      | ${null}
 | 
			
		||||
    `.it('parses "$contents"', ({contents, expected}) => {
 | 
			
		||||
      expect(util.parseNodeVersionFile(contents)).toBe(expected);
 | 
			
		||||
      const existsSpy = jest.spyOn(fs, 'existsSync');
 | 
			
		||||
      existsSpy.mockImplementation(() => true);
 | 
			
		||||
 | 
			
		||||
      const readFileSpy = jest.spyOn(fs, 'readFileSync');
 | 
			
		||||
      readFileSpy.mockImplementation(filePath => {
 | 
			
		||||
        if (
 | 
			
		||||
          typeof filePath === 'string' &&
 | 
			
		||||
          path.basename(filePath) === 'package.json'
 | 
			
		||||
        ) {
 | 
			
		||||
          // Special case for volta.extends
 | 
			
		||||
          return '{"volta": {"node": "18.0.0"}}';
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return contents;
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
      expect(util.getNodeVersionFromFile('file')).toBe(expected);
 | 
			
		||||
    });
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
@ -125,6 +147,10 @@ describe('main tests', () => {
 | 
			
		||||
        return {stdout: obj[command], stderr: '', exitCode: 0};
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
      whichSpy.mockImplementation(cmd => {
 | 
			
		||||
        return `some/${cmd}/path`;
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
      await util.printEnvDetailsAndSetOutput();
 | 
			
		||||
 | 
			
		||||
      expect(setOutputSpy).toHaveBeenCalledWith('node-version', obj['node']);
 | 
			
		||||
@ -141,10 +167,17 @@ describe('main tests', () => {
 | 
			
		||||
 | 
			
		||||
  describe('node-version-file flag', () => {
 | 
			
		||||
    beforeEach(() => {
 | 
			
		||||
      parseNodeVersionSpy = jest.spyOn(util, 'parseNodeVersionFile');
 | 
			
		||||
      delete inputs['node-version'];
 | 
			
		||||
      inputs['node-version-file'] = '.nvmrc';
 | 
			
		||||
 | 
			
		||||
      getNodeVersionFromFileSpy = jest.spyOn(util, 'getNodeVersionFromFile');
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    it('not used if node-version is provided', async () => {
 | 
			
		||||
    afterEach(() => {
 | 
			
		||||
      getNodeVersionFromFileSpy.mockRestore();
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    it('does not read node-version-file if node-version is provided', async () => {
 | 
			
		||||
      // Arrange
 | 
			
		||||
      inputs['node-version'] = '12';
 | 
			
		||||
 | 
			
		||||
@ -152,107 +185,54 @@ describe('main tests', () => {
 | 
			
		||||
      await main.run();
 | 
			
		||||
 | 
			
		||||
      // Assert
 | 
			
		||||
      expect(parseNodeVersionSpy).toHaveBeenCalledTimes(0);
 | 
			
		||||
    }, 10000);
 | 
			
		||||
 | 
			
		||||
    it('not used if node-version-file not provided', async () => {
 | 
			
		||||
      // Act
 | 
			
		||||
      await main.run();
 | 
			
		||||
 | 
			
		||||
      // Assert
 | 
			
		||||
      expect(parseNodeVersionSpy).toHaveBeenCalledTimes(0);
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    it('reads node-version-file if provided', async () => {
 | 
			
		||||
      // Arrange
 | 
			
		||||
      const versionSpec = 'v14';
 | 
			
		||||
      const versionFile = '.nvmrc';
 | 
			
		||||
      const expectedVersionSpec = '14';
 | 
			
		||||
      process.env['GITHUB_WORKSPACE'] = path.join(__dirname, 'data');
 | 
			
		||||
      inputs['node-version-file'] = versionFile;
 | 
			
		||||
 | 
			
		||||
      parseNodeVersionSpy.mockImplementation(() => expectedVersionSpec);
 | 
			
		||||
      existsSpy.mockImplementationOnce(
 | 
			
		||||
        input => input === path.join(__dirname, 'data', versionFile)
 | 
			
		||||
      );
 | 
			
		||||
 | 
			
		||||
      // Act
 | 
			
		||||
      await main.run();
 | 
			
		||||
 | 
			
		||||
      // Assert
 | 
			
		||||
      expect(existsSpy).toHaveBeenCalledTimes(1);
 | 
			
		||||
      expect(existsSpy).toHaveReturnedWith(true);
 | 
			
		||||
      expect(parseNodeVersionSpy).toHaveBeenCalledWith(versionSpec);
 | 
			
		||||
      expect(infoSpy).toHaveBeenCalledWith(
 | 
			
		||||
        `Resolved ${versionFile} as ${expectedVersionSpec}`
 | 
			
		||||
      );
 | 
			
		||||
    }, 10000);
 | 
			
		||||
 | 
			
		||||
    it('reads package.json as node-version-file if provided', async () => {
 | 
			
		||||
      // Arrange
 | 
			
		||||
      const versionSpec = fs.readFileSync(
 | 
			
		||||
        path.join(__dirname, 'data/package.json'),
 | 
			
		||||
        'utf-8'
 | 
			
		||||
      );
 | 
			
		||||
      const versionFile = 'package.json';
 | 
			
		||||
      const expectedVersionSpec = '14';
 | 
			
		||||
      process.env['GITHUB_WORKSPACE'] = path.join(__dirname, 'data');
 | 
			
		||||
      inputs['node-version-file'] = versionFile;
 | 
			
		||||
 | 
			
		||||
      parseNodeVersionSpy.mockImplementation(() => expectedVersionSpec);
 | 
			
		||||
      existsSpy.mockImplementationOnce(
 | 
			
		||||
        input => input === path.join(__dirname, 'data', versionFile)
 | 
			
		||||
      );
 | 
			
		||||
      // Act
 | 
			
		||||
      await main.run();
 | 
			
		||||
 | 
			
		||||
      // Assert
 | 
			
		||||
      expect(existsSpy).toHaveBeenCalledTimes(1);
 | 
			
		||||
      expect(existsSpy).toHaveReturnedWith(true);
 | 
			
		||||
      expect(parseNodeVersionSpy).toHaveBeenCalledWith(versionSpec);
 | 
			
		||||
      expect(infoSpy).toHaveBeenCalledWith(
 | 
			
		||||
        `Resolved ${versionFile} as ${expectedVersionSpec}`
 | 
			
		||||
      );
 | 
			
		||||
    }, 10000);
 | 
			
		||||
 | 
			
		||||
    it('both node-version-file and node-version are provided', async () => {
 | 
			
		||||
      inputs['node-version'] = '12';
 | 
			
		||||
      const versionSpec = 'v14';
 | 
			
		||||
      const versionFile = '.nvmrc';
 | 
			
		||||
      const expectedVersionSpec = '14';
 | 
			
		||||
      process.env['GITHUB_WORKSPACE'] = path.join(__dirname, '..');
 | 
			
		||||
      inputs['node-version-file'] = versionFile;
 | 
			
		||||
 | 
			
		||||
      parseNodeVersionSpy.mockImplementation(() => expectedVersionSpec);
 | 
			
		||||
 | 
			
		||||
      // Act
 | 
			
		||||
      await main.run();
 | 
			
		||||
 | 
			
		||||
      // Assert
 | 
			
		||||
      expect(existsSpy).toHaveBeenCalledTimes(0);
 | 
			
		||||
      expect(parseNodeVersionSpy).not.toHaveBeenCalled();
 | 
			
		||||
      expect(inputs['node-version']).toBeDefined();
 | 
			
		||||
      expect(inputs['node-version-file']).toBeDefined();
 | 
			
		||||
      expect(getNodeVersionFromFileSpy).not.toHaveBeenCalled();
 | 
			
		||||
      expect(warningSpy).toHaveBeenCalledWith(
 | 
			
		||||
        'Both node-version and node-version-file inputs are specified, only node-version will be used'
 | 
			
		||||
      );
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    it('should throw an error if node-version-file is not found', async () => {
 | 
			
		||||
      const versionFile = '.nvmrc';
 | 
			
		||||
      const versionFilePath = path.join(__dirname, '..', versionFile);
 | 
			
		||||
      inputs['node-version-file'] = versionFile;
 | 
			
		||||
    it('does not read node-version-file if node-version-file is not provided', async () => {
 | 
			
		||||
      // Arrange
 | 
			
		||||
      delete inputs['node-version-file'];
 | 
			
		||||
 | 
			
		||||
      inSpy.mockImplementation(name => inputs[name]);
 | 
			
		||||
      existsSpy.mockImplementationOnce(
 | 
			
		||||
        input => input === path.join(__dirname, 'data', versionFile)
 | 
			
		||||
      // Act
 | 
			
		||||
      await main.run();
 | 
			
		||||
 | 
			
		||||
      // Assert
 | 
			
		||||
      expect(getNodeVersionFromFileSpy).not.toHaveBeenCalled();
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    it('reads node-version-file', async () => {
 | 
			
		||||
      // Arrange
 | 
			
		||||
      const expectedVersionSpec = '14';
 | 
			
		||||
      getNodeVersionFromFileSpy.mockImplementation(() => expectedVersionSpec);
 | 
			
		||||
 | 
			
		||||
      // Act
 | 
			
		||||
      await main.run();
 | 
			
		||||
 | 
			
		||||
      // Assert
 | 
			
		||||
      expect(getNodeVersionFromFileSpy).toHaveBeenCalled();
 | 
			
		||||
      expect(infoSpy).toHaveBeenCalledWith(
 | 
			
		||||
        `Resolved ${inputs['node-version-file']} as ${expectedVersionSpec}`
 | 
			
		||||
      );
 | 
			
		||||
    }, 10000);
 | 
			
		||||
 | 
			
		||||
    it('should throw an error if node-version-file is not accessible', async () => {
 | 
			
		||||
      // Arrange
 | 
			
		||||
      inputs['node-version-file'] = 'non-existing-file';
 | 
			
		||||
      const versionFilePath = path.join(
 | 
			
		||||
        __dirname,
 | 
			
		||||
        'data',
 | 
			
		||||
        inputs['node-version-file']
 | 
			
		||||
      );
 | 
			
		||||
 | 
			
		||||
      // Act
 | 
			
		||||
      await main.run();
 | 
			
		||||
 | 
			
		||||
      // Assert
 | 
			
		||||
      expect(existsSpy).toHaveBeenCalled();
 | 
			
		||||
      expect(existsSpy).toHaveReturnedWith(false);
 | 
			
		||||
      expect(parseNodeVersionSpy).not.toHaveBeenCalled();
 | 
			
		||||
      expect(getNodeVersionFromFileSpy).toHaveBeenCalled();
 | 
			
		||||
      expect(cnSpy).toHaveBeenCalledWith(
 | 
			
		||||
        `::error::The specified node version file at: ${versionFilePath} does not exist${osm.EOL}`
 | 
			
		||||
      );
 | 
			
		||||
 | 
			
		||||
@ -248,6 +248,9 @@ describe('setup-node', () => {
 | 
			
		||||
    const toolPath = path.normalize('/cache/node/12.16.2/x64');
 | 
			
		||||
    exSpy.mockImplementation(async () => '/some/other/temp/path');
 | 
			
		||||
    cacheSpy.mockImplementation(async () => toolPath);
 | 
			
		||||
    whichSpy.mockImplementation(cmd => {
 | 
			
		||||
      return `some/${cmd}/path`;
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    await main.run();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -8,7 +8,7 @@ inputs:
 | 
			
		||||
  node-version:
 | 
			
		||||
    description: 'Version Spec of the version to use. Examples: 12.x, 10.15.1, >=10.15.0.'
 | 
			
		||||
  node-version-file:
 | 
			
		||||
    description: 'File containing the version Spec of the version to use.  Examples: .nvmrc, .node-version, .tool-versions.'
 | 
			
		||||
    description: 'File containing the version Spec of the version to use.  Examples: package.json, .nvmrc, .node-version, .tool-versions.'
 | 
			
		||||
  architecture:
 | 
			
		||||
    description: 'Target architecture for Node to use. Examples: x86, x64. Will use system architecture by default.'
 | 
			
		||||
  check-latest:
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										4642
									
								
								dist/cache-save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4642
									
								
								dist/cache-save/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1266
									
								
								dist/setup/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1266
									
								
								dist/setup/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -46,7 +46,7 @@ If `check-latest` is set to `true`, the action first checks if the cached versio
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '16'
 | 
			
		||||
    check-latest: true
 | 
			
		||||
@ -64,7 +64,7 @@ See [supported version syntax](https://github.com/actions/setup-node#supported-v
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version-file: '.nvmrc'
 | 
			
		||||
- run: npm ci
 | 
			
		||||
@ -84,6 +84,8 @@ When using the `package.json` input, the action will look for `volta.node` first
 | 
			
		||||
}
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
Otherwise, when [`volta.extends`](https://docs.volta.sh/advanced/workspaces) is defined, then it will resolve the corresponding file and look for `volta.node` or `engines.node` recursively.
 | 
			
		||||
 | 
			
		||||
## Architecture
 | 
			
		||||
 | 
			
		||||
You can use any of the [supported operating systems](https://docs.github.com/en/actions/using-github-hosted-runners/about-github-hosted-runners), and the compatible `architecture` can be selected using `architecture`. Values are `x86`, `x64`, `arm64`, `armv6l`, `armv7l`, `ppc64le`, `s390x` (not all of the architectures are available on all platforms).
 | 
			
		||||
@ -96,7 +98,7 @@ jobs:
 | 
			
		||||
    name: Node sample
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-node@v3
 | 
			
		||||
      - uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: '14'
 | 
			
		||||
          architecture: 'x64' # optional, x64 or x86. If not specified, x64 will be used by default
 | 
			
		||||
@ -117,7 +119,7 @@ jobs:
 | 
			
		||||
    name: Node sample
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-node@v3
 | 
			
		||||
      - uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: '20.0.0-v8-canary' # it will install the latest v8 canary release for node 20.0.0
 | 
			
		||||
      - run: npm ci
 | 
			
		||||
@ -132,7 +134,7 @@ jobs:
 | 
			
		||||
    name: Node sample
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-node@v3
 | 
			
		||||
      - uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: '20-v8-canary' # it will install the latest v8 canary release for node 20
 | 
			
		||||
      - run: npm ci
 | 
			
		||||
@ -148,7 +150,7 @@ jobs:
 | 
			
		||||
    name: Node sample
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-node@v3
 | 
			
		||||
      - uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: 'v20.1.1-v8-canary20221103f7e2421e91'
 | 
			
		||||
      - run: npm ci
 | 
			
		||||
@ -168,7 +170,7 @@ jobs:
 | 
			
		||||
    name: Node sample
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-node@v3
 | 
			
		||||
      - uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: '16-nightly' # it will install the latest nightly release for node 16
 | 
			
		||||
      - run: npm ci
 | 
			
		||||
@ -184,7 +186,7 @@ jobs:
 | 
			
		||||
    name: Node sample
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-node@v3
 | 
			
		||||
      - uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: '16.0.0-nightly' # it will install the latest nightly release for node 16.0.0
 | 
			
		||||
      - run: npm ci
 | 
			
		||||
@ -200,7 +202,7 @@ jobs:
 | 
			
		||||
    name: Node sample
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-node@v3
 | 
			
		||||
      - uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: '16.0.0-nightly20210420a0261d231c'
 | 
			
		||||
      - run: npm ci
 | 
			
		||||
@ -218,7 +220,7 @@ jobs:
 | 
			
		||||
    name: Node sample
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-node@v3
 | 
			
		||||
      - uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: '16.0.0-rc.1'
 | 
			
		||||
      - run: npm ci
 | 
			
		||||
@ -235,7 +237,7 @@ Yarn caching handles both yarn versions: 1 or 2.
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '14'
 | 
			
		||||
    cache: 'yarn'
 | 
			
		||||
@ -257,7 +259,7 @@ steps:
 | 
			
		||||
- uses: pnpm/action-setup@v2
 | 
			
		||||
  with:
 | 
			
		||||
    version: 6.32.9
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '14'
 | 
			
		||||
    cache: 'pnpm'
 | 
			
		||||
@ -273,7 +275,7 @@ steps:
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '14'
 | 
			
		||||
    cache: 'npm'
 | 
			
		||||
@ -286,7 +288,7 @@ steps:
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '14'
 | 
			
		||||
    cache: 'npm'
 | 
			
		||||
@ -324,7 +326,7 @@ jobs:
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Setup node
 | 
			
		||||
        uses: actions/setup-node@v3
 | 
			
		||||
        uses: actions/setup-node@v4
 | 
			
		||||
        with:
 | 
			
		||||
          node-version: ${{ matrix.node_version }}
 | 
			
		||||
          architecture: ${{ matrix.architecture }}
 | 
			
		||||
@ -336,7 +338,7 @@ jobs:
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '14.x'
 | 
			
		||||
    registry-url: 'https://registry.npmjs.org'
 | 
			
		||||
@ -344,7 +346,7 @@ steps:
 | 
			
		||||
- run: npm publish
 | 
			
		||||
  env:
 | 
			
		||||
    NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    registry-url: 'https://npm.pkg.github.com'
 | 
			
		||||
- run: npm publish
 | 
			
		||||
@ -356,7 +358,7 @@ steps:
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '14.x'
 | 
			
		||||
    registry-url: <registry url>
 | 
			
		||||
@ -364,7 +366,7 @@ steps:
 | 
			
		||||
- run: yarn publish
 | 
			
		||||
  env:
 | 
			
		||||
    NODE_AUTH_TOKEN: ${{ secrets.YARN_TOKEN }}
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    registry-url: 'https://npm.pkg.github.com'
 | 
			
		||||
- run: yarn publish
 | 
			
		||||
@ -376,7 +378,7 @@ steps:
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '14.x'
 | 
			
		||||
    registry-url: 'https://registry.npmjs.org'
 | 
			
		||||
@ -396,7 +398,7 @@ Below you can find a sample "Setup .yarnrc.yml" step, that is going to allow you
 | 
			
		||||
```yaml
 | 
			
		||||
steps:
 | 
			
		||||
- uses: actions/checkout@v4
 | 
			
		||||
- uses: actions/setup-node@v3
 | 
			
		||||
- uses: actions/setup-node@v4
 | 
			
		||||
  with:
 | 
			
		||||
    node-version: '14.x'
 | 
			
		||||
- name: Setup .yarnrc.yml
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										152
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										152
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@ -9,34 +9,34 @@
 | 
			
		||||
      "version": "4.0.0",
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "@actions/cache": "^3.0.4",
 | 
			
		||||
        "@actions/cache": "^3.2.4",
 | 
			
		||||
        "@actions/core": "^1.10.0",
 | 
			
		||||
        "@actions/exec": "^1.1.0",
 | 
			
		||||
        "@actions/github": "^5.1.1",
 | 
			
		||||
        "@actions/glob": "^0.4.0",
 | 
			
		||||
        "@actions/http-client": "^2.1.1",
 | 
			
		||||
        "@actions/http-client": "^2.2.1",
 | 
			
		||||
        "@actions/io": "^1.0.2",
 | 
			
		||||
        "@actions/tool-cache": "^2.0.1",
 | 
			
		||||
        "semver": "^7.5.4",
 | 
			
		||||
        "semver": "^7.6.0",
 | 
			
		||||
        "uuid": "^9.0.1"
 | 
			
		||||
      },
 | 
			
		||||
      "devDependencies": {
 | 
			
		||||
        "@types/jest": "^29.5.5",
 | 
			
		||||
        "@types/node": "^20.8.2",
 | 
			
		||||
        "@types/semver": "^7.5.3",
 | 
			
		||||
        "@types/jest": "^29.5.12",
 | 
			
		||||
        "@types/node": "^20.11.25",
 | 
			
		||||
        "@types/semver": "^7.5.8",
 | 
			
		||||
        "@typescript-eslint/eslint-plugin": "^5.54.0",
 | 
			
		||||
        "@typescript-eslint/parser": "^5.54.0",
 | 
			
		||||
        "@vercel/ncc": "^0.38.0",
 | 
			
		||||
        "eslint": "^8.35.0",
 | 
			
		||||
        "eslint": "^8.57.0",
 | 
			
		||||
        "eslint-config-prettier": "^8.6.0",
 | 
			
		||||
        "eslint-plugin-jest": "^27.2.1",
 | 
			
		||||
        "eslint-plugin-jest": "^27.9.0",
 | 
			
		||||
        "eslint-plugin-node": "^11.1.0",
 | 
			
		||||
        "jest": "^29.7.0",
 | 
			
		||||
        "jest-circus": "^29.7.0",
 | 
			
		||||
        "jest-each": "^29.7.0",
 | 
			
		||||
        "prettier": "^2.8.4",
 | 
			
		||||
        "ts-jest": "^29.1.1",
 | 
			
		||||
        "typescript": "^5.2.2"
 | 
			
		||||
        "ts-jest": "^29.1.2",
 | 
			
		||||
        "typescript": "^5.4.2"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@aashutoshrathi/word-wrap": {
 | 
			
		||||
@ -49,9 +49,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@actions/cache": {
 | 
			
		||||
      "version": "3.2.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-3.2.2.tgz",
 | 
			
		||||
      "integrity": "sha512-6D0Jq5JrLZRQ3VApeQwQkkV20ZZXjXsHNYXd9VjNUdi9E0h93wESpxfMJ2JWLCUCgHNLcfY0v3GjNM+2FdRMlg==",
 | 
			
		||||
      "version": "3.2.4",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-3.2.4.tgz",
 | 
			
		||||
      "integrity": "sha512-RuHnwfcDagtX+37s0ZWy7clbOfnZ7AlDJQ7k/9rzt2W4Gnwde3fa/qjSjVuz4vLcLIpc7fUob27CMrqiWZytYA==",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "@actions/core": "^1.10.0",
 | 
			
		||||
        "@actions/exec": "^1.0.1",
 | 
			
		||||
@ -61,7 +61,7 @@
 | 
			
		||||
        "@azure/abort-controller": "^1.1.0",
 | 
			
		||||
        "@azure/ms-rest-js": "^2.6.0",
 | 
			
		||||
        "@azure/storage-blob": "^12.13.0",
 | 
			
		||||
        "semver": "^6.1.0",
 | 
			
		||||
        "semver": "^6.3.1",
 | 
			
		||||
        "uuid": "^3.3.3"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
@ -137,9 +137,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@actions/http-client": {
 | 
			
		||||
      "version": "2.2.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@actions/http-client/-/http-client-2.2.0.tgz",
 | 
			
		||||
      "integrity": "sha512-q+epW0trjVUUHboliPb4UF9g2msf+w61b32tAkFEwL/IwP0DQWgbCMM0Hbe3e3WXSKz5VcUXbzJQgy8Hkra/Lg==",
 | 
			
		||||
      "version": "2.2.1",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@actions/http-client/-/http-client-2.2.1.tgz",
 | 
			
		||||
      "integrity": "sha512-KhC/cZsq7f8I4LfZSJKgCvEwfkE8o1538VoBeoGzokVLLnbFDEAdFD3UhoMklxo2un9NJVBdANOresx7vTHlHw==",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "tunnel": "^0.0.6",
 | 
			
		||||
        "undici": "^5.25.4"
 | 
			
		||||
@ -1042,9 +1042,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@eslint/eslintrc": {
 | 
			
		||||
      "version": "2.1.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.2.tgz",
 | 
			
		||||
      "integrity": "sha512-+wvgpDsrB1YqAMdEUCcnTlpfVBH7Vqn6A/NT3D8WVXFIaKMlErPIZT3oCIAVCOtarRpMtelZLqJeU3t7WY6X6g==",
 | 
			
		||||
      "version": "2.1.4",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz",
 | 
			
		||||
      "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "ajv": "^6.12.4",
 | 
			
		||||
@ -1065,9 +1065,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@eslint/js": {
 | 
			
		||||
      "version": "8.52.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.52.0.tgz",
 | 
			
		||||
      "integrity": "sha512-mjZVbpaeMZludF2fsWLD0Z9gCref1Tk4i9+wddjRvpUNqqcndPkBD09N/Mapey0b3jaXbLm2kICwFv2E64QinA==",
 | 
			
		||||
      "version": "8.57.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz",
 | 
			
		||||
      "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "engines": {
 | 
			
		||||
        "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
 | 
			
		||||
@ -1082,13 +1082,13 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@humanwhocodes/config-array": {
 | 
			
		||||
      "version": "0.11.13",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.13.tgz",
 | 
			
		||||
      "integrity": "sha512-JSBDMiDKSzQVngfRjOdFXgFfklaXI4K9nLF49Auh21lmBWRLIK3+xTErTWD4KU54pb6coM6ESE7Awz/FNU3zgQ==",
 | 
			
		||||
      "version": "0.11.14",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz",
 | 
			
		||||
      "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "@humanwhocodes/object-schema": "^2.0.1",
 | 
			
		||||
        "debug": "^4.1.1",
 | 
			
		||||
        "@humanwhocodes/object-schema": "^2.0.2",
 | 
			
		||||
        "debug": "^4.3.1",
 | 
			
		||||
        "minimatch": "^3.0.5"
 | 
			
		||||
      },
 | 
			
		||||
      "engines": {
 | 
			
		||||
@ -1109,9 +1109,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@humanwhocodes/object-schema": {
 | 
			
		||||
      "version": "2.0.1",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.1.tgz",
 | 
			
		||||
      "integrity": "sha512-dvuCeX5fC9dXgJn9t+X5atfmgQAzUOWqS1254Gh0m6i8wKd10ebXkfNKiRK+1GWi/yTvvLDHpoxLr0xxxeslWw==",
 | 
			
		||||
      "version": "2.0.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz",
 | 
			
		||||
      "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==",
 | 
			
		||||
      "dev": true
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@istanbuljs/load-nyc-config": {
 | 
			
		||||
@ -1791,9 +1791,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@types/jest": {
 | 
			
		||||
      "version": "29.5.6",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.6.tgz",
 | 
			
		||||
      "integrity": "sha512-/t9NnzkOpXb4Nfvg17ieHE6EeSjDS2SGSpNYfoLbUAeL/EOueU/RSdOWFpfQTXBEM7BguYW1XQ0EbM+6RlIh6w==",
 | 
			
		||||
      "version": "29.5.12",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.12.tgz",
 | 
			
		||||
      "integrity": "sha512-eDC8bTvT/QhYdxJAulQikueigY5AsdBRH2yDKW3yveW7svY3+DzN84/2NUgkw10RTiJbWqZrTtoGVdYlvFJdLw==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "expect": "^29.0.0",
 | 
			
		||||
@ -1807,11 +1807,11 @@
 | 
			
		||||
      "dev": true
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@types/node": {
 | 
			
		||||
      "version": "20.8.7",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@types/node/-/node-20.8.7.tgz",
 | 
			
		||||
      "integrity": "sha512-21TKHHh3eUHIi2MloeptJWALuCu5H7HQTdTrWIFReA8ad+aggoX+lRes3ex7/FtpC+sVUpFMQ+QTfYr74mruiQ==",
 | 
			
		||||
      "version": "20.11.25",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@types/node/-/node-20.11.25.tgz",
 | 
			
		||||
      "integrity": "sha512-TBHyJxk2b7HceLVGFcpAUjsa5zIdsPWlR6XHfyGzd0SFu+/NFgQgMAl96MSDZgQDvJAvV6BKsFOrt6zIL09JDw==",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "undici-types": "~5.25.1"
 | 
			
		||||
        "undici-types": "~5.26.4"
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@types/node-fetch": {
 | 
			
		||||
@ -1837,9 +1837,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@types/semver": {
 | 
			
		||||
      "version": "7.5.4",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.4.tgz",
 | 
			
		||||
      "integrity": "sha512-MMzuxN3GdFwskAnb6fz0orFvhfqi752yjaXylr0Rp4oDg5H0Zn1IuyRhDVvYOwAXoJirx2xuS16I3WjxnAIHiQ==",
 | 
			
		||||
      "version": "7.5.8",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.8.tgz",
 | 
			
		||||
      "integrity": "sha512-I8EUhyrgfLrcTkzV3TSsGyl1tSuPrEDzr0yd5m90UgNxQkyDXULk3b6MlQqTCpZpNtWe1K0hzclnZkTcLBe2UQ==",
 | 
			
		||||
      "dev": true
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@types/stack-utils": {
 | 
			
		||||
@ -2086,9 +2086,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/acorn": {
 | 
			
		||||
      "version": "8.10.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz",
 | 
			
		||||
      "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==",
 | 
			
		||||
      "version": "8.11.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz",
 | 
			
		||||
      "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "bin": {
 | 
			
		||||
        "acorn": "bin/acorn"
 | 
			
		||||
@ -2757,16 +2757,16 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/eslint": {
 | 
			
		||||
      "version": "8.52.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.52.0.tgz",
 | 
			
		||||
      "integrity": "sha512-zh/JHnaixqHZsolRB/w9/02akBk9EPrOs9JwcTP2ek7yL5bVvXuRariiaAjjoJ5DvuwQ1WAE/HsMz+w17YgBCg==",
 | 
			
		||||
      "version": "8.57.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz",
 | 
			
		||||
      "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "@eslint-community/eslint-utils": "^4.2.0",
 | 
			
		||||
        "@eslint-community/regexpp": "^4.6.1",
 | 
			
		||||
        "@eslint/eslintrc": "^2.1.2",
 | 
			
		||||
        "@eslint/js": "8.52.0",
 | 
			
		||||
        "@humanwhocodes/config-array": "^0.11.13",
 | 
			
		||||
        "@eslint/eslintrc": "^2.1.4",
 | 
			
		||||
        "@eslint/js": "8.57.0",
 | 
			
		||||
        "@humanwhocodes/config-array": "^0.11.14",
 | 
			
		||||
        "@humanwhocodes/module-importer": "^1.0.1",
 | 
			
		||||
        "@nodelib/fs.walk": "^1.2.8",
 | 
			
		||||
        "@ungap/structured-clone": "^1.2.0",
 | 
			
		||||
@ -2843,9 +2843,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/eslint-plugin-jest": {
 | 
			
		||||
      "version": "27.4.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-27.4.3.tgz",
 | 
			
		||||
      "integrity": "sha512-7S6SmmsHsgIm06BAGCAxL+ABd9/IB3MWkz2pudj6Qqor2y1qQpWPfuFU4SG9pWj4xDjF0e+D7Llh5useuSzAZw==",
 | 
			
		||||
      "version": "27.9.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-27.9.0.tgz",
 | 
			
		||||
      "integrity": "sha512-QIT7FH7fNmd9n4se7FFKHbsLKGQiw885Ds6Y/sxKgCZ6natwCsXdgPOADnYVxN2QrRweF0FZWbJ6S7Rsn7llug==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "@typescript-eslint/utils": "^5.10.0"
 | 
			
		||||
@ -2854,7 +2854,7 @@
 | 
			
		||||
        "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
 | 
			
		||||
      },
 | 
			
		||||
      "peerDependencies": {
 | 
			
		||||
        "@typescript-eslint/eslint-plugin": "^5.0.0 || ^6.0.0",
 | 
			
		||||
        "@typescript-eslint/eslint-plugin": "^5.0.0 || ^6.0.0 || ^7.0.0",
 | 
			
		||||
        "eslint": "^7.0.0 || ^8.0.0",
 | 
			
		||||
        "jest": "*"
 | 
			
		||||
      },
 | 
			
		||||
@ -3362,9 +3362,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/globals": {
 | 
			
		||||
      "version": "13.23.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/globals/-/globals-13.23.0.tgz",
 | 
			
		||||
      "integrity": "sha512-XAmF0RjlrjY23MA51q3HltdlGxUpXPvg0GioKiD9X6HD28iMjo2dKC8Vqwm7lne4GNr78+RHTfliktR6ZH09wA==",
 | 
			
		||||
      "version": "13.24.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz",
 | 
			
		||||
      "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "type-fest": "^0.20.2"
 | 
			
		||||
@ -4864,9 +4864,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/punycode": {
 | 
			
		||||
      "version": "2.3.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz",
 | 
			
		||||
      "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==",
 | 
			
		||||
      "version": "2.3.1",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
 | 
			
		||||
      "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "engines": {
 | 
			
		||||
        "node": ">=6"
 | 
			
		||||
@ -5045,9 +5045,9 @@
 | 
			
		||||
      "integrity": "sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA=="
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/semver": {
 | 
			
		||||
      "version": "7.5.4",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz",
 | 
			
		||||
      "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==",
 | 
			
		||||
      "version": "7.6.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz",
 | 
			
		||||
      "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "lru-cache": "^6.0.0"
 | 
			
		||||
      },
 | 
			
		||||
@ -5308,9 +5308,9 @@
 | 
			
		||||
      "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw=="
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/ts-jest": {
 | 
			
		||||
      "version": "29.1.1",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.1.1.tgz",
 | 
			
		||||
      "integrity": "sha512-D6xjnnbP17cC85nliwGiL+tpoKN0StpgE0TeOjXQTU6MVCfsB4v7aW05CgQ/1OywGb0x/oy9hHFnN+sczTiRaA==",
 | 
			
		||||
      "version": "29.1.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.1.2.tgz",
 | 
			
		||||
      "integrity": "sha512-br6GJoH/WUX4pu7FbZXuWGKGNDuU7b8Uj77g/Sp7puZV6EXzuByl6JrECvm0MzVzSTkSHWTihsXt+5XYER5b+g==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "bs-logger": "0.x",
 | 
			
		||||
@ -5326,7 +5326,7 @@
 | 
			
		||||
        "ts-jest": "cli.js"
 | 
			
		||||
      },
 | 
			
		||||
      "engines": {
 | 
			
		||||
        "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
 | 
			
		||||
        "node": "^16.10.0 || ^18.0.0 || >=20.0.0"
 | 
			
		||||
      },
 | 
			
		||||
      "peerDependencies": {
 | 
			
		||||
        "@babel/core": ">=7.0.0-beta.0 <8",
 | 
			
		||||
@ -5418,9 +5418,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/typescript": {
 | 
			
		||||
      "version": "5.2.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.2.2.tgz",
 | 
			
		||||
      "integrity": "sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w==",
 | 
			
		||||
      "version": "5.4.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.2.tgz",
 | 
			
		||||
      "integrity": "sha512-+2/g0Fds1ERlP6JsakQQDXjZdZMM+rqpamFZJEKh4kwTIn3iDkgKtby0CeNd5ATNZ4Ry1ax15TMx0W2V+miizQ==",
 | 
			
		||||
      "dev": true,
 | 
			
		||||
      "bin": {
 | 
			
		||||
        "tsc": "bin/tsc",
 | 
			
		||||
@ -5431,9 +5431,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/undici": {
 | 
			
		||||
      "version": "5.26.5",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/undici/-/undici-5.26.5.tgz",
 | 
			
		||||
      "integrity": "sha512-cSb4bPFd5qgR7qr2jYAi0hlX9n5YKK2ONKkLFkxl+v/9BvC0sOpZjBHDBSXc5lWAf5ty9oZdRXytBIHzgUcerw==",
 | 
			
		||||
      "version": "5.28.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/undici/-/undici-5.28.3.tgz",
 | 
			
		||||
      "integrity": "sha512-3ItfzbrhDlINjaP0duwnNsKpDQk3acHI3gVJ1z4fmwMK31k5G9OVIAMLSIaP6w4FaGkaAkN6zaQO9LUvZ1t7VA==",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "@fastify/busboy": "^2.0.0"
 | 
			
		||||
      },
 | 
			
		||||
@ -5442,9 +5442,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/undici-types": {
 | 
			
		||||
      "version": "5.25.3",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.25.3.tgz",
 | 
			
		||||
      "integrity": "sha512-Ga1jfYwRn7+cP9v8auvEXN1rX3sWqlayd4HP7OKk4mZWylEmu3KzXDUGrQUN6Ol7qo1gPvB2e5gX6udnyEPgdA=="
 | 
			
		||||
      "version": "5.26.5",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz",
 | 
			
		||||
      "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA=="
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/universal-user-agent": {
 | 
			
		||||
      "version": "6.0.0",
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										20
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								package.json
									
									
									
									
									
								
							@ -25,33 +25,33 @@
 | 
			
		||||
  "author": "GitHub",
 | 
			
		||||
  "license": "MIT",
 | 
			
		||||
  "dependencies": {
 | 
			
		||||
    "@actions/cache": "^3.0.4",
 | 
			
		||||
    "@actions/cache": "^3.2.4",
 | 
			
		||||
    "@actions/core": "^1.10.0",
 | 
			
		||||
    "@actions/exec": "^1.1.0",
 | 
			
		||||
    "@actions/github": "^5.1.1",
 | 
			
		||||
    "@actions/glob": "^0.4.0",
 | 
			
		||||
    "@actions/http-client": "^2.1.1",
 | 
			
		||||
    "@actions/http-client": "^2.2.1",
 | 
			
		||||
    "@actions/io": "^1.0.2",
 | 
			
		||||
    "@actions/tool-cache": "^2.0.1",
 | 
			
		||||
    "semver": "^7.5.4",
 | 
			
		||||
    "semver": "^7.6.0",
 | 
			
		||||
    "uuid": "^9.0.1"
 | 
			
		||||
  },
 | 
			
		||||
  "devDependencies": {
 | 
			
		||||
    "@types/jest": "^29.5.5",
 | 
			
		||||
    "@types/node": "^20.8.2",
 | 
			
		||||
    "@types/semver": "^7.5.3",
 | 
			
		||||
    "@types/jest": "^29.5.12",
 | 
			
		||||
    "@types/node": "^20.11.25",
 | 
			
		||||
    "@types/semver": "^7.5.8",
 | 
			
		||||
    "@typescript-eslint/eslint-plugin": "^5.54.0",
 | 
			
		||||
    "@typescript-eslint/parser": "^5.54.0",
 | 
			
		||||
    "@vercel/ncc": "^0.38.0",
 | 
			
		||||
    "eslint": "^8.35.0",
 | 
			
		||||
    "eslint": "^8.57.0",
 | 
			
		||||
    "eslint-config-prettier": "^8.6.0",
 | 
			
		||||
    "eslint-plugin-jest": "^27.2.1",
 | 
			
		||||
    "eslint-plugin-jest": "^27.9.0",
 | 
			
		||||
    "eslint-plugin-node": "^11.1.0",
 | 
			
		||||
    "jest": "^29.7.0",
 | 
			
		||||
    "jest-circus": "^29.7.0",
 | 
			
		||||
    "jest-each": "^29.7.0",
 | 
			
		||||
    "prettier": "^2.8.4",
 | 
			
		||||
    "ts-jest": "^29.1.1",
 | 
			
		||||
    "typescript": "^5.2.2"
 | 
			
		||||
    "ts-jest": "^29.1.2",
 | 
			
		||||
    "typescript": "^5.4.2"
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -12,10 +12,20 @@ process.on('uncaughtException', e => {
 | 
			
		||||
  core.info(`${warningPrefix}${e.message}`);
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
export async function run() {
 | 
			
		||||
// Added early exit to resolve issue with slow post action step:
 | 
			
		||||
export async function run(earlyExit?: boolean) {
 | 
			
		||||
  try {
 | 
			
		||||
    const cacheLock = core.getState(State.CachePackageManager);
 | 
			
		||||
    await cachePackages(cacheLock);
 | 
			
		||||
 | 
			
		||||
    if (cacheLock) {
 | 
			
		||||
      await cachePackages(cacheLock);
 | 
			
		||||
 | 
			
		||||
      if (earlyExit) {
 | 
			
		||||
        process.exit(0);
 | 
			
		||||
      }
 | 
			
		||||
    } else {
 | 
			
		||||
      core.debug(`Caching for '${cacheLock}' is not supported`);
 | 
			
		||||
    }
 | 
			
		||||
  } catch (error) {
 | 
			
		||||
    core.setFailed((error as Error).message);
 | 
			
		||||
  }
 | 
			
		||||
@ -58,4 +68,4 @@ const cachePackages = async (packageManager: string) => {
 | 
			
		||||
  core.info(`Cache saved with the key: ${primaryKey}`);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
run();
 | 
			
		||||
run(true);
 | 
			
		||||
 | 
			
		||||
@ -112,7 +112,11 @@ export default abstract class BaseDistribution {
 | 
			
		||||
        ? `node-v${version}-win-${osArch}`
 | 
			
		||||
        : `node-v${version}-${this.osPlat}-${osArch}`;
 | 
			
		||||
    const urlFileName: string =
 | 
			
		||||
      this.osPlat == 'win32' ? `${fileName}.7z` : `${fileName}.tar.gz`;
 | 
			
		||||
      this.osPlat == 'win32'
 | 
			
		||||
        ? this.nodeInfo.arch === 'arm64'
 | 
			
		||||
          ? `${fileName}.zip`
 | 
			
		||||
          : `${fileName}.7z`
 | 
			
		||||
        : `${fileName}.tar.gz`;
 | 
			
		||||
    const initialUrl = this.getDistributionUrl();
 | 
			
		||||
    const url = `${initialUrl}/v${version}/${urlFileName}`;
 | 
			
		||||
 | 
			
		||||
@ -215,12 +219,24 @@ export default abstract class BaseDistribution {
 | 
			
		||||
    let extPath: string;
 | 
			
		||||
    info = info || ({} as INodeVersionInfo); // satisfy compiler, never null when reaches here
 | 
			
		||||
    if (this.osPlat == 'win32') {
 | 
			
		||||
      const _7zPath = path.join(__dirname, '../..', 'externals', '7zr.exe');
 | 
			
		||||
      extPath = await tc.extract7z(downloadPath, undefined, _7zPath);
 | 
			
		||||
      const extension = this.nodeInfo.arch === 'arm64' ? '.zip' : '.7z';
 | 
			
		||||
      // Rename archive to add extension because after downloading
 | 
			
		||||
      // archive does not contain extension type and it leads to some issues
 | 
			
		||||
      // on Windows runners without PowerShell Core.
 | 
			
		||||
      //
 | 
			
		||||
      // For default PowerShell Windows it should contain extension type to unpack it.
 | 
			
		||||
      if (extension === '.zip') {
 | 
			
		||||
        const renamedArchive = `${downloadPath}.zip`;
 | 
			
		||||
        fs.renameSync(downloadPath, renamedArchive);
 | 
			
		||||
        extPath = await tc.extractZip(renamedArchive);
 | 
			
		||||
      } else {
 | 
			
		||||
        const _7zPath = path.join(__dirname, '../..', 'externals', '7zr.exe');
 | 
			
		||||
        extPath = await tc.extract7z(downloadPath, undefined, _7zPath);
 | 
			
		||||
      }
 | 
			
		||||
      // 7z extracts to folder matching file name
 | 
			
		||||
      const nestedPath = path.join(
 | 
			
		||||
        extPath,
 | 
			
		||||
        path.basename(info.fileName, '.7z')
 | 
			
		||||
        path.basename(info.fileName, extension)
 | 
			
		||||
      );
 | 
			
		||||
      if (fs.existsSync(nestedPath)) {
 | 
			
		||||
        extPath = nestedPath;
 | 
			
		||||
@ -260,7 +276,11 @@ export default abstract class BaseDistribution {
 | 
			
		||||
        dataFileName = `osx-${osArch}-tar`;
 | 
			
		||||
        break;
 | 
			
		||||
      case 'win32':
 | 
			
		||||
        dataFileName = `win-${osArch}-exe`;
 | 
			
		||||
        if (this.nodeInfo.arch === 'arm64') {
 | 
			
		||||
          dataFileName = `win-${osArch}-zip`;
 | 
			
		||||
        } else {
 | 
			
		||||
          dataFileName = `win-${osArch}-exe`;
 | 
			
		||||
        }
 | 
			
		||||
        break;
 | 
			
		||||
      default:
 | 
			
		||||
        throw new Error(`Unexpected OS '${this.osPlat}'`);
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										15
									
								
								src/main.ts
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								src/main.ts
									
									
									
									
									
								
							@ -1,6 +1,5 @@
 | 
			
		||||
import * as core from '@actions/core';
 | 
			
		||||
 | 
			
		||||
import fs from 'fs';
 | 
			
		||||
import os from 'os';
 | 
			
		||||
 | 
			
		||||
import * as auth from './authutil';
 | 
			
		||||
@ -8,7 +7,7 @@ import * as path from 'path';
 | 
			
		||||
import {restoreCache} from './cache-restore';
 | 
			
		||||
import {isCacheFeatureAvailable} from './cache-utils';
 | 
			
		||||
import {getNodejsDistribution} from './distributions/installer-factory';
 | 
			
		||||
import {parseNodeVersionFile, printEnvDetailsAndSetOutput} from './util';
 | 
			
		||||
import {getNodeVersionFromFile, printEnvDetailsAndSetOutput} from './util';
 | 
			
		||||
import {State} from './constants';
 | 
			
		||||
 | 
			
		||||
export async function run() {
 | 
			
		||||
@ -99,14 +98,16 @@ function resolveVersionInput(): string {
 | 
			
		||||
      versionFileInput
 | 
			
		||||
    );
 | 
			
		||||
 | 
			
		||||
    if (!fs.existsSync(versionFilePath)) {
 | 
			
		||||
      throw new Error(
 | 
			
		||||
        `The specified node version file at: ${versionFilePath} does not exist`
 | 
			
		||||
    const parsedVersion = getNodeVersionFromFile(versionFilePath);
 | 
			
		||||
 | 
			
		||||
    if (parsedVersion) {
 | 
			
		||||
      version = parsedVersion;
 | 
			
		||||
    } else {
 | 
			
		||||
      core.warning(
 | 
			
		||||
        `Could not determine node version from ${versionFilePath}. Falling back`
 | 
			
		||||
      );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    version = parseNodeVersionFile(fs.readFileSync(versionFilePath, 'utf8'));
 | 
			
		||||
 | 
			
		||||
    core.info(`Resolved ${versionFileInput} as ${version}`);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										68
									
								
								src/util.ts
									
									
									
									
									
								
							
							
						
						
									
										68
									
								
								src/util.ts
									
									
									
									
									
								
							@ -1,34 +1,70 @@
 | 
			
		||||
import * as core from '@actions/core';
 | 
			
		||||
import * as exec from '@actions/exec';
 | 
			
		||||
import * as io from '@actions/io';
 | 
			
		||||
 | 
			
		||||
export function parseNodeVersionFile(contents: string): string {
 | 
			
		||||
  let nodeVersion: string | undefined;
 | 
			
		||||
import fs from 'fs';
 | 
			
		||||
import path from 'path';
 | 
			
		||||
 | 
			
		||||
export function getNodeVersionFromFile(versionFilePath: string): string | null {
 | 
			
		||||
  if (!fs.existsSync(versionFilePath)) {
 | 
			
		||||
    throw new Error(
 | 
			
		||||
      `The specified node version file at: ${versionFilePath} does not exist`
 | 
			
		||||
    );
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  const contents = fs.readFileSync(versionFilePath, 'utf8');
 | 
			
		||||
 | 
			
		||||
  // Try parsing the file as an NPM `package.json` file.
 | 
			
		||||
  try {
 | 
			
		||||
    nodeVersion = JSON.parse(contents).volta?.node;
 | 
			
		||||
    if (!nodeVersion) nodeVersion = JSON.parse(contents).engines?.node;
 | 
			
		||||
    const manifest = JSON.parse(contents);
 | 
			
		||||
 | 
			
		||||
    // Presume package.json file.
 | 
			
		||||
    if (typeof manifest === 'object' && !!manifest) {
 | 
			
		||||
      // Support Volta.
 | 
			
		||||
      // See https://docs.volta.sh/guide/understanding#managing-your-project
 | 
			
		||||
      if (manifest.volta?.node) {
 | 
			
		||||
        return manifest.volta.node;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      if (manifest.engines?.node) {
 | 
			
		||||
        return manifest.engines.node;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // Support Volta workspaces.
 | 
			
		||||
      // See https://docs.volta.sh/advanced/workspaces
 | 
			
		||||
      if (manifest.volta?.extends) {
 | 
			
		||||
        const extendedFilePath = path.resolve(
 | 
			
		||||
          path.dirname(versionFilePath),
 | 
			
		||||
          manifest.volta.extends
 | 
			
		||||
        );
 | 
			
		||||
        core.info('Resolving node version from ' + extendedFilePath);
 | 
			
		||||
        return getNodeVersionFromFile(extendedFilePath);
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // If contents are an object, we parsed JSON
 | 
			
		||||
      // this can happen if node-version-file is a package.json
 | 
			
		||||
      // yet contains no volta.node or engines.node
 | 
			
		||||
      //
 | 
			
		||||
      // If node-version file is _not_ JSON, control flow
 | 
			
		||||
      // will not have reached these lines.
 | 
			
		||||
      //
 | 
			
		||||
      // And because we've reached here, we know the contents
 | 
			
		||||
      // *are* JSON, so no further string parsing makes sense.
 | 
			
		||||
      return null;
 | 
			
		||||
    }
 | 
			
		||||
  } catch {
 | 
			
		||||
    core.info('Node version file is not JSON file');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (!nodeVersion) {
 | 
			
		||||
    const found = contents.match(/^(?:node(js)?\s+)?v?(?<version>[^\s]+)$/m);
 | 
			
		||||
    nodeVersion = found?.groups?.version;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // In the case of an unknown format,
 | 
			
		||||
  // return as is and evaluate the version separately.
 | 
			
		||||
  if (!nodeVersion) nodeVersion = contents.trim();
 | 
			
		||||
 | 
			
		||||
  return nodeVersion as string;
 | 
			
		||||
  const found = contents.match(/^(?:node(js)?\s+)?v?(?<version>[^\s]+)$/m);
 | 
			
		||||
  return found?.groups?.version ?? contents.trim();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export async function printEnvDetailsAndSetOutput() {
 | 
			
		||||
  core.startGroup('Environment details');
 | 
			
		||||
 | 
			
		||||
  const promises = ['node', 'npm', 'yarn'].map(async tool => {
 | 
			
		||||
    const output = await getToolVersion(tool, ['--version']);
 | 
			
		||||
    const pathTool = await io.which(tool, false);
 | 
			
		||||
    const output = pathTool ? await getToolVersion(tool, ['--version']) : '';
 | 
			
		||||
 | 
			
		||||
    return {tool, output};
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user