mirror of
				https://gitea.com/actions/setup-node.git
				synced 2025-10-31 07:47:14 +00:00 
			
		
		
		
	Compare commits
	
		
			16 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 39370e3970 | ||
|   | abb238b131 | ||
|   | aca7b64a59 | ||
|   | 88de2a3d99 | ||
|   | 0a44ba7841 | ||
|   | d6ebc7b438 | ||
|   | 97ca147735 | ||
|   | aa363ded8f | ||
|   | 1c7b2db920 | ||
|   | 26961cf329 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1e60f620b9 | ||
|   | eff380dfbc | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c2ac33f2c6 | ||
|   | 25b062c917 | ||
|   | 60edb5dd54 | ||
|   | d86ebcd40b | 
							
								
								
									
										16
									
								
								.github/workflows/e2e-cache.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/e2e-cache.yml
									
									
									
									
										vendored
									
									
								
							| @@ -19,7 +19,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|         node-version: [12, 14, 16] |         node-version: [18, 20, 22] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Clean global cache |       - name: Clean global cache | ||||||
| @@ -42,7 +42,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|         node-version: [12, 14, 16] |         node-version: [18, 20, 22] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Install pnpm |       - name: Install pnpm | ||||||
| @@ -75,7 +75,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|         node-version: [14, 16] |         node-version: [18, 20] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Yarn version |       - name: Yarn version | ||||||
| @@ -107,7 +107,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|         node-version: [12, 14, 16] |         node-version: [18, 20, 22] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Update yarn |       - name: Update yarn | ||||||
| @@ -139,7 +139,7 @@ jobs: | |||||||
|     name: Test yarn subprojects |     name: Test yarn subprojects | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         node-version: [12, 14, 16] |         node-version: [18, 20, 22] | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
| @@ -166,7 +166,7 @@ jobs: | |||||||
|     name: Test yarn subprojects all locally managed |     name: Test yarn subprojects all locally managed | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         node-version: [12, 14, 16] |         node-version: [18, 20, 22] | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
| @@ -193,7 +193,7 @@ jobs: | |||||||
|     name: Test yarn subprojects some locally managed |     name: Test yarn subprojects some locally managed | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         node-version: [12, 14, 16] |         node-version: [18, 20, 22] | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
| @@ -220,7 +220,7 @@ jobs: | |||||||
|     name: Test yarn subprojects managed by git |     name: Test yarn subprojects managed by git | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         node-version: [12, 14, 16] |         node-version: [18, 20, 22] | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								.github/workflows/publish-immutable-actions.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/publish-immutable-actions.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | name: 'Publish Immutable Action Version' | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   release: | ||||||
|  |     types: [published] | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   publish: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       contents: read | ||||||
|  |       id-token: write | ||||||
|  |       packages: write | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |       - name: Checking out | ||||||
|  |         uses: actions/checkout@v4 | ||||||
|  |       - name: Publish | ||||||
|  |         id: publish | ||||||
|  |         uses: actions/publish-immutable-action@0.0.3 | ||||||
							
								
								
									
										46
									
								
								.github/workflows/versions.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										46
									
								
								.github/workflows/versions.yml
									
									
									
									
										vendored
									
									
								
							| @@ -18,7 +18,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|         node-version: [10, 12, 14] |         node-version: [18, 20, 22] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Setup Node |       - name: Setup Node | ||||||
| @@ -34,7 +34,7 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       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] |         node-version: [lts/dubnium, lts/erbium, lts/fermium, lts/*, lts/-1] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| @@ -43,7 +43,7 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           node-version: ${{ matrix.node-version }} |           node-version: ${{ matrix.node-version }} | ||||||
|           check-latest: true |           check-latest: true | ||||||
|       - if: runner.os != 'Windows' |       - if: runner.os != 'Windows' && runner.os != 'macOS' | ||||||
|         name: Verify node and npm |         name: Verify node and npm | ||||||
|         run: | |         run: | | ||||||
|           . "$NVM_DIR/nvm.sh" |           . "$NVM_DIR/nvm.sh" | ||||||
| @@ -83,7 +83,7 @@ jobs: | |||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|         node-version: |         node-version: | ||||||
|           [16.0.0-nightly20210420a0261d231c, 17-nightly, 18.0.0-nightly] |           [20.11.0-nightly202312211a0be537da, 21-nightly, 18.0.0-nightly] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Setup Node |       - name: Setup Node | ||||||
| @@ -103,7 +103,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         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: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Setup Node |       - name: Setup Node | ||||||
| @@ -123,7 +123,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         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: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Setup Node |       - name: Setup Node | ||||||
| @@ -140,7 +140,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|         node-version: [10, 12, 14] |         node-version: [18, 20, 22] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Setup Node and check latest |       - name: Setup Node and check latest | ||||||
| @@ -162,15 +162,12 @@ jobs: | |||||||
|           [.nvmrc, .tool-versions, .tool-versions-node, package.json] |           [.nvmrc, .tool-versions, .tool-versions-node, package.json] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - 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 |       - name: Setup node from node version file | ||||||
|         uses: ./ |         uses: ./ | ||||||
|         with: |         with: | ||||||
|           node-version-file: '__tests__/data/${{ matrix.node-version-file }}' |           node-version-file: '__tests__/data/${{ matrix.node-version-file }}' | ||||||
|       - name: Verify node |       - name: Verify node | ||||||
|         run: __tests__/verify-node.sh 14 |         run: __tests__/verify-node.sh 20 | ||||||
|  |  | ||||||
|   version-file-volta: |   version-file-volta: | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
| @@ -183,9 +180,24 @@ jobs: | |||||||
|       - name: Setup node from node version file |       - name: Setup node from node version file | ||||||
|         uses: ./ |         uses: ./ | ||||||
|         with: |         with: | ||||||
|           node-version-file: '__tests__/data/package.json' |           node-version-file: '__tests__/data/package-volta.json' | ||||||
|       - name: Verify node |       - 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: |   node-dist: | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
| @@ -193,7 +205,7 @@ jobs: | |||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|         node-version: [11, 13] |         node-version: [17, 19] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Setup Node from dist |       - name: Setup Node from dist | ||||||
| @@ -209,7 +221,7 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-latest] |         os: [ubuntu-latest, windows-latest, macos-13] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       # test old versions which didn't have npm and layout different |       # test old versions which didn't have npm and layout different | ||||||
| @@ -225,10 +237,10 @@ jobs: | |||||||
|     runs-on: windows-latest |     runs-on: windows-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - name: Setup node 14 x86 from dist |       - name: Setup node 20 x86 from dist | ||||||
|         uses: ./ |         uses: ./ | ||||||
|         with: |         with: | ||||||
|           node-version: '14' |           node-version: '20' | ||||||
|           architecture: 'x86' |           architecture: 'x86' | ||||||
|       - name: Verify node |       - name: Verify node | ||||||
|         run: __tests__/verify-arch.sh "ia32" |         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" | name: "@actions/cache" | ||||||
| version: 3.2.2 | version: 3.2.4 | ||||||
| type: npm | type: npm | ||||||
| summary: Actions cache lib | summary: Actions cache lib | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/cache | 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" | name: "@actions/http-client" | ||||||
| version: 2.2.0 | version: 2.2.1 | ||||||
| type: npm | type: npm | ||||||
| summary: Actions Http Client | summary: Actions Http Client | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/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" | name: "@types/node" | ||||||
| version: 20.8.7 | version: 20.11.25 | ||||||
| type: npm | type: npm | ||||||
| summary: TypeScript definitions for node | summary: TypeScript definitions for node | ||||||
| homepage: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node | homepage: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
| name: semver | name: semver | ||||||
| version: 7.5.4 | version: 7.6.0 | ||||||
| type: npm | type: npm | ||||||
| summary: The semantic version parser used by npm. | summary: The semantic version parser used by npm. | ||||||
| homepage: | homepage: | ||||||
							
								
								
									
										2
									
								
								.licenses/npm/undici-types.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/undici-types.dep.yml
									
									
									
										generated
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
| name: undici-types | name: undici-types | ||||||
| version: 5.25.3 | version: 5.26.5 | ||||||
| type: npm | type: npm | ||||||
| summary: A stand-alone types package for Undici | summary: A stand-alone types package for Undici | ||||||
| homepage: https://undici.nodejs.org | 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 | name: undici | ||||||
| version: 5.26.5 | version: 5.28.4 | ||||||
| type: npm | type: npm | ||||||
| summary: An HTTP/1.1 client, written from scratch for Node.js | summary: An HTTP/1.1 client, written from scratch for Node.js | ||||||
| homepage: https://undici.nodejs.org | homepage: https://undici.nodejs.org | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								README.md
									
									
									
									
									
								
							| @@ -21,7 +21,7 @@ See [action.yml](action.yml) | |||||||
| - uses: actions/setup-node@v4 | - uses: actions/setup-node@v4 | ||||||
|   with: |   with: | ||||||
|     # Version Spec of the version to use in SemVer notation. |     # Version Spec of the version to use in SemVer notation. | ||||||
|     # It also emits such aliases as lts, latest, nightly and canary builds |     # It also admits such aliases as lts/*, latest, nightly and canary builds | ||||||
|     # Examples: 12.x, 10.15.1, >=10.15.0, lts/Hydrogen, 16-nightly, latest, node |     # Examples: 12.x, 10.15.1, >=10.15.0, lts/Hydrogen, 16-nightly, latest, node | ||||||
|     node-version: '' |     node-version: '' | ||||||
|  |  | ||||||
| @@ -103,7 +103,7 @@ The `node-version` input supports the Semantic Versioning Specification, for mor | |||||||
|  |  | ||||||
| Examples: | Examples: | ||||||
|  |  | ||||||
|  - Major versions: `16`, `18`, `20` |  - Major versions: `18`, `20` | ||||||
|  - More specific versions: `10.15`, `16.15.1` , `18.4.0` |  - More specific versions: `10.15`, `16.15.1` , `18.4.0` | ||||||
|  - NVM LTS syntax: `lts/erbium`, `lts/fermium`, `lts/*`, `lts/-n` |  - NVM LTS syntax: `lts/erbium`, `lts/fermium`, `lts/*`, `lts/-n` | ||||||
|  - Latest release: `*` or `latest`/`current`/`node` |  - Latest release: `*` or `latest`/`current`/`node` | ||||||
| @@ -135,7 +135,7 @@ steps: | |||||||
| - uses: actions/checkout@v4 | - uses: actions/checkout@v4 | ||||||
| - uses: actions/setup-node@v4 | - uses: actions/setup-node@v4 | ||||||
|   with: |   with: | ||||||
|     node-version: 16 |     node-version: 20 | ||||||
|     cache: 'npm' |     cache: 'npm' | ||||||
| - run: npm ci | - run: npm ci | ||||||
| - run: npm test | - run: npm test | ||||||
| @@ -148,7 +148,7 @@ steps: | |||||||
| - uses: actions/checkout@v4 | - uses: actions/checkout@v4 | ||||||
| - uses: actions/setup-node@v4 | - uses: actions/setup-node@v4 | ||||||
|   with: |   with: | ||||||
|     node-version: 16 |     node-version: 20 | ||||||
|     cache: 'npm' |     cache: 'npm' | ||||||
|     cache-dependency-path: subdir/package-lock.json |     cache-dependency-path: subdir/package-lock.json | ||||||
| - run: npm ci | - run: npm ci | ||||||
| @@ -185,7 +185,7 @@ To get a higher rate limit, you can [generate a personal access token on github. | |||||||
| uses: actions/setup-node@v4 | uses: actions/setup-node@v4 | ||||||
| with: | with: | ||||||
|   token: ${{ secrets.GH_DOTCOM_TOKEN }} |   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. | 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. | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ import * as core from '@actions/core'; | |||||||
| import * as cache from '@actions/cache'; | import * as cache from '@actions/cache'; | ||||||
| import * as path from 'path'; | import * as path from 'path'; | ||||||
| import * as glob from '@actions/glob'; | import * as glob from '@actions/glob'; | ||||||
|  | import osm from 'os'; | ||||||
|  |  | ||||||
| import * as utils from '../src/cache-utils'; | import * as utils from '../src/cache-utils'; | ||||||
| import {restoreCache} from '../src/cache-restore'; | import {restoreCache} from '../src/cache-restore'; | ||||||
| @@ -12,6 +13,7 @@ describe('cache-restore', () => { | |||||||
|     process.env.RUNNER_OS = 'Linux'; |     process.env.RUNNER_OS = 'Linux'; | ||||||
|   } |   } | ||||||
|   const platform = process.env.RUNNER_OS; |   const platform = process.env.RUNNER_OS; | ||||||
|  |   const arch = 'arm64'; | ||||||
|   const commonPath = '/some/random/path'; |   const commonPath = '/some/random/path'; | ||||||
|   const npmCachePath = `${commonPath}/npm`; |   const npmCachePath = `${commonPath}/npm`; | ||||||
|   const pnpmCachePath = `${commonPath}/pnpm`; |   const pnpmCachePath = `${commonPath}/pnpm`; | ||||||
| @@ -52,6 +54,7 @@ describe('cache-restore', () => { | |||||||
|   let getCommandOutputSpy: jest.SpyInstance; |   let getCommandOutputSpy: jest.SpyInstance; | ||||||
|   let restoreCacheSpy: jest.SpyInstance; |   let restoreCacheSpy: jest.SpyInstance; | ||||||
|   let hashFilesSpy: jest.SpyInstance; |   let hashFilesSpy: jest.SpyInstance; | ||||||
|  |   let archSpy: jest.SpyInstance; | ||||||
|  |  | ||||||
|   beforeEach(() => { |   beforeEach(() => { | ||||||
|     // core |     // core | ||||||
| @@ -102,6 +105,10 @@ describe('cache-restore', () => { | |||||||
|  |  | ||||||
|     // cache-utils |     // cache-utils | ||||||
|     getCommandOutputSpy = jest.spyOn(utils, 'getCommandOutput'); |     getCommandOutputSpy = jest.spyOn(utils, 'getCommandOutput'); | ||||||
|  |  | ||||||
|  |     // os | ||||||
|  |     archSpy = jest.spyOn(osm, 'arch'); | ||||||
|  |     archSpy.mockImplementation(() => arch); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   describe('Validate provided package manager', () => { |   describe('Validate provided package manager', () => { | ||||||
| @@ -135,7 +142,7 @@ describe('cache-restore', () => { | |||||||
|         await restoreCache(packageManager, ''); |         await restoreCache(packageManager, ''); | ||||||
|         expect(hashFilesSpy).toHaveBeenCalled(); |         expect(hashFilesSpy).toHaveBeenCalled(); | ||||||
|         expect(infoSpy).toHaveBeenCalledWith( |         expect(infoSpy).toHaveBeenCalledWith( | ||||||
|           `Cache restored from key: node-cache-${platform}-${packageManager}-${fileHash}` |           `Cache restored from key: node-cache-${platform}-${arch}-${packageManager}-${fileHash}` | ||||||
|         ); |         ); | ||||||
|         expect(infoSpy).not.toHaveBeenCalledWith( |         expect(infoSpy).not.toHaveBeenCalledWith( | ||||||
|           `${packageManager} cache is not found` |           `${packageManager} cache is not found` | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import { | |||||||
|   PackageManagerInfo, |   PackageManagerInfo, | ||||||
|   isCacheFeatureAvailable, |   isCacheFeatureAvailable, | ||||||
|   supportedPackageManagers, |   supportedPackageManagers, | ||||||
|   getCommandOutput, |   isGhes, | ||||||
|   resetProjectDirectoriesMemoized |   resetProjectDirectoriesMemoized | ||||||
| } from '../src/cache-utils'; | } from '../src/cache-utils'; | ||||||
| import fs from 'fs'; | import fs from 'fs'; | ||||||
| @@ -361,3 +361,41 @@ describe('cache-utils', () => { | |||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | describe('isGhes', () => { | ||||||
|  |   const pristineEnv = process.env; | ||||||
|  |  | ||||||
|  |   beforeEach(() => { | ||||||
|  |     jest.resetModules(); | ||||||
|  |     process.env = {...pristineEnv}; | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   afterAll(() => { | ||||||
|  |     process.env = pristineEnv; | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('returns false when the GITHUB_SERVER_URL environment variable is not defined', () => { | ||||||
|  |     delete process.env['GITHUB_SERVER_URL']; | ||||||
|  |     expect(isGhes()).toBeFalsy(); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('returns false when the GITHUB_SERVER_URL environment variable is set to github.com', () => { | ||||||
|  |     process.env['GITHUB_SERVER_URL'] = 'https://github.com'; | ||||||
|  |     expect(isGhes()).toBeFalsy(); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('returns false when the GITHUB_SERVER_URL environment variable is set to a GitHub Enterprise Cloud-style URL', () => { | ||||||
|  |     process.env['GITHUB_SERVER_URL'] = 'https://contoso.ghe.com'; | ||||||
|  |     expect(isGhes()).toBeFalsy(); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('returns false when the GITHUB_SERVER_URL environment variable has a .localhost suffix', () => { | ||||||
|  |     process.env['GITHUB_SERVER_URL'] = 'https://mock-github.localhost'; | ||||||
|  |     expect(isGhes()).toBeFalsy(); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('returns true when the GITHUB_SERVER_URL environment variable is set to some other URL', () => { | ||||||
|  |     process.env['GITHUB_SERVER_URL'] = 'https://src.onpremise.fabrikam.com'; | ||||||
|  |     expect(isGhes()).toBeTruthy(); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| v14 | v20 | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| nodejs 14.0.0 | nodejs 20.0.0 | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| node 14.0.0 | node 20.0.0 | ||||||
|   | |||||||
							
								
								
									
										1630
									
								
								__tests__/data/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1630
									
								
								__tests__/data/package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										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": { |   "engines": { | ||||||
|     "node": "^14.0.0" |     "node": "^20.0.0" | ||||||
|   }, |  | ||||||
|   "volta": { |  | ||||||
|     "node": "16.0.0" |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										1359
									
								
								__tests__/data/pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1359
									
								
								__tests__/data/pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -2,61 +2,111 @@ | |||||||
| # yarn lockfile v1 | # yarn lockfile v1 | ||||||
|  |  | ||||||
|  |  | ||||||
| accepts@~1.3.7: | accepts@^1.3.8: | ||||||
|   version "1.3.7" |   version "1.3.8" | ||||||
|   resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.7.tgz#531bc726517a3b2b41f850021c6cc15eaab507cd" |   resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.8.tgz#0bf0be125b67014adcb0b0921e62db7bffe16b2e" | ||||||
|   integrity sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA== |   integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== | ||||||
|   dependencies: |   dependencies: | ||||||
|     mime-types "~2.1.24" |     mime-types "~2.1.34" | ||||||
|     negotiator "0.6.2" |     negotiator "0.6.3" | ||||||
|  |  | ||||||
| array-flatten@1.1.1: | accepts@^2.0.0: | ||||||
|   version "1.1.1" |   version "2.0.0" | ||||||
|   resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" |   resolved "https://registry.yarnpkg.com/accepts/-/accepts-2.0.0.tgz#bbcf4ba5075467f3f2131eab3cffc73c2f5d7895" | ||||||
|   integrity sha1-ml9pkFGx5wczKPKgCJaLZOopVdI= |   integrity sha512-5cvg6CtKwfgdmVqY1WIiXKc3Q1bkRqGLi+2W/6ao+6Y7gu/RCwRuAhGEzh5B4KlszSuTLgZYuqFqo5bImjNKng== | ||||||
|  |  | ||||||
| body-parser@1.19.0: |  | ||||||
|   version "1.19.0" |  | ||||||
|   resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.19.0.tgz#96b2709e57c9c4e09a6fd66a8fd979844f69f08a" |  | ||||||
|   integrity sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw== |  | ||||||
|   dependencies: |   dependencies: | ||||||
|     bytes "3.1.0" |     mime-types "^3.0.0" | ||||||
|     content-type "~1.0.4" |     negotiator "^1.0.0" | ||||||
|  |  | ||||||
|  | array-flatten@3.0.0, array-flatten@^3.0.0: | ||||||
|  |   version "3.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-3.0.0.tgz#6428ca2ee52c7b823192ec600fa3ed2f157cd541" | ||||||
|  |   integrity sha512-zPMVc3ZYlGLNk4mpK1NzP2wg0ml9t7fUgDsayR5Y5rSzxQilzR9FGu/EH2jQOcKSAeAfWeylyW8juy3OkWRvNA== | ||||||
|  |  | ||||||
|  | body-parser@^1.20.3: | ||||||
|  |   version "1.20.3" | ||||||
|  |   resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.20.3.tgz#1953431221c6fb5cd63c4b36d53fab0928e548c6" | ||||||
|  |   integrity sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g== | ||||||
|  |   dependencies: | ||||||
|  |     bytes "3.1.2" | ||||||
|  |     content-type "~1.0.5" | ||||||
|     debug "2.6.9" |     debug "2.6.9" | ||||||
|     depd "~1.1.2" |     depd "2.0.0" | ||||||
|     http-errors "1.7.2" |     destroy "1.2.0" | ||||||
|  |     http-errors "2.0.0" | ||||||
|     iconv-lite "0.4.24" |     iconv-lite "0.4.24" | ||||||
|     on-finished "~2.3.0" |     on-finished "2.4.1" | ||||||
|     qs "6.7.0" |     qs "6.13.0" | ||||||
|     raw-body "2.4.0" |     raw-body "2.5.2" | ||||||
|     type-is "~1.6.17" |     type-is "~1.6.18" | ||||||
|  |     unpipe "1.0.0" | ||||||
|  |  | ||||||
| bytes@3.1.0: | body-parser@^2.0.1: | ||||||
|   version "3.1.0" |   version "2.0.1" | ||||||
|   resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.0.tgz#f6cf7933a360e0588fa9fde85651cdc7f805d1f6" |   resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-2.0.1.tgz#979de4a43468c5624403457fd6d45f797faffbaf" | ||||||
|   integrity sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg== |   integrity sha512-PagxbjvuPH6tv0f/kdVbFGcb79D236SLcDTs6DrQ7GizJ88S1UWP4nMXFEo/I4fdhGRGabvFfFjVGm3M7U8JwA== | ||||||
|  |  | ||||||
| content-disposition@0.5.3: |  | ||||||
|   version "0.5.3" |  | ||||||
|   resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.3.tgz#e130caf7e7279087c5616c2007d0485698984fbd" |  | ||||||
|   integrity sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g== |  | ||||||
|   dependencies: |   dependencies: | ||||||
|     safe-buffer "5.1.2" |     bytes "3.1.2" | ||||||
|  |     content-type "~1.0.5" | ||||||
|  |     debug "3.1.0" | ||||||
|  |     destroy "1.2.0" | ||||||
|  |     http-errors "2.0.0" | ||||||
|  |     iconv-lite "0.5.2" | ||||||
|  |     on-finished "2.4.1" | ||||||
|  |     qs "6.13.0" | ||||||
|  |     raw-body "^3.0.0" | ||||||
|  |     type-is "~1.6.18" | ||||||
|  |     unpipe "1.0.0" | ||||||
|  |  | ||||||
| content-type@~1.0.4: | bytes@3.1.2, bytes@^3.1.2: | ||||||
|   version "1.0.4" |   version "3.1.2" | ||||||
|   resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" |   resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" | ||||||
|   integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== |   integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== | ||||||
|  |  | ||||||
| cookie-signature@1.0.6: | call-bind@^1.0.7: | ||||||
|   version "1.0.6" |   version "1.0.7" | ||||||
|   resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" |   resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.7.tgz#06016599c40c56498c18769d2730be242b6fa3b9" | ||||||
|   integrity sha1-4wOogrNCzD7oylE6eZmXNNqzriw= |   integrity sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w== | ||||||
|  |   dependencies: | ||||||
|  |     es-define-property "^1.0.0" | ||||||
|  |     es-errors "^1.3.0" | ||||||
|  |     function-bind "^1.1.2" | ||||||
|  |     get-intrinsic "^1.2.4" | ||||||
|  |     set-function-length "^1.2.1" | ||||||
|  |  | ||||||
| cookie@0.4.0: | content-disposition@^0.5.4: | ||||||
|   version "0.4.0" |   version "0.5.4" | ||||||
|   resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.0.tgz#beb437e7022b3b6d49019d088665303ebe9c14ba" |   resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.4.tgz#8b82b4efac82512a02bb0b1dcec9d2c5e8eb5bfe" | ||||||
|   integrity sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg== |   integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== | ||||||
|  |   dependencies: | ||||||
|  |     safe-buffer "5.2.1" | ||||||
|  |  | ||||||
|  | content-disposition@^1.0.0: | ||||||
|  |   version "1.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-1.0.0.tgz#844426cb398f934caefcbb172200126bc7ceace2" | ||||||
|  |   integrity sha512-Au9nRL8VNUut/XSzbQA38+M78dzP4D+eqg3gfJHMIHHYa3bg067xj1KxMUWj+VULbiZMowKngFFbKczUrNJ1mg== | ||||||
|  |   dependencies: | ||||||
|  |     safe-buffer "5.2.1" | ||||||
|  |  | ||||||
|  | content-type@^1.0.5, content-type@~1.0.4, content-type@~1.0.5: | ||||||
|  |   version "1.0.5" | ||||||
|  |   resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.5.tgz#8b773162656d1d1086784c8f23a54ce6d73d7918" | ||||||
|  |   integrity sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA== | ||||||
|  |  | ||||||
|  | cookie-signature@^1.0.7, cookie-signature@^1.2.1: | ||||||
|  |   version "1.2.1" | ||||||
|  |   resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.2.1.tgz#790dea2cce64638c7ae04d9fabed193bd7ccf3b4" | ||||||
|  |   integrity sha512-78KWk9T26NhzXtuL26cIJ8/qNHANyJ/ZYrmEXFzUmhZdjpBv+DlWlOANRTGBt48YcyslsLrj0bMLFTmXvLRCOw== | ||||||
|  |  | ||||||
|  | cookie@0.6.0: | ||||||
|  |   version "0.6.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.6.0.tgz#2798b04b071b0ecbff0dbb62a505a8efa4e19051" | ||||||
|  |   integrity sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw== | ||||||
|  |  | ||||||
|  | cookie@^0.5.0: | ||||||
|  |   version "0.5.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.5.0.tgz#d1f5d71adec6558c58f389987c366aa47e994f8b" | ||||||
|  |   integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== | ||||||
|  |  | ||||||
| debug@2.6.9: | debug@2.6.9: | ||||||
|   version "2.6.9" |   version "2.6.9" | ||||||
| @@ -65,116 +115,235 @@ debug@2.6.9: | |||||||
|   dependencies: |   dependencies: | ||||||
|     ms "2.0.0" |     ms "2.0.0" | ||||||
|  |  | ||||||
|  | debug@3.1.0: | ||||||
|  |   version "3.1.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/debug/-/debug-3.1.0.tgz#5bb5a0672628b64149566ba16819e61518c67261" | ||||||
|  |   integrity sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g== | ||||||
|  |   dependencies: | ||||||
|  |     ms "2.0.0" | ||||||
|  |  | ||||||
|  | debug@4.3.6: | ||||||
|  |   version "4.3.6" | ||||||
|  |   resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.6.tgz#2ab2c38fbaffebf8aa95fdfe6d88438c7a13c52b" | ||||||
|  |   integrity sha512-O/09Bd4Z1fBrU4VzkhFqVgpPzaGbw6Sm9FEkBT1A/YBXQFGuuSxa1dN2nxgxS34JmKXqYx8CZAwEVoJFImUXIg== | ||||||
|  |   dependencies: | ||||||
|  |     ms "2.1.2" | ||||||
|  |  | ||||||
|  | debug@^4.0.0, debug@^4.3.5: | ||||||
|  |   version "4.3.7" | ||||||
|  |   resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.7.tgz#87945b4151a011d76d95a198d7111c865c360a52" | ||||||
|  |   integrity sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ== | ||||||
|  |   dependencies: | ||||||
|  |     ms "^2.1.3" | ||||||
|  |  | ||||||
|  | define-data-property@^1.1.4: | ||||||
|  |   version "1.1.4" | ||||||
|  |   resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.4.tgz#894dc141bb7d3060ae4366f6a0107e68fbe48c5e" | ||||||
|  |   integrity sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A== | ||||||
|  |   dependencies: | ||||||
|  |     es-define-property "^1.0.0" | ||||||
|  |     es-errors "^1.3.0" | ||||||
|  |     gopd "^1.0.1" | ||||||
|  |  | ||||||
|  | depd@2.0.0, depd@^2.0.0: | ||||||
|  |   version "2.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" | ||||||
|  |   integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== | ||||||
|  |  | ||||||
| depd@~1.1.2: | depd@~1.1.2: | ||||||
|   version "1.1.2" |   version "1.1.2" | ||||||
|   resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" |   resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" | ||||||
|   integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak= |   integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== | ||||||
|  |  | ||||||
| destroy@~1.0.4: | destroy@1.2.0, destroy@^1.1.0, destroy@^1.2.0: | ||||||
|   version "1.0.4" |   version "1.2.0" | ||||||
|   resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80" |   resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.2.0.tgz#4803735509ad8be552934c67df614f94e66fa015" | ||||||
|   integrity sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA= |   integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== | ||||||
|  |  | ||||||
| ee-first@1.1.1: | ee-first@1.1.1, ee-first@^1.1.1: | ||||||
|   version "1.1.1" |   version "1.1.1" | ||||||
|   resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" |   resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" | ||||||
|   integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= |   integrity sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow== | ||||||
|  |  | ||||||
|  | encodeurl@^2.0.0, encodeurl@~2.0.0: | ||||||
|  |   version "2.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-2.0.0.tgz#7b8ea898077d7e409d3ac45474ea38eaf0857a58" | ||||||
|  |   integrity sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg== | ||||||
|  |  | ||||||
| encodeurl@~1.0.2: | encodeurl@~1.0.2: | ||||||
|   version "1.0.2" |   version "1.0.2" | ||||||
|   resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" |   resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" | ||||||
|   integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= |   integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w== | ||||||
|  |  | ||||||
| escape-html@~1.0.3: | es-define-property@^1.0.0: | ||||||
|  |   version "1.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/es-define-property/-/es-define-property-1.0.0.tgz#c7faefbdff8b2696cf5f46921edfb77cc4ba3845" | ||||||
|  |   integrity sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ== | ||||||
|  |   dependencies: | ||||||
|  |     get-intrinsic "^1.2.4" | ||||||
|  |  | ||||||
|  | es-errors@^1.3.0: | ||||||
|  |   version "1.3.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/es-errors/-/es-errors-1.3.0.tgz#05f75a25dab98e4fb1dcd5e1472c0546d5057c8f" | ||||||
|  |   integrity sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw== | ||||||
|  |  | ||||||
|  | escape-html@^1.0.3, escape-html@~1.0.3: | ||||||
|   version "1.0.3" |   version "1.0.3" | ||||||
|   resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" |   resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" | ||||||
|   integrity sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg= |   integrity sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow== | ||||||
|  |  | ||||||
| etag@~1.8.1: | etag@^1.8.1, etag@~1.8.1: | ||||||
|   version "1.8.1" |   version "1.8.1" | ||||||
|   resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" |   resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" | ||||||
|   integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= |   integrity sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg== | ||||||
|  |  | ||||||
| express@^4.17.1: | express@^5.0.0: | ||||||
|   version "4.17.1" |   version "5.0.0" | ||||||
|   resolved "https://registry.yarnpkg.com/express/-/express-4.17.1.tgz#4491fc38605cf51f8629d39c2b5d026f98a4c134" |   resolved "https://registry.yarnpkg.com/express/-/express-5.0.0.tgz#744f9ec86025a01aeca99e4300aa4fc050d493c7" | ||||||
|   integrity sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g== |   integrity sha512-V4UkHQc+B7ldh1YC84HCXHwf60M4BOMvp9rkvTUWCK5apqDC1Esnbid4wm6nFyVuDy8XMfETsJw5lsIGBWyo0A== | ||||||
|   dependencies: |   dependencies: | ||||||
|     accepts "~1.3.7" |     accepts "^2.0.0" | ||||||
|     array-flatten "1.1.1" |     body-parser "^2.0.1" | ||||||
|     body-parser "1.19.0" |     content-disposition "^1.0.0" | ||||||
|     content-disposition "0.5.3" |  | ||||||
|     content-type "~1.0.4" |     content-type "~1.0.4" | ||||||
|     cookie "0.4.0" |     cookie "0.6.0" | ||||||
|     cookie-signature "1.0.6" |     cookie-signature "^1.2.1" | ||||||
|     debug "2.6.9" |     debug "4.3.6" | ||||||
|     depd "~1.1.2" |     depd "2.0.0" | ||||||
|     encodeurl "~1.0.2" |     encodeurl "~2.0.0" | ||||||
|     escape-html "~1.0.3" |     escape-html "~1.0.3" | ||||||
|     etag "~1.8.1" |     etag "~1.8.1" | ||||||
|     finalhandler "~1.1.2" |     finalhandler "^2.0.0" | ||||||
|     fresh "0.5.2" |     fresh "2.0.0" | ||||||
|     merge-descriptors "1.0.1" |     http-errors "2.0.0" | ||||||
|  |     merge-descriptors "^2.0.0" | ||||||
|     methods "~1.1.2" |     methods "~1.1.2" | ||||||
|     on-finished "~2.3.0" |     mime-types "^3.0.0" | ||||||
|  |     on-finished "2.4.1" | ||||||
|  |     once "1.4.0" | ||||||
|     parseurl "~1.3.3" |     parseurl "~1.3.3" | ||||||
|     path-to-regexp "0.1.7" |     proxy-addr "~2.0.7" | ||||||
|     proxy-addr "~2.0.5" |     qs "6.13.0" | ||||||
|     qs "6.7.0" |  | ||||||
|     range-parser "~1.2.1" |     range-parser "~1.2.1" | ||||||
|     safe-buffer "5.1.2" |     router "^2.0.0" | ||||||
|     send "0.17.1" |     safe-buffer "5.2.1" | ||||||
|     serve-static "1.14.1" |     send "^1.1.0" | ||||||
|     setprototypeof "1.1.1" |     serve-static "^2.1.0" | ||||||
|     statuses "~1.5.0" |     setprototypeof "1.2.0" | ||||||
|     type-is "~1.6.18" |     statuses "2.0.1" | ||||||
|  |     type-is "^2.0.0" | ||||||
|     utils-merge "1.0.1" |     utils-merge "1.0.1" | ||||||
|     vary "~1.1.2" |     vary "~1.1.2" | ||||||
|  |  | ||||||
| finalhandler@~1.1.2: | finalhandler@^1.2.0: | ||||||
|   version "1.1.2" |   version "1.3.1" | ||||||
|   resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.2.tgz#b7e7d000ffd11938d0fdb053506f6ebabe9f587d" |   resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.3.1.tgz#0c575f1d1d324ddd1da35ad7ece3df7d19088019" | ||||||
|   integrity sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA== |   integrity sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ== | ||||||
|  |   dependencies: | ||||||
|  |     debug "2.6.9" | ||||||
|  |     encodeurl "~2.0.0" | ||||||
|  |     escape-html "~1.0.3" | ||||||
|  |     on-finished "2.4.1" | ||||||
|  |     parseurl "~1.3.3" | ||||||
|  |     statuses "2.0.1" | ||||||
|  |     unpipe "~1.0.0" | ||||||
|  |  | ||||||
|  | finalhandler@^2.0.0: | ||||||
|  |   version "2.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-2.0.0.tgz#9d3c79156dfa798069db7de7dd53bc37546f564b" | ||||||
|  |   integrity sha512-MX6Zo2adDViYh+GcxxB1dpO43eypOGUOL12rLCOTMQv/DfIbpSJUy4oQIIZhVZkH9e+bZWKMon0XHFEju16tkQ== | ||||||
|   dependencies: |   dependencies: | ||||||
|     debug "2.6.9" |     debug "2.6.9" | ||||||
|     encodeurl "~1.0.2" |     encodeurl "~1.0.2" | ||||||
|     escape-html "~1.0.3" |     escape-html "~1.0.3" | ||||||
|     on-finished "~2.3.0" |     on-finished "2.4.1" | ||||||
|     parseurl "~1.3.3" |     parseurl "~1.3.3" | ||||||
|     statuses "~1.5.0" |     statuses "2.0.1" | ||||||
|     unpipe "~1.0.0" |     unpipe "~1.0.0" | ||||||
|  |  | ||||||
| forwarded@~0.1.2: | forwarded@0.2.0, forwarded@^0.2.0: | ||||||
|   version "0.1.2" |   version "0.2.0" | ||||||
|   resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.1.2.tgz#98c23dab1175657b8c0573e8ceccd91b0ff18c84" |   resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" | ||||||
|   integrity sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ= |   integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== | ||||||
|  |  | ||||||
| fresh@0.5.2: | fresh@0.5.2, fresh@^0.5.2: | ||||||
|   version "0.5.2" |   version "0.5.2" | ||||||
|   resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" |   resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" | ||||||
|   integrity sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac= |   integrity sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q== | ||||||
|  |  | ||||||
| http-errors@1.7.2: | fresh@2.0.0: | ||||||
|   version "1.7.2" |   version "2.0.0" | ||||||
|   resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.2.tgz#4f5029cf13239f31036e5b2e55292bcfbcc85c8f" |   resolved "https://registry.yarnpkg.com/fresh/-/fresh-2.0.0.tgz#8dd7df6a1b3a1b3a5cf186c05a5dd267622635a4" | ||||||
|   integrity sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg== |   integrity sha512-Rx/WycZ60HOaqLKAi6cHRKKI7zxWbJ31MhntmtwMoaTeF7XFH9hhBp8vITaMidfljRQ6eYWCKkaTK+ykVJHP2A== | ||||||
|  |  | ||||||
|  | function-bind@^1.1.2: | ||||||
|  |   version "1.1.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" | ||||||
|  |   integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== | ||||||
|  |  | ||||||
|  | get-intrinsic@^1.1.3, get-intrinsic@^1.2.4: | ||||||
|  |   version "1.2.4" | ||||||
|  |   resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.4.tgz#e385f5a4b5227d449c3eabbad05494ef0abbeadd" | ||||||
|  |   integrity sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ== | ||||||
|   dependencies: |   dependencies: | ||||||
|     depd "~1.1.2" |     es-errors "^1.3.0" | ||||||
|     inherits "2.0.3" |     function-bind "^1.1.2" | ||||||
|     setprototypeof "1.1.1" |     has-proto "^1.0.1" | ||||||
|     statuses ">= 1.5.0 < 2" |     has-symbols "^1.0.3" | ||||||
|     toidentifier "1.0.0" |     hasown "^2.0.0" | ||||||
|  |  | ||||||
| http-errors@~1.7.2: | gopd@^1.0.1: | ||||||
|   version "1.7.3" |   version "1.0.1" | ||||||
|   resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.3.tgz#6c619e4f9c60308c38519498c14fbb10aacebb06" |   resolved "https://registry.yarnpkg.com/gopd/-/gopd-1.0.1.tgz#29ff76de69dac7489b7c0918a5788e56477c332c" | ||||||
|   integrity sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw== |   integrity sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA== | ||||||
|  |   dependencies: | ||||||
|  |     get-intrinsic "^1.1.3" | ||||||
|  |  | ||||||
|  | has-property-descriptors@^1.0.2: | ||||||
|  |   version "1.0.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz#963ed7d071dc7bf5f084c5bfbe0d1b6222586854" | ||||||
|  |   integrity sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg== | ||||||
|  |   dependencies: | ||||||
|  |     es-define-property "^1.0.0" | ||||||
|  |  | ||||||
|  | has-proto@^1.0.1: | ||||||
|  |   version "1.0.3" | ||||||
|  |   resolved "https://registry.yarnpkg.com/has-proto/-/has-proto-1.0.3.tgz#b31ddfe9b0e6e9914536a6ab286426d0214f77fd" | ||||||
|  |   integrity sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q== | ||||||
|  |  | ||||||
|  | has-symbols@^1.0.3: | ||||||
|  |   version "1.0.3" | ||||||
|  |   resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" | ||||||
|  |   integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== | ||||||
|  |  | ||||||
|  | hasown@^2.0.0: | ||||||
|  |   version "2.0.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.2.tgz#003eaf91be7adc372e84ec59dc37252cedb80003" | ||||||
|  |   integrity sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ== | ||||||
|  |   dependencies: | ||||||
|  |     function-bind "^1.1.2" | ||||||
|  |  | ||||||
|  | http-errors@2.0.0, http-errors@^2.0.0: | ||||||
|  |   version "2.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" | ||||||
|  |   integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== | ||||||
|  |   dependencies: | ||||||
|  |     depd "2.0.0" | ||||||
|  |     inherits "2.0.4" | ||||||
|  |     setprototypeof "1.2.0" | ||||||
|  |     statuses "2.0.1" | ||||||
|  |     toidentifier "1.0.1" | ||||||
|  |  | ||||||
|  | http-errors@^1.8.0: | ||||||
|  |   version "1.8.1" | ||||||
|  |   resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.8.1.tgz#7c3f28577cbc8a207388455dbd62295ed07bd68c" | ||||||
|  |   integrity sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g== | ||||||
|   dependencies: |   dependencies: | ||||||
|     depd "~1.1.2" |     depd "~1.1.2" | ||||||
|     inherits "2.0.4" |     inherits "2.0.4" | ||||||
|     setprototypeof "1.1.1" |     setprototypeof "1.2.0" | ||||||
|     statuses ">= 1.5.0 < 2" |     statuses ">= 1.5.0 < 2" | ||||||
|     toidentifier "1.0.0" |     toidentifier "1.0.1" | ||||||
|  |  | ||||||
| iconv-lite@0.4.24: | iconv-lite@0.4.24: | ||||||
|   version "0.4.24" |   version "0.4.24" | ||||||
| @@ -183,12 +352,21 @@ iconv-lite@0.4.24: | |||||||
|   dependencies: |   dependencies: | ||||||
|     safer-buffer ">= 2.1.2 < 3" |     safer-buffer ">= 2.1.2 < 3" | ||||||
|  |  | ||||||
| inherits@2.0.3: | iconv-lite@0.5.2: | ||||||
|   version "2.0.3" |   version "0.5.2" | ||||||
|   resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" |   resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.5.2.tgz#af6d628dccfb463b7364d97f715e4b74b8c8c2b8" | ||||||
|   integrity sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4= |   integrity sha512-kERHXvpSaB4aU3eANwidg79K8FlrN77m8G9V+0vOR3HYaRifrlwMEpT7ZBJqLSEIHnEgJTHcWK82wwLwwKwtag== | ||||||
|  |   dependencies: | ||||||
|  |     safer-buffer ">= 2.1.2 < 3" | ||||||
|  |  | ||||||
| inherits@2.0.4: | iconv-lite@0.6.3, iconv-lite@^0.6.0: | ||||||
|  |   version "0.6.3" | ||||||
|  |   resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" | ||||||
|  |   integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== | ||||||
|  |   dependencies: | ||||||
|  |     safer-buffer ">= 2.1.2 < 3.0.0" | ||||||
|  |  | ||||||
|  | inherits@2.0.4, inherits@^2.0.4: | ||||||
|   version "2.0.4" |   version "2.0.4" | ||||||
|   resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" |   resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" | ||||||
|   integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== |   integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== | ||||||
| @@ -198,34 +376,61 @@ ipaddr.js@1.9.1: | |||||||
|   resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" |   resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" | ||||||
|   integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== |   integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== | ||||||
|  |  | ||||||
|  | ipaddr.js@^2.2.0: | ||||||
|  |   version "2.2.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-2.2.0.tgz#d33fa7bac284f4de7af949638c9d68157c6b92e8" | ||||||
|  |   integrity sha512-Ag3wB2o37wslZS19hZqorUnrnzSkpOVy+IiiDEiTqNubEYpYuHWIf6K4psgN2ZWKExS4xhVCrRVfb/wfW8fWJA== | ||||||
|  |  | ||||||
|  | is-promise@4.0.0: | ||||||
|  |   version "4.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/is-promise/-/is-promise-4.0.0.tgz#42ff9f84206c1991d26debf520dd5c01042dd2f3" | ||||||
|  |   integrity sha512-hvpoI6korhJMnej285dSg6nu1+e6uxs7zG3BYAm5byqDsgJNWwxzM6z6iZiAgQR4TJ30JmBTOwqZUw3WlyH3AQ== | ||||||
|  |  | ||||||
| media-typer@0.3.0: | media-typer@0.3.0: | ||||||
|   version "0.3.0" |   version "0.3.0" | ||||||
|   resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" |   resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" | ||||||
|   integrity sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g= |   integrity sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ== | ||||||
|  |  | ||||||
| merge-descriptors@1.0.1: | media-typer@^1.1.0: | ||||||
|   version "1.0.1" |   version "1.1.0" | ||||||
|   resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" |   resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-1.1.0.tgz#6ab74b8f2d3320f2064b2a87a38e7931ff3a5561" | ||||||
|   integrity sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E= |   integrity sha512-aisnrDP4GNe06UcKFnV5bfMNPBUw4jsLGaWwWfnH3v02GnBuXX2MCVn5RbrWo0j3pczUilYblq7fQ7Nw2t5XKw== | ||||||
|  |  | ||||||
| methods@~1.1.2: | merge-descriptors@^2.0.0: | ||||||
|  |   version "2.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-2.0.0.tgz#ea922f660635a2249ee565e0449f951e6b603808" | ||||||
|  |   integrity sha512-Snk314V5ayFLhp3fkUREub6WtjBfPdCPY1Ln8/8munuLuiYhsABgBVWsozAG+MWMbVEvcdcpbi9R7ww22l9Q3g== | ||||||
|  |  | ||||||
|  | methods@^1.1.2, methods@~1.1.2: | ||||||
|   version "1.1.2" |   version "1.1.2" | ||||||
|   resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" |   resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" | ||||||
|   integrity sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4= |   integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== | ||||||
|  |  | ||||||
| mime-db@1.47.0: | mime-db@1.52.0: | ||||||
|   version "1.47.0" |   version "1.52.0" | ||||||
|   resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.47.0.tgz#8cb313e59965d3c05cfbf898915a267af46a335c" |   resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" | ||||||
|   integrity sha512-QBmA/G2y+IfeS4oktet3qRZ+P5kPhCKRXxXnQEudYqUaEioAU1/Lq2us3D/t1Jfo4hE9REQPrbB7K5sOczJVIw== |   integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== | ||||||
|  |  | ||||||
| mime-types@~2.1.24: | mime-db@^1.51.0, mime-db@^1.53.0: | ||||||
|   version "2.1.30" |   version "1.53.0" | ||||||
|   resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.30.tgz#6e7be8b4c479825f85ed6326695db73f9305d62d" |   resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.53.0.tgz#3cb63cd820fc29896d9d4e8c32ab4fcd74ccb447" | ||||||
|   integrity sha512-crmjA4bLtR8m9qLpHvgxSChT+XoSlZi8J4n/aIdn3z92e/U47Z0V/yl+Wh9W046GgFVAmoNR/fmdbZYcSSIUeg== |   integrity sha512-oHlN/w+3MQ3rba9rqFr6V/ypF10LSkdwUysQL7GkXoTgIWeV+tcXGA852TBxH+gsh8UWoyhR1hKcoMJTuWflpg== | ||||||
|  |  | ||||||
|  | mime-types@^2.1.35, mime-types@~2.1.24, mime-types@~2.1.34: | ||||||
|  |   version "2.1.35" | ||||||
|  |   resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" | ||||||
|  |   integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== | ||||||
|   dependencies: |   dependencies: | ||||||
|     mime-db "1.47.0" |     mime-db "1.52.0" | ||||||
|  |  | ||||||
| mime@1.6.0: | mime-types@^3.0.0: | ||||||
|  |   version "3.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-3.0.0.tgz#148453a900475522d095a445355c074cca4f5217" | ||||||
|  |   integrity sha512-XqoSHeCGjVClAmoGFG3lVFqQFRIrTVw2OH3axRqAcfaw+gHWIfnASS92AV+Rl/mk0MupgZTRHQOjxY6YVnzK5w== | ||||||
|  |   dependencies: | ||||||
|  |     mime-db "^1.53.0" | ||||||
|  |  | ||||||
|  | mime@1.6.0, mime@^1.6.0: | ||||||
|   version "1.6.0" |   version "1.6.0" | ||||||
|   resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" |   resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" | ||||||
|   integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== |   integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== | ||||||
| @@ -233,118 +438,220 @@ mime@1.6.0: | |||||||
| ms@2.0.0: | ms@2.0.0: | ||||||
|   version "2.0.0" |   version "2.0.0" | ||||||
|   resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" |   resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" | ||||||
|   integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g= |   integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== | ||||||
|  |  | ||||||
| ms@2.1.1: | ms@2.1.2: | ||||||
|   version "2.1.1" |   version "2.1.2" | ||||||
|   resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.1.tgz#30a5864eb3ebb0a66f2ebe6d727af06a09d86e0a" |   resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" | ||||||
|   integrity sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg== |   integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== | ||||||
|  |  | ||||||
| negotiator@0.6.2: | ms@2.1.3, ms@^2.1.2, ms@^2.1.3: | ||||||
|   version "0.6.2" |   version "2.1.3" | ||||||
|   resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.2.tgz#feacf7ccf525a77ae9634436a64883ffeca346fb" |   resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" | ||||||
|   integrity sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw== |   integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== | ||||||
|  |  | ||||||
| on-finished@~2.3.0: | negotiator@0.6.3, negotiator@^0.6.3: | ||||||
|   version "2.3.0" |   version "0.6.3" | ||||||
|   resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" |   resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" | ||||||
|   integrity sha1-IPEzZIGwg811M3mSoWlxqi2QaUc= |   integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== | ||||||
|  |  | ||||||
|  | negotiator@^1.0.0: | ||||||
|  |   version "1.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-1.0.0.tgz#b6c91bb47172d69f93cfd7c357bbb529019b5f6a" | ||||||
|  |   integrity sha512-8Ofs/AUQh8MaEcrlq5xOX0CQ9ypTF5dl78mjlMNfOK08fzpgTHQRQPBxcPlEtIw0yRpws+Zo/3r+5WRby7u3Gg== | ||||||
|  |  | ||||||
|  | object-inspect@^1.13.1: | ||||||
|  |   version "1.13.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.13.2.tgz#dea0088467fb991e67af4058147a24824a3043ff" | ||||||
|  |   integrity sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g== | ||||||
|  |  | ||||||
|  | on-finished@2.4.1, on-finished@^2.4.0, on-finished@^2.4.1: | ||||||
|  |   version "2.4.1" | ||||||
|  |   resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.4.1.tgz#58c8c44116e54845ad57f14ab10b03533184ac3f" | ||||||
|  |   integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== | ||||||
|   dependencies: |   dependencies: | ||||||
|     ee-first "1.1.1" |     ee-first "1.1.1" | ||||||
|  |  | ||||||
| parseurl@~1.3.3: | once@1.4.0: | ||||||
|  |   version "1.4.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" | ||||||
|  |   integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== | ||||||
|  |   dependencies: | ||||||
|  |     wrappy "1" | ||||||
|  |  | ||||||
|  | parseurl@^1.3.3, parseurl@~1.3.3: | ||||||
|   version "1.3.3" |   version "1.3.3" | ||||||
|   resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" |   resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" | ||||||
|   integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== |   integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== | ||||||
|  |  | ||||||
| path-to-regexp@0.1.7: | path-to-regexp@^8.0.0: | ||||||
|   version "0.1.7" |   version "8.1.0" | ||||||
|   resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" |   resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-8.1.0.tgz#4d687606ed0be8ed512ba802eb94d620cb1a86f0" | ||||||
|   integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= |   integrity sha512-Bqn3vc8CMHty6zuD+tG23s6v2kwxslHEhTj4eYaVKGIEB+YX/2wd0/rgXLFD9G9id9KCtbVy/3ZgmvZjpa0UdQ== | ||||||
|  |  | ||||||
| proxy-addr@~2.0.5: | proxy-addr@^2.0.7, proxy-addr@~2.0.7: | ||||||
|   version "2.0.6" |   version "2.0.7" | ||||||
|   resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.6.tgz#fdc2336505447d3f2f2c638ed272caf614bbb2bf" |   resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" | ||||||
|   integrity sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw== |   integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== | ||||||
|   dependencies: |   dependencies: | ||||||
|     forwarded "~0.1.2" |     forwarded "0.2.0" | ||||||
|     ipaddr.js "1.9.1" |     ipaddr.js "1.9.1" | ||||||
|  |  | ||||||
| qs@6.7.0: | qs@6.13.0, qs@^6.8.0: | ||||||
|   version "6.7.0" |   version "6.13.0" | ||||||
|   resolved "https://registry.yarnpkg.com/qs/-/qs-6.7.0.tgz#41dc1a015e3d581f1621776be31afb2876a9b1bc" |   resolved "https://registry.yarnpkg.com/qs/-/qs-6.13.0.tgz#6ca3bd58439f7e245655798997787b0d88a51906" | ||||||
|   integrity sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ== |   integrity sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg== | ||||||
|  |   dependencies: | ||||||
|  |     side-channel "^1.0.6" | ||||||
|  |  | ||||||
| range-parser@~1.2.1: | range-parser@^1.2.1, range-parser@~1.2.1: | ||||||
|   version "1.2.1" |   version "1.2.1" | ||||||
|   resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" |   resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" | ||||||
|   integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== |   integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== | ||||||
|  |  | ||||||
| raw-body@2.4.0: | raw-body@2.5.2, raw-body@^2.4.1: | ||||||
|   version "2.4.0" |   version "2.5.2" | ||||||
|   resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.0.tgz#a1ce6fb9c9bc356ca52e89256ab59059e13d0332" |   resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.2.tgz#99febd83b90e08975087e8f1f9419a149366b68a" | ||||||
|   integrity sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q== |   integrity sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA== | ||||||
|   dependencies: |   dependencies: | ||||||
|     bytes "3.1.0" |     bytes "3.1.2" | ||||||
|     http-errors "1.7.2" |     http-errors "2.0.0" | ||||||
|     iconv-lite "0.4.24" |     iconv-lite "0.4.24" | ||||||
|     unpipe "1.0.0" |     unpipe "1.0.0" | ||||||
|  |  | ||||||
| safe-buffer@5.1.2: | raw-body@^3.0.0: | ||||||
|   version "5.1.2" |   version "3.0.0" | ||||||
|   resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" |   resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-3.0.0.tgz#25b3476f07a51600619dae3fe82ddc28a36e5e0f" | ||||||
|   integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== |   integrity sha512-RmkhL8CAyCRPXCE28MMH0z2PNWQBNk2Q09ZdxM9IOOXwxwZbN+qbWaatPkdkWIKL2ZVDImrN/pK5HTRz2PcS4g== | ||||||
|  |   dependencies: | ||||||
|  |     bytes "3.1.2" | ||||||
|  |     http-errors "2.0.0" | ||||||
|  |     iconv-lite "0.6.3" | ||||||
|  |     unpipe "1.0.0" | ||||||
|  |  | ||||||
| "safer-buffer@>= 2.1.2 < 3": | router@^2.0.0: | ||||||
|  |   version "2.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/router/-/router-2.0.0.tgz#8692720b95de83876870d7bc638dd3c7e1ae8a27" | ||||||
|  |   integrity sha512-dIM5zVoG8xhC6rnSN8uoAgFARwTE7BQs8YwHEvK0VCmfxQXMaOuA1uiR1IPwsW7JyK5iTt7Od/TC9StasS2NPQ== | ||||||
|  |   dependencies: | ||||||
|  |     array-flatten "3.0.0" | ||||||
|  |     is-promise "4.0.0" | ||||||
|  |     methods "~1.1.2" | ||||||
|  |     parseurl "~1.3.3" | ||||||
|  |     path-to-regexp "^8.0.0" | ||||||
|  |     setprototypeof "1.2.0" | ||||||
|  |     utils-merge "1.0.1" | ||||||
|  |  | ||||||
|  | safe-buffer@5.2.1, safe-buffer@^5.2.1: | ||||||
|  |   version "5.2.1" | ||||||
|  |   resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" | ||||||
|  |   integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== | ||||||
|  |  | ||||||
|  | "safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0", safer-buffer@^2.1.2: | ||||||
|   version "2.1.2" |   version "2.1.2" | ||||||
|   resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" |   resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" | ||||||
|   integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== |   integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== | ||||||
|  |  | ||||||
| send@0.17.1: | send@0.19.0, send@^0.19.0: | ||||||
|   version "0.17.1" |   version "0.19.0" | ||||||
|   resolved "https://registry.yarnpkg.com/send/-/send-0.17.1.tgz#c1d8b059f7900f7466dd4938bdc44e11ddb376c8" |   resolved "https://registry.yarnpkg.com/send/-/send-0.19.0.tgz#bbc5a388c8ea6c048967049dbeac0e4a3f09d7f8" | ||||||
|   integrity sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg== |   integrity sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw== | ||||||
|   dependencies: |   dependencies: | ||||||
|     debug "2.6.9" |     debug "2.6.9" | ||||||
|     depd "~1.1.2" |     depd "2.0.0" | ||||||
|     destroy "~1.0.4" |     destroy "1.2.0" | ||||||
|     encodeurl "~1.0.2" |     encodeurl "~1.0.2" | ||||||
|     escape-html "~1.0.3" |     escape-html "~1.0.3" | ||||||
|     etag "~1.8.1" |     etag "~1.8.1" | ||||||
|     fresh "0.5.2" |     fresh "0.5.2" | ||||||
|     http-errors "~1.7.2" |     http-errors "2.0.0" | ||||||
|     mime "1.6.0" |     mime "1.6.0" | ||||||
|     ms "2.1.1" |     ms "2.1.3" | ||||||
|     on-finished "~2.3.0" |     on-finished "2.4.1" | ||||||
|     range-parser "~1.2.1" |     range-parser "~1.2.1" | ||||||
|     statuses "~1.5.0" |     statuses "2.0.1" | ||||||
|  |  | ||||||
| serve-static@1.14.1: | send@^1.0.0, send@^1.1.0: | ||||||
|   version "1.14.1" |   version "1.1.0" | ||||||
|   resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.14.1.tgz#666e636dc4f010f7ef29970a88a674320898b2f9" |   resolved "https://registry.yarnpkg.com/send/-/send-1.1.0.tgz#4efe6ff3bb2139b0e5b2648d8b18d4dec48fc9c5" | ||||||
|   integrity sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg== |   integrity sha512-v67WcEouB5GxbTWL/4NeToqcZiAWEq90N888fczVArY8A79J0L4FD7vj5hm3eUMua5EpoQ59wa/oovY6TLvRUA== | ||||||
|   dependencies: |   dependencies: | ||||||
|     encodeurl "~1.0.2" |     debug "^4.3.5" | ||||||
|  |     destroy "^1.2.0" | ||||||
|  |     encodeurl "^2.0.0" | ||||||
|  |     escape-html "^1.0.3" | ||||||
|  |     etag "^1.8.1" | ||||||
|  |     fresh "^0.5.2" | ||||||
|  |     http-errors "^2.0.0" | ||||||
|  |     mime-types "^2.1.35" | ||||||
|  |     ms "^2.1.3" | ||||||
|  |     on-finished "^2.4.1" | ||||||
|  |     range-parser "^1.2.1" | ||||||
|  |     statuses "^2.0.1" | ||||||
|  |  | ||||||
|  | serve-static@^1.15.0: | ||||||
|  |   version "1.16.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.16.2.tgz#b6a5343da47f6bdd2673848bf45754941e803296" | ||||||
|  |   integrity sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw== | ||||||
|  |   dependencies: | ||||||
|  |     encodeurl "~2.0.0" | ||||||
|     escape-html "~1.0.3" |     escape-html "~1.0.3" | ||||||
|     parseurl "~1.3.3" |     parseurl "~1.3.3" | ||||||
|     send "0.17.1" |     send "0.19.0" | ||||||
|  |  | ||||||
| setprototypeof@1.1.1: | serve-static@^2.1.0: | ||||||
|   version "1.1.1" |   version "2.1.0" | ||||||
|   resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.1.tgz#7e95acb24aa92f5885e0abef5ba131330d4ae683" |   resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-2.1.0.tgz#1b4eacbe93006b79054faa4d6d0a501d7f0e84e2" | ||||||
|   integrity sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw== |   integrity sha512-A3We5UfEjG8Z7VkDv6uItWw6HY2bBSBJT1KtVESn6EOoOr2jAxNhxWCLY3jDE2WcuHXByWju74ck3ZgLwL8xmA== | ||||||
|  |   dependencies: | ||||||
|  |     encodeurl "^2.0.0" | ||||||
|  |     escape-html "^1.0.3" | ||||||
|  |     parseurl "^1.3.3" | ||||||
|  |     send "^1.0.0" | ||||||
|  |  | ||||||
| "statuses@>= 1.5.0 < 2", statuses@~1.5.0: | set-function-length@^1.2.1: | ||||||
|  |   version "1.2.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/set-function-length/-/set-function-length-1.2.2.tgz#aac72314198eaed975cf77b2c3b6b880695e5449" | ||||||
|  |   integrity sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg== | ||||||
|  |   dependencies: | ||||||
|  |     define-data-property "^1.1.4" | ||||||
|  |     es-errors "^1.3.0" | ||||||
|  |     function-bind "^1.1.2" | ||||||
|  |     get-intrinsic "^1.2.4" | ||||||
|  |     gopd "^1.0.1" | ||||||
|  |     has-property-descriptors "^1.0.2" | ||||||
|  |  | ||||||
|  | setprototypeof@1.2.0, setprototypeof@^1.2.0: | ||||||
|  |   version "1.2.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424" | ||||||
|  |   integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== | ||||||
|  |  | ||||||
|  | side-channel@^1.0.6: | ||||||
|  |   version "1.0.6" | ||||||
|  |   resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.6.tgz#abd25fb7cd24baf45466406b1096b7831c9215f2" | ||||||
|  |   integrity sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA== | ||||||
|  |   dependencies: | ||||||
|  |     call-bind "^1.0.7" | ||||||
|  |     es-errors "^1.3.0" | ||||||
|  |     get-intrinsic "^1.2.4" | ||||||
|  |     object-inspect "^1.13.1" | ||||||
|  |  | ||||||
|  | statuses@2.0.1, statuses@^2.0.1: | ||||||
|  |   version "2.0.1" | ||||||
|  |   resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" | ||||||
|  |   integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== | ||||||
|  |  | ||||||
|  | "statuses@>= 1.5.0 < 2": | ||||||
|   version "1.5.0" |   version "1.5.0" | ||||||
|   resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" |   resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" | ||||||
|   integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= |   integrity sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA== | ||||||
|  |  | ||||||
| toidentifier@1.0.0: | toidentifier@1.0.1: | ||||||
|   version "1.0.0" |   version "1.0.1" | ||||||
|   resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.0.tgz#7e1be3470f1e77948bc43d94a3c8f4d7752ba553" |   resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" | ||||||
|   integrity sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw== |   integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== | ||||||
|  |  | ||||||
| type-is@~1.6.17, type-is@~1.6.18: | type-is@^1.6.18, type-is@~1.6.18: | ||||||
|   version "1.6.18" |   version "1.6.18" | ||||||
|   resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" |   resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" | ||||||
|   integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== |   integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== | ||||||
| @@ -352,17 +659,31 @@ type-is@~1.6.17, type-is@~1.6.18: | |||||||
|     media-typer "0.3.0" |     media-typer "0.3.0" | ||||||
|     mime-types "~2.1.24" |     mime-types "~2.1.24" | ||||||
|  |  | ||||||
|  | type-is@^2.0.0: | ||||||
|  |   version "2.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/type-is/-/type-is-2.0.0.tgz#7d249c2e2af716665cc149575dadb8b3858653af" | ||||||
|  |   integrity sha512-gd0sGezQYCbWSbkZr75mln4YBidWUN60+devscpLF5mtRDUpiaTvKpBNrdaCvel1NdR2k6vclXybU5fBd2i+nw== | ||||||
|  |   dependencies: | ||||||
|  |     content-type "^1.0.5" | ||||||
|  |     media-typer "^1.1.0" | ||||||
|  |     mime-types "^3.0.0" | ||||||
|  |  | ||||||
| unpipe@1.0.0, unpipe@~1.0.0: | unpipe@1.0.0, unpipe@~1.0.0: | ||||||
|   version "1.0.0" |   version "1.0.0" | ||||||
|   resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" |   resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" | ||||||
|   integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw= |   integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== | ||||||
|  |  | ||||||
| utils-merge@1.0.1: | utils-merge@1.0.1, utils-merge@^1.0.1: | ||||||
|   version "1.0.1" |   version "1.0.1" | ||||||
|   resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" |   resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" | ||||||
|   integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= |   integrity sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA== | ||||||
|  |  | ||||||
| vary@~1.1.2: | vary@^1.1.2, vary@~1.1.2: | ||||||
|   version "1.1.2" |   version "1.1.2" | ||||||
|   resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" |   resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" | ||||||
|   integrity sha1-IpnwLG3tMNSllhsLn3RSShj2NPw= |   integrity sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg== | ||||||
|  |  | ||||||
|  | wrappy@1: | ||||||
|  |   version "1.0.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" | ||||||
|  |   integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ import * as core from '@actions/core'; | |||||||
| import * as exec from '@actions/exec'; | import * as exec from '@actions/exec'; | ||||||
| import * as tc from '@actions/tool-cache'; | import * as tc from '@actions/tool-cache'; | ||||||
| import * as cache from '@actions/cache'; | import * as cache from '@actions/cache'; | ||||||
|  | import * as io from '@actions/io'; | ||||||
|  |  | ||||||
| import fs from 'fs'; | import fs from 'fs'; | ||||||
| import path from 'path'; | import path from 'path'; | ||||||
| @@ -24,11 +25,13 @@ describe('main tests', () => { | |||||||
|   let startGroupSpy: jest.SpyInstance; |   let startGroupSpy: jest.SpyInstance; | ||||||
|   let endGroupSpy: jest.SpyInstance; |   let endGroupSpy: jest.SpyInstance; | ||||||
|  |  | ||||||
|  |   let whichSpy: jest.SpyInstance; | ||||||
|  |  | ||||||
|   let existsSpy: jest.SpyInstance; |   let existsSpy: jest.SpyInstance; | ||||||
|  |  | ||||||
|   let getExecOutputSpy: jest.SpyInstance; |   let getExecOutputSpy: jest.SpyInstance; | ||||||
|  |  | ||||||
|   let parseNodeVersionSpy: jest.SpyInstance; |   let getNodeVersionFromFileSpy: jest.SpyInstance; | ||||||
|   let cnSpy: jest.SpyInstance; |   let cnSpy: jest.SpyInstance; | ||||||
|   let findSpy: jest.SpyInstance; |   let findSpy: jest.SpyInstance; | ||||||
|   let isCacheActionAvailable: jest.SpyInstance; |   let isCacheActionAvailable: jest.SpyInstance; | ||||||
| @@ -41,6 +44,7 @@ describe('main tests', () => { | |||||||
|     // node |     // node | ||||||
|     os = {}; |     os = {}; | ||||||
|     console.log('::stop-commands::stoptoken'); |     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_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 |     process.env['GITHUB_OUTPUT'] = ''; // Stub out ENV file functionality so we can verify it writes to standard out | ||||||
|     infoSpy = jest.spyOn(core, 'info'); |     infoSpy = jest.spyOn(core, 'info'); | ||||||
| @@ -56,18 +60,18 @@ describe('main tests', () => { | |||||||
|     inSpy = jest.spyOn(core, 'getInput'); |     inSpy = jest.spyOn(core, 'getInput'); | ||||||
|     inSpy.mockImplementation(name => inputs[name]); |     inSpy.mockImplementation(name => inputs[name]); | ||||||
|  |  | ||||||
|  |     whichSpy = jest.spyOn(io, 'which'); | ||||||
|  |  | ||||||
|     getExecOutputSpy = jest.spyOn(exec, 'getExecOutput'); |     getExecOutputSpy = jest.spyOn(exec, 'getExecOutput'); | ||||||
|  |  | ||||||
|     findSpy = jest.spyOn(tc, 'find'); |     findSpy = jest.spyOn(tc, 'find'); | ||||||
|  |  | ||||||
|     isCacheActionAvailable = jest.spyOn(cache, 'isFeatureAvailable'); |     isCacheActionAvailable = jest.spyOn(cache, 'isFeatureAvailable'); | ||||||
|  |  | ||||||
|     existsSpy = jest.spyOn(fs, 'existsSync'); |  | ||||||
|  |  | ||||||
|     cnSpy = jest.spyOn(process.stdout, 'write'); |     cnSpy = jest.spyOn(process.stdout, 'write'); | ||||||
|     cnSpy.mockImplementation(line => { |     cnSpy.mockImplementation(line => { | ||||||
|       // uncomment to debug |       // uncomment to debug | ||||||
|       // process.stderr.write('write:' + line + '\n'); |       process.stderr.write('write:' + line + '\n'); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     setupNodeJsSpy = jest.spyOn(OfficialBuilds.prototype, 'setupNodeJs'); |     setupNodeJsSpy = jest.spyOn(OfficialBuilds.prototype, 'setupNodeJs'); | ||||||
| @@ -85,7 +89,7 @@ describe('main tests', () => { | |||||||
|     jest.restoreAllMocks(); |     jest.restoreAllMocks(); | ||||||
|   }, 100000); |   }, 100000); | ||||||
|  |  | ||||||
|   describe('parseNodeVersionFile', () => { |   describe('getNodeVersionFromFile', () => { | ||||||
|     each` |     each` | ||||||
|       contents                                     | expected |       contents                                     | expected | ||||||
|       ${'12'}                                      | ${'12'} |       ${'12'}                                      | ${'12'} | ||||||
| @@ -100,10 +104,27 @@ describe('main tests', () => { | |||||||
|       ${'unknown format'}                          | ${'unknown format'} |       ${'unknown format'}                          | ${'unknown format'} | ||||||
|       ${'  14.1.0  '}                              | ${'14.1.0'} |       ${'  14.1.0  '}                              | ${'14.1.0'} | ||||||
|       ${'{"volta": {"node": ">=14.0.0 <=17.0.0"}}'}| ${'>=14.0.0 <=17.0.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'} |       ${'{"engines": {"node": "17.0.0"}}'}         | ${'17.0.0'} | ||||||
|       ${'{}'}                                      | ${null} |       ${'{}'}                                      | ${null} | ||||||
|     `.it('parses "$contents"', ({contents, expected}) => { |     `.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); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -126,6 +147,10 @@ describe('main tests', () => { | |||||||
|         return {stdout: obj[command], stderr: '', exitCode: 0}; |         return {stdout: obj[command], stderr: '', exitCode: 0}; | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|  |       whichSpy.mockImplementation(cmd => { | ||||||
|  |         return `some/${cmd}/path`; | ||||||
|  |       }); | ||||||
|  |  | ||||||
|       await util.printEnvDetailsAndSetOutput(); |       await util.printEnvDetailsAndSetOutput(); | ||||||
|  |  | ||||||
|       expect(setOutputSpy).toHaveBeenCalledWith('node-version', obj['node']); |       expect(setOutputSpy).toHaveBeenCalledWith('node-version', obj['node']); | ||||||
| @@ -142,10 +167,17 @@ describe('main tests', () => { | |||||||
|  |  | ||||||
|   describe('node-version-file flag', () => { |   describe('node-version-file flag', () => { | ||||||
|     beforeEach(() => { |     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 |       // Arrange | ||||||
|       inputs['node-version'] = '12'; |       inputs['node-version'] = '12'; | ||||||
|  |  | ||||||
| @@ -153,107 +185,54 @@ describe('main tests', () => { | |||||||
|       await main.run(); |       await main.run(); | ||||||
|  |  | ||||||
|       // Assert |       // Assert | ||||||
|       expect(parseNodeVersionSpy).toHaveBeenCalledTimes(0); |       expect(inputs['node-version']).toBeDefined(); | ||||||
|     }, 10000); |       expect(inputs['node-version-file']).toBeDefined(); | ||||||
|  |       expect(getNodeVersionFromFileSpy).not.toHaveBeenCalled(); | ||||||
|     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(warningSpy).toHaveBeenCalledWith( |       expect(warningSpy).toHaveBeenCalledWith( | ||||||
|         'Both node-version and node-version-file inputs are specified, only node-version will be used' |         '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 () => { |     it('does not read node-version-file if node-version-file is not provided', async () => { | ||||||
|       const versionFile = '.nvmrc'; |       // Arrange | ||||||
|       const versionFilePath = path.join(__dirname, '..', versionFile); |       delete inputs['node-version-file']; | ||||||
|       inputs['node-version-file'] = versionFile; |  | ||||||
|  |  | ||||||
|       inSpy.mockImplementation(name => inputs[name]); |       // Act | ||||||
|       existsSpy.mockImplementationOnce( |       await main.run(); | ||||||
|         input => input === path.join(__dirname, 'data', versionFile) |  | ||||||
|  |       // 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 |       // Act | ||||||
|       await main.run(); |       await main.run(); | ||||||
|  |  | ||||||
|       // Assert |       // Assert | ||||||
|       expect(existsSpy).toHaveBeenCalled(); |       expect(getNodeVersionFromFileSpy).toHaveBeenCalled(); | ||||||
|       expect(existsSpy).toHaveReturnedWith(false); |  | ||||||
|       expect(parseNodeVersionSpy).not.toHaveBeenCalled(); |  | ||||||
|       expect(cnSpy).toHaveBeenCalledWith( |       expect(cnSpy).toHaveBeenCalledWith( | ||||||
|         `::error::The specified node version file at: ${versionFilePath} does not exist${osm.EOL}` |         `::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'); |     const toolPath = path.normalize('/cache/node/12.16.2/x64'); | ||||||
|     exSpy.mockImplementation(async () => '/some/other/temp/path'); |     exSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|     cacheSpy.mockImplementation(async () => toolPath); |     cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |     whichSpy.mockImplementation(cmd => { | ||||||
|  |       return `some/${cmd}/path`; | ||||||
|  |     }); | ||||||
|  |  | ||||||
|     await main.run(); |     await main.run(); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										1436
									
								
								dist/cache-save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1436
									
								
								dist/cache-save/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1511
									
								
								dist/setup/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1511
									
								
								dist/setup/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -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 | ## 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). | 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). | ||||||
|   | |||||||
							
								
								
									
										174
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										174
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -9,34 +9,34 @@ | |||||||
|       "version": "4.0.0", |       "version": "4.0.0", | ||||||
|       "license": "MIT", |       "license": "MIT", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@actions/cache": "^3.0.4", |         "@actions/cache": "^3.2.4", | ||||||
|         "@actions/core": "^1.10.0", |         "@actions/core": "^1.10.0", | ||||||
|         "@actions/exec": "^1.1.0", |         "@actions/exec": "^1.1.0", | ||||||
|         "@actions/github": "^5.1.1", |         "@actions/github": "^5.1.1", | ||||||
|         "@actions/glob": "^0.4.0", |         "@actions/glob": "^0.4.0", | ||||||
|         "@actions/http-client": "^2.1.1", |         "@actions/http-client": "^2.2.1", | ||||||
|         "@actions/io": "^1.0.2", |         "@actions/io": "^1.0.2", | ||||||
|         "@actions/tool-cache": "^2.0.1", |         "@actions/tool-cache": "^2.0.1", | ||||||
|         "semver": "^7.5.4", |         "semver": "^7.6.0", | ||||||
|         "uuid": "^9.0.1" |         "uuid": "^9.0.1" | ||||||
|       }, |       }, | ||||||
|       "devDependencies": { |       "devDependencies": { | ||||||
|         "@types/jest": "^29.5.5", |         "@types/jest": "^29.5.12", | ||||||
|         "@types/node": "^20.8.2", |         "@types/node": "^20.11.25", | ||||||
|         "@types/semver": "^7.5.3", |         "@types/semver": "^7.5.8", | ||||||
|         "@typescript-eslint/eslint-plugin": "^5.54.0", |         "@typescript-eslint/eslint-plugin": "^5.54.0", | ||||||
|         "@typescript-eslint/parser": "^5.54.0", |         "@typescript-eslint/parser": "^5.54.0", | ||||||
|         "@vercel/ncc": "^0.38.0", |         "@vercel/ncc": "^0.38.0", | ||||||
|         "eslint": "^8.35.0", |         "eslint": "^8.57.0", | ||||||
|         "eslint-config-prettier": "^8.6.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", |         "eslint-plugin-node": "^11.1.0", | ||||||
|         "jest": "^29.7.0", |         "jest": "^29.7.0", | ||||||
|         "jest-circus": "^29.7.0", |         "jest-circus": "^29.7.0", | ||||||
|         "jest-each": "^29.7.0", |         "jest-each": "^29.7.0", | ||||||
|         "prettier": "^2.8.4", |         "prettier": "^2.8.4", | ||||||
|         "ts-jest": "^29.1.1", |         "ts-jest": "^29.1.2", | ||||||
|         "typescript": "^5.2.2" |         "typescript": "^5.4.2" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@aashutoshrathi/word-wrap": { |     "node_modules/@aashutoshrathi/word-wrap": { | ||||||
| @@ -49,9 +49,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@actions/cache": { |     "node_modules/@actions/cache": { | ||||||
|       "version": "3.2.2", |       "version": "3.2.4", | ||||||
|       "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-3.2.2.tgz", |       "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-3.2.4.tgz", | ||||||
|       "integrity": "sha512-6D0Jq5JrLZRQ3VApeQwQkkV20ZZXjXsHNYXd9VjNUdi9E0h93wESpxfMJ2JWLCUCgHNLcfY0v3GjNM+2FdRMlg==", |       "integrity": "sha512-RuHnwfcDagtX+37s0ZWy7clbOfnZ7AlDJQ7k/9rzt2W4Gnwde3fa/qjSjVuz4vLcLIpc7fUob27CMrqiWZytYA==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@actions/core": "^1.10.0", |         "@actions/core": "^1.10.0", | ||||||
|         "@actions/exec": "^1.0.1", |         "@actions/exec": "^1.0.1", | ||||||
| @@ -61,7 +61,7 @@ | |||||||
|         "@azure/abort-controller": "^1.1.0", |         "@azure/abort-controller": "^1.1.0", | ||||||
|         "@azure/ms-rest-js": "^2.6.0", |         "@azure/ms-rest-js": "^2.6.0", | ||||||
|         "@azure/storage-blob": "^12.13.0", |         "@azure/storage-blob": "^12.13.0", | ||||||
|         "semver": "^6.1.0", |         "semver": "^6.3.1", | ||||||
|         "uuid": "^3.3.3" |         "uuid": "^3.3.3" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
| @@ -137,9 +137,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@actions/http-client": { |     "node_modules/@actions/http-client": { | ||||||
|       "version": "2.2.0", |       "version": "2.2.1", | ||||||
|       "resolved": "https://registry.npmjs.org/@actions/http-client/-/http-client-2.2.0.tgz", |       "resolved": "https://registry.npmjs.org/@actions/http-client/-/http-client-2.2.1.tgz", | ||||||
|       "integrity": "sha512-q+epW0trjVUUHboliPb4UF9g2msf+w61b32tAkFEwL/IwP0DQWgbCMM0Hbe3e3WXSKz5VcUXbzJQgy8Hkra/Lg==", |       "integrity": "sha512-KhC/cZsq7f8I4LfZSJKgCvEwfkE8o1538VoBeoGzokVLLnbFDEAdFD3UhoMklxo2un9NJVBdANOresx7vTHlHw==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "tunnel": "^0.0.6", |         "tunnel": "^0.0.6", | ||||||
|         "undici": "^5.25.4" |         "undici": "^5.25.4" | ||||||
| @@ -1042,9 +1042,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@eslint/eslintrc": { |     "node_modules/@eslint/eslintrc": { | ||||||
|       "version": "2.1.2", |       "version": "2.1.4", | ||||||
|       "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.2.tgz", |       "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", | ||||||
|       "integrity": "sha512-+wvgpDsrB1YqAMdEUCcnTlpfVBH7Vqn6A/NT3D8WVXFIaKMlErPIZT3oCIAVCOtarRpMtelZLqJeU3t7WY6X6g==", |       "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "ajv": "^6.12.4", |         "ajv": "^6.12.4", | ||||||
| @@ -1065,9 +1065,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@eslint/js": { |     "node_modules/@eslint/js": { | ||||||
|       "version": "8.52.0", |       "version": "8.57.0", | ||||||
|       "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.52.0.tgz", |       "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", | ||||||
|       "integrity": "sha512-mjZVbpaeMZludF2fsWLD0Z9gCref1Tk4i9+wddjRvpUNqqcndPkBD09N/Mapey0b3jaXbLm2kICwFv2E64QinA==", |       "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": "^12.22.0 || ^14.17.0 || >=16.0.0" |         "node": "^12.22.0 || ^14.17.0 || >=16.0.0" | ||||||
| @@ -1082,13 +1082,13 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@humanwhocodes/config-array": { |     "node_modules/@humanwhocodes/config-array": { | ||||||
|       "version": "0.11.13", |       "version": "0.11.14", | ||||||
|       "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.13.tgz", |       "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", | ||||||
|       "integrity": "sha512-JSBDMiDKSzQVngfRjOdFXgFfklaXI4K9nLF49Auh21lmBWRLIK3+xTErTWD4KU54pb6coM6ESE7Awz/FNU3zgQ==", |       "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@humanwhocodes/object-schema": "^2.0.1", |         "@humanwhocodes/object-schema": "^2.0.2", | ||||||
|         "debug": "^4.1.1", |         "debug": "^4.3.1", | ||||||
|         "minimatch": "^3.0.5" |         "minimatch": "^3.0.5" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
| @@ -1109,9 +1109,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@humanwhocodes/object-schema": { |     "node_modules/@humanwhocodes/object-schema": { | ||||||
|       "version": "2.0.1", |       "version": "2.0.2", | ||||||
|       "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.1.tgz", |       "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", | ||||||
|       "integrity": "sha512-dvuCeX5fC9dXgJn9t+X5atfmgQAzUOWqS1254Gh0m6i8wKd10ebXkfNKiRK+1GWi/yTvvLDHpoxLr0xxxeslWw==", |       "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "node_modules/@istanbuljs/load-nyc-config": { |     "node_modules/@istanbuljs/load-nyc-config": { | ||||||
| @@ -1791,9 +1791,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@types/jest": { |     "node_modules/@types/jest": { | ||||||
|       "version": "29.5.6", |       "version": "29.5.12", | ||||||
|       "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.6.tgz", |       "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.12.tgz", | ||||||
|       "integrity": "sha512-/t9NnzkOpXb4Nfvg17ieHE6EeSjDS2SGSpNYfoLbUAeL/EOueU/RSdOWFpfQTXBEM7BguYW1XQ0EbM+6RlIh6w==", |       "integrity": "sha512-eDC8bTvT/QhYdxJAulQikueigY5AsdBRH2yDKW3yveW7svY3+DzN84/2NUgkw10RTiJbWqZrTtoGVdYlvFJdLw==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "expect": "^29.0.0", |         "expect": "^29.0.0", | ||||||
| @@ -1807,11 +1807,11 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "node_modules/@types/node": { |     "node_modules/@types/node": { | ||||||
|       "version": "20.8.7", |       "version": "20.11.25", | ||||||
|       "resolved": "https://registry.npmjs.org/@types/node/-/node-20.8.7.tgz", |       "resolved": "https://registry.npmjs.org/@types/node/-/node-20.11.25.tgz", | ||||||
|       "integrity": "sha512-21TKHHh3eUHIi2MloeptJWALuCu5H7HQTdTrWIFReA8ad+aggoX+lRes3ex7/FtpC+sVUpFMQ+QTfYr74mruiQ==", |       "integrity": "sha512-TBHyJxk2b7HceLVGFcpAUjsa5zIdsPWlR6XHfyGzd0SFu+/NFgQgMAl96MSDZgQDvJAvV6BKsFOrt6zIL09JDw==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "undici-types": "~5.25.1" |         "undici-types": "~5.26.4" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@types/node-fetch": { |     "node_modules/@types/node-fetch": { | ||||||
| @@ -1837,9 +1837,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@types/semver": { |     "node_modules/@types/semver": { | ||||||
|       "version": "7.5.4", |       "version": "7.5.8", | ||||||
|       "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.4.tgz", |       "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.8.tgz", | ||||||
|       "integrity": "sha512-MMzuxN3GdFwskAnb6fz0orFvhfqi752yjaXylr0Rp4oDg5H0Zn1IuyRhDVvYOwAXoJirx2xuS16I3WjxnAIHiQ==", |       "integrity": "sha512-I8EUhyrgfLrcTkzV3TSsGyl1tSuPrEDzr0yd5m90UgNxQkyDXULk3b6MlQqTCpZpNtWe1K0hzclnZkTcLBe2UQ==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "node_modules/@types/stack-utils": { |     "node_modules/@types/stack-utils": { | ||||||
| @@ -2086,9 +2086,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/acorn": { |     "node_modules/acorn": { | ||||||
|       "version": "8.10.0", |       "version": "8.11.3", | ||||||
|       "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", |       "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", | ||||||
|       "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", |       "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "bin": { |       "bin": { | ||||||
|         "acorn": "bin/acorn" |         "acorn": "bin/acorn" | ||||||
| @@ -2342,12 +2342,12 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/braces": { |     "node_modules/braces": { | ||||||
|       "version": "3.0.2", |       "version": "3.0.3", | ||||||
|       "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", |       "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", | ||||||
|       "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", |       "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "fill-range": "^7.0.1" |         "fill-range": "^7.1.1" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=8" |         "node": ">=8" | ||||||
| @@ -2757,16 +2757,16 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/eslint": { |     "node_modules/eslint": { | ||||||
|       "version": "8.52.0", |       "version": "8.57.0", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.52.0.tgz", |       "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", | ||||||
|       "integrity": "sha512-zh/JHnaixqHZsolRB/w9/02akBk9EPrOs9JwcTP2ek7yL5bVvXuRariiaAjjoJ5DvuwQ1WAE/HsMz+w17YgBCg==", |       "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@eslint-community/eslint-utils": "^4.2.0", |         "@eslint-community/eslint-utils": "^4.2.0", | ||||||
|         "@eslint-community/regexpp": "^4.6.1", |         "@eslint-community/regexpp": "^4.6.1", | ||||||
|         "@eslint/eslintrc": "^2.1.2", |         "@eslint/eslintrc": "^2.1.4", | ||||||
|         "@eslint/js": "8.52.0", |         "@eslint/js": "8.57.0", | ||||||
|         "@humanwhocodes/config-array": "^0.11.13", |         "@humanwhocodes/config-array": "^0.11.14", | ||||||
|         "@humanwhocodes/module-importer": "^1.0.1", |         "@humanwhocodes/module-importer": "^1.0.1", | ||||||
|         "@nodelib/fs.walk": "^1.2.8", |         "@nodelib/fs.walk": "^1.2.8", | ||||||
|         "@ungap/structured-clone": "^1.2.0", |         "@ungap/structured-clone": "^1.2.0", | ||||||
| @@ -2843,9 +2843,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/eslint-plugin-jest": { |     "node_modules/eslint-plugin-jest": { | ||||||
|       "version": "27.4.3", |       "version": "27.9.0", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-27.4.3.tgz", |       "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-27.9.0.tgz", | ||||||
|       "integrity": "sha512-7S6SmmsHsgIm06BAGCAxL+ABd9/IB3MWkz2pudj6Qqor2y1qQpWPfuFU4SG9pWj4xDjF0e+D7Llh5useuSzAZw==", |       "integrity": "sha512-QIT7FH7fNmd9n4se7FFKHbsLKGQiw885Ds6Y/sxKgCZ6natwCsXdgPOADnYVxN2QrRweF0FZWbJ6S7Rsn7llug==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@typescript-eslint/utils": "^5.10.0" |         "@typescript-eslint/utils": "^5.10.0" | ||||||
| @@ -2854,7 +2854,7 @@ | |||||||
|         "node": "^14.15.0 || ^16.10.0 || >=18.0.0" |         "node": "^14.15.0 || ^16.10.0 || >=18.0.0" | ||||||
|       }, |       }, | ||||||
|       "peerDependencies": { |       "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", |         "eslint": "^7.0.0 || ^8.0.0", | ||||||
|         "jest": "*" |         "jest": "*" | ||||||
|       }, |       }, | ||||||
| @@ -3201,9 +3201,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/fill-range": { |     "node_modules/fill-range": { | ||||||
|       "version": "7.0.1", |       "version": "7.1.1", | ||||||
|       "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", |       "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", | ||||||
|       "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", |       "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "to-regex-range": "^5.0.1" |         "to-regex-range": "^5.0.1" | ||||||
| @@ -3362,9 +3362,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/globals": { |     "node_modules/globals": { | ||||||
|       "version": "13.23.0", |       "version": "13.24.0", | ||||||
|       "resolved": "https://registry.npmjs.org/globals/-/globals-13.23.0.tgz", |       "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", | ||||||
|       "integrity": "sha512-XAmF0RjlrjY23MA51q3HltdlGxUpXPvg0GioKiD9X6HD28iMjo2dKC8Vqwm7lne4GNr78+RHTfliktR6ZH09wA==", |       "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "type-fest": "^0.20.2" |         "type-fest": "^0.20.2" | ||||||
| @@ -4429,12 +4429,12 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/micromatch": { |     "node_modules/micromatch": { | ||||||
|       "version": "4.0.5", |       "version": "4.0.8", | ||||||
|       "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", |       "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz", | ||||||
|       "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", |       "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "braces": "^3.0.2", |         "braces": "^3.0.3", | ||||||
|         "picomatch": "^2.3.1" |         "picomatch": "^2.3.1" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
| @@ -4864,9 +4864,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/punycode": { |     "node_modules/punycode": { | ||||||
|       "version": "2.3.0", |       "version": "2.3.1", | ||||||
|       "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", |       "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", | ||||||
|       "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", |       "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">=6" |         "node": ">=6" | ||||||
| @@ -5045,9 +5045,9 @@ | |||||||
|       "integrity": "sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA==" |       "integrity": "sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA==" | ||||||
|     }, |     }, | ||||||
|     "node_modules/semver": { |     "node_modules/semver": { | ||||||
|       "version": "7.5.4", |       "version": "7.6.0", | ||||||
|       "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", |       "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", | ||||||
|       "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", |       "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "lru-cache": "^6.0.0" |         "lru-cache": "^6.0.0" | ||||||
|       }, |       }, | ||||||
| @@ -5308,9 +5308,9 @@ | |||||||
|       "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" |       "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" | ||||||
|     }, |     }, | ||||||
|     "node_modules/ts-jest": { |     "node_modules/ts-jest": { | ||||||
|       "version": "29.1.1", |       "version": "29.1.2", | ||||||
|       "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.1.1.tgz", |       "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.1.2.tgz", | ||||||
|       "integrity": "sha512-D6xjnnbP17cC85nliwGiL+tpoKN0StpgE0TeOjXQTU6MVCfsB4v7aW05CgQ/1OywGb0x/oy9hHFnN+sczTiRaA==", |       "integrity": "sha512-br6GJoH/WUX4pu7FbZXuWGKGNDuU7b8Uj77g/Sp7puZV6EXzuByl6JrECvm0MzVzSTkSHWTihsXt+5XYER5b+g==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "bs-logger": "0.x", |         "bs-logger": "0.x", | ||||||
| @@ -5326,7 +5326,7 @@ | |||||||
|         "ts-jest": "cli.js" |         "ts-jest": "cli.js" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": "^14.15.0 || ^16.10.0 || >=18.0.0" |         "node": "^16.10.0 || ^18.0.0 || >=20.0.0" | ||||||
|       }, |       }, | ||||||
|       "peerDependencies": { |       "peerDependencies": { | ||||||
|         "@babel/core": ">=7.0.0-beta.0 <8", |         "@babel/core": ">=7.0.0-beta.0 <8", | ||||||
| @@ -5418,9 +5418,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/typescript": { |     "node_modules/typescript": { | ||||||
|       "version": "5.2.2", |       "version": "5.4.2", | ||||||
|       "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.2.2.tgz", |       "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.2.tgz", | ||||||
|       "integrity": "sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w==", |       "integrity": "sha512-+2/g0Fds1ERlP6JsakQQDXjZdZMM+rqpamFZJEKh4kwTIn3iDkgKtby0CeNd5ATNZ4Ry1ax15TMx0W2V+miizQ==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "bin": { |       "bin": { | ||||||
|         "tsc": "bin/tsc", |         "tsc": "bin/tsc", | ||||||
| @@ -5431,9 +5431,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/undici": { |     "node_modules/undici": { | ||||||
|       "version": "5.26.5", |       "version": "5.28.4", | ||||||
|       "resolved": "https://registry.npmjs.org/undici/-/undici-5.26.5.tgz", |       "resolved": "https://registry.npmjs.org/undici/-/undici-5.28.4.tgz", | ||||||
|       "integrity": "sha512-cSb4bPFd5qgR7qr2jYAi0hlX9n5YKK2ONKkLFkxl+v/9BvC0sOpZjBHDBSXc5lWAf5ty9oZdRXytBIHzgUcerw==", |       "integrity": "sha512-72RFADWFqKmUb2hmmvNODKL3p9hcB6Gt2DOQMis1SEBaV6a4MH8soBvzg+95CYhCKPFedut2JY9bMfrDl9D23g==", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@fastify/busboy": "^2.0.0" |         "@fastify/busboy": "^2.0.0" | ||||||
|       }, |       }, | ||||||
| @@ -5442,9 +5442,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/undici-types": { |     "node_modules/undici-types": { | ||||||
|       "version": "5.25.3", |       "version": "5.26.5", | ||||||
|       "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.25.3.tgz", |       "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", | ||||||
|       "integrity": "sha512-Ga1jfYwRn7+cP9v8auvEXN1rX3sWqlayd4HP7OKk4mZWylEmu3KzXDUGrQUN6Ol7qo1gPvB2e5gX6udnyEPgdA==" |       "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==" | ||||||
|     }, |     }, | ||||||
|     "node_modules/universal-user-agent": { |     "node_modules/universal-user-agent": { | ||||||
|       "version": "6.0.0", |       "version": "6.0.0", | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								package.json
									
									
									
									
									
								
							| @@ -25,33 +25,33 @@ | |||||||
|   "author": "GitHub", |   "author": "GitHub", | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@actions/cache": "^3.0.4", |     "@actions/cache": "^3.2.4", | ||||||
|     "@actions/core": "^1.10.0", |     "@actions/core": "^1.10.0", | ||||||
|     "@actions/exec": "^1.1.0", |     "@actions/exec": "^1.1.0", | ||||||
|     "@actions/github": "^5.1.1", |     "@actions/github": "^5.1.1", | ||||||
|     "@actions/glob": "^0.4.0", |     "@actions/glob": "^0.4.0", | ||||||
|     "@actions/http-client": "^2.1.1", |     "@actions/http-client": "^2.2.1", | ||||||
|     "@actions/io": "^1.0.2", |     "@actions/io": "^1.0.2", | ||||||
|     "@actions/tool-cache": "^2.0.1", |     "@actions/tool-cache": "^2.0.1", | ||||||
|     "semver": "^7.5.4", |     "semver": "^7.6.0", | ||||||
|     "uuid": "^9.0.1" |     "uuid": "^9.0.1" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/jest": "^29.5.5", |     "@types/jest": "^29.5.12", | ||||||
|     "@types/node": "^20.8.2", |     "@types/node": "^20.11.25", | ||||||
|     "@types/semver": "^7.5.3", |     "@types/semver": "^7.5.8", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.54.0", |     "@typescript-eslint/eslint-plugin": "^5.54.0", | ||||||
|     "@typescript-eslint/parser": "^5.54.0", |     "@typescript-eslint/parser": "^5.54.0", | ||||||
|     "@vercel/ncc": "^0.38.0", |     "@vercel/ncc": "^0.38.0", | ||||||
|     "eslint": "^8.35.0", |     "eslint": "^8.57.0", | ||||||
|     "eslint-config-prettier": "^8.6.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", |     "eslint-plugin-node": "^11.1.0", | ||||||
|     "jest": "^29.7.0", |     "jest": "^29.7.0", | ||||||
|     "jest-circus": "^29.7.0", |     "jest-circus": "^29.7.0", | ||||||
|     "jest-each": "^29.7.0", |     "jest-each": "^29.7.0", | ||||||
|     "prettier": "^2.8.4", |     "prettier": "^2.8.4", | ||||||
|     "ts-jest": "^29.1.1", |     "ts-jest": "^29.1.2", | ||||||
|     "typescript": "^5.2.2" |     "typescript": "^5.4.2" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,6 +3,7 @@ import * as core from '@actions/core'; | |||||||
| import * as glob from '@actions/glob'; | import * as glob from '@actions/glob'; | ||||||
| import path from 'path'; | import path from 'path'; | ||||||
| import fs from 'fs'; | import fs from 'fs'; | ||||||
|  | import os from 'os'; | ||||||
|  |  | ||||||
| import {State} from './constants'; | import {State} from './constants'; | ||||||
| import { | import { | ||||||
| @@ -21,6 +22,7 @@ export const restoreCache = async ( | |||||||
|     throw new Error(`Caching for '${packageManager}' is not supported`); |     throw new Error(`Caching for '${packageManager}' is not supported`); | ||||||
|   } |   } | ||||||
|   const platform = process.env.RUNNER_OS; |   const platform = process.env.RUNNER_OS; | ||||||
|  |   const arch = os.arch(); | ||||||
|  |  | ||||||
|   const cachePaths = await getCacheDirectories( |   const cachePaths = await getCacheDirectories( | ||||||
|     packageManagerInfo, |     packageManagerInfo, | ||||||
| @@ -38,7 +40,7 @@ export const restoreCache = async ( | |||||||
|     ); |     ); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   const keyPrefix = `node-cache-${platform}-${packageManager}`; |   const keyPrefix = `node-cache-${platform}-${arch}-${packageManager}`; | ||||||
|   const primaryKey = `${keyPrefix}-${fileHash}`; |   const primaryKey = `${keyPrefix}-${fileHash}`; | ||||||
|   core.debug(`primary key is ${primaryKey}`); |   core.debug(`primary key is ${primaryKey}`); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -295,7 +295,13 @@ export function isGhes(): boolean { | |||||||
|   const ghUrl = new URL( |   const ghUrl = new URL( | ||||||
|     process.env['GITHUB_SERVER_URL'] || 'https://github.com' |     process.env['GITHUB_SERVER_URL'] || 'https://github.com' | ||||||
|   ); |   ); | ||||||
|   return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'; |  | ||||||
|  |   const hostname = ghUrl.hostname.trimEnd().toUpperCase(); | ||||||
|  |   const isGitHubHost = hostname === 'GITHUB.COM'; | ||||||
|  |   const isGitHubEnterpriseCloudHost = hostname.endsWith('.GHE.COM'); | ||||||
|  |   const isLocalHost = hostname.endsWith('.LOCALHOST'); | ||||||
|  |  | ||||||
|  |   return !isGitHubHost && !isGitHubEnterpriseCloudHost && !isLocalHost; | ||||||
| } | } | ||||||
|  |  | ||||||
| export function isCacheFeatureAvailable(): boolean { | export function isCacheFeatureAvailable(): boolean { | ||||||
|   | |||||||
| @@ -112,7 +112,11 @@ export default abstract class BaseDistribution { | |||||||
|         ? `node-v${version}-win-${osArch}` |         ? `node-v${version}-win-${osArch}` | ||||||
|         : `node-v${version}-${this.osPlat}-${osArch}`; |         : `node-v${version}-${this.osPlat}-${osArch}`; | ||||||
|     const urlFileName: string = |     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 initialUrl = this.getDistributionUrl(); | ||||||
|     const url = `${initialUrl}/v${version}/${urlFileName}`; |     const url = `${initialUrl}/v${version}/${urlFileName}`; | ||||||
|  |  | ||||||
| @@ -146,7 +150,7 @@ export default abstract class BaseDistribution { | |||||||
|       throw err; |       throw err; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     const toolPath = await this.extractArchive(downloadPath, info); |     const toolPath = await this.extractArchive(downloadPath, info, true); | ||||||
|     core.info('Done'); |     core.info('Done'); | ||||||
|  |  | ||||||
|     return toolPath; |     return toolPath; | ||||||
| @@ -206,7 +210,8 @@ export default abstract class BaseDistribution { | |||||||
|  |  | ||||||
|   protected async extractArchive( |   protected async extractArchive( | ||||||
|     downloadPath: string, |     downloadPath: string, | ||||||
|     info: INodeVersionInfo | null |     info: INodeVersionInfo | null, | ||||||
|  |     isOfficialArchive?: boolean | ||||||
|   ) { |   ) { | ||||||
|     // |     // | ||||||
|     // Extract |     // Extract | ||||||
| @@ -215,12 +220,24 @@ export default abstract class BaseDistribution { | |||||||
|     let extPath: string; |     let extPath: string; | ||||||
|     info = info || ({} as INodeVersionInfo); // satisfy compiler, never null when reaches here |     info = info || ({} as INodeVersionInfo); // satisfy compiler, never null when reaches here | ||||||
|     if (this.osPlat == 'win32') { |     if (this.osPlat == 'win32') { | ||||||
|  |       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' && isOfficialArchive) { | ||||||
|  |         const renamedArchive = `${downloadPath}.zip`; | ||||||
|  |         fs.renameSync(downloadPath, renamedArchive); | ||||||
|  |         extPath = await tc.extractZip(renamedArchive); | ||||||
|  |       } else { | ||||||
|         const _7zPath = path.join(__dirname, '../..', 'externals', '7zr.exe'); |         const _7zPath = path.join(__dirname, '../..', 'externals', '7zr.exe'); | ||||||
|         extPath = await tc.extract7z(downloadPath, undefined, _7zPath); |         extPath = await tc.extract7z(downloadPath, undefined, _7zPath); | ||||||
|  |       } | ||||||
|       // 7z extracts to folder matching file name |       // 7z extracts to folder matching file name | ||||||
|       const nestedPath = path.join( |       const nestedPath = path.join( | ||||||
|         extPath, |         extPath, | ||||||
|         path.basename(info.fileName, '.7z') |         path.basename(info.fileName, extension) | ||||||
|       ); |       ); | ||||||
|       if (fs.existsSync(nestedPath)) { |       if (fs.existsSync(nestedPath)) { | ||||||
|         extPath = nestedPath; |         extPath = nestedPath; | ||||||
| @@ -260,7 +277,11 @@ export default abstract class BaseDistribution { | |||||||
|         dataFileName = `osx-${osArch}-tar`; |         dataFileName = `osx-${osArch}-tar`; | ||||||
|         break; |         break; | ||||||
|       case 'win32': |       case 'win32': | ||||||
|  |         if (this.nodeInfo.arch === 'arm64') { | ||||||
|  |           dataFileName = `win-${osArch}-zip`; | ||||||
|  |         } else { | ||||||
|           dataFileName = `win-${osArch}-exe`; |           dataFileName = `win-${osArch}-exe`; | ||||||
|  |         } | ||||||
|         break; |         break; | ||||||
|       default: |       default: | ||||||
|         throw new Error(`Unexpected OS '${this.osPlat}'`); |         throw new Error(`Unexpected OS '${this.osPlat}'`); | ||||||
|   | |||||||
| @@ -88,7 +88,11 @@ export default class OfficialBuilds extends BaseDistribution { | |||||||
|         ); |         ); | ||||||
|  |  | ||||||
|         if (downloadPath) { |         if (downloadPath) { | ||||||
|           toolPath = await this.extractArchive(downloadPath, versionInfo); |           toolPath = await this.extractArchive( | ||||||
|  |             downloadPath, | ||||||
|  |             versionInfo, | ||||||
|  |             false | ||||||
|  |           ); | ||||||
|         } |         } | ||||||
|       } else { |       } else { | ||||||
|         core.info( |         core.info( | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								src/main.ts
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								src/main.ts
									
									
									
									
									
								
							| @@ -1,6 +1,5 @@ | |||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
|  |  | ||||||
| import fs from 'fs'; |  | ||||||
| import os from 'os'; | import os from 'os'; | ||||||
|  |  | ||||||
| import * as auth from './authutil'; | import * as auth from './authutil'; | ||||||
| @@ -8,7 +7,7 @@ import * as path from 'path'; | |||||||
| import {restoreCache} from './cache-restore'; | import {restoreCache} from './cache-restore'; | ||||||
| import {isCacheFeatureAvailable} from './cache-utils'; | import {isCacheFeatureAvailable} from './cache-utils'; | ||||||
| import {getNodejsDistribution} from './distributions/installer-factory'; | import {getNodejsDistribution} from './distributions/installer-factory'; | ||||||
| import {parseNodeVersionFile, printEnvDetailsAndSetOutput} from './util'; | import {getNodeVersionFromFile, printEnvDetailsAndSetOutput} from './util'; | ||||||
| import {State} from './constants'; | import {State} from './constants'; | ||||||
|  |  | ||||||
| export async function run() { | export async function run() { | ||||||
| @@ -99,15 +98,7 @@ function resolveVersionInput(): string { | |||||||
|       versionFileInput |       versionFileInput | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
|     if (!fs.existsSync(versionFilePath)) { |     const parsedVersion = getNodeVersionFromFile(versionFilePath); | ||||||
|       throw new Error( |  | ||||||
|         `The specified node version file at: ${versionFilePath} does not exist` |  | ||||||
|       ); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     const parsedVersion = parseNodeVersionFile( |  | ||||||
|       fs.readFileSync(versionFilePath, 'utf8') |  | ||||||
|     ); |  | ||||||
|  |  | ||||||
|     if (parsedVersion) { |     if (parsedVersion) { | ||||||
|       version = parsedVersion; |       version = parsedVersion; | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								src/util.ts
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								src/util.ts
									
									
									
									
									
								
							| @@ -1,52 +1,70 @@ | |||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
| import * as exec from '@actions/exec'; | import * as exec from '@actions/exec'; | ||||||
|  | import * as io from '@actions/io'; | ||||||
|  |  | ||||||
| export function parseNodeVersionFile(contents: string): string | null { | import fs from 'fs'; | ||||||
|   let nodeVersion: string | undefined; | 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 parsing the file as an NPM `package.json` file. | ||||||
|   try { |   try { | ||||||
|     const manifest = JSON.parse(contents); |     const manifest = JSON.parse(contents); | ||||||
|  |  | ||||||
|     // JSON can parse numbers, but that's handled later |     // Presume package.json file. | ||||||
|     if (typeof manifest === 'object') { |     if (typeof manifest === 'object' && !!manifest) { | ||||||
|       nodeVersion = manifest.volta?.node; |       // Support Volta. | ||||||
|       if (!nodeVersion) nodeVersion = manifest.engines?.node; |       // See https://docs.volta.sh/guide/understanding#managing-your-project | ||||||
|  |       if (manifest.volta?.node) { | ||||||
|  |         return manifest.volta.node; | ||||||
|  |       } | ||||||
|  |  | ||||||
|       // if contents are an object, we parsed JSON |       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 |       // this can happen if node-version-file is a package.json | ||||||
|       // yet contains no volta.node or engines.node |       // yet contains no volta.node or engines.node | ||||||
|       // |       // | ||||||
|       // if node-version file is _not_ json, control flow |       // If node-version file is _not_ JSON, control flow | ||||||
|       // will not have reached these lines. |       // will not have reached these lines. | ||||||
|       // |       // | ||||||
|       // And because we've reached here, we know the contents |       // And because we've reached here, we know the contents | ||||||
|       // *are* JSON, so no further string parsing makes sense. |       // *are* JSON, so no further string parsing makes sense. | ||||||
|       if (!nodeVersion) { |  | ||||||
|       return null; |       return null; | ||||||
|     } |     } | ||||||
|     } |  | ||||||
|   } catch { |   } catch { | ||||||
|     core.info('Node version file is not JSON file'); |     core.info('Node version file is not JSON file'); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (!nodeVersion) { |  | ||||||
|   const found = contents.match(/^(?:node(js)?\s+)?v?(?<version>[^\s]+)$/m); |   const found = contents.match(/^(?:node(js)?\s+)?v?(?<version>[^\s]+)$/m); | ||||||
|     nodeVersion = found?.groups?.version; |   return found?.groups?.version ?? contents.trim(); | ||||||
|   } |  | ||||||
|  |  | ||||||
|   // In the case of an unknown format, |  | ||||||
|   // return as is and evaluate the version separately. |  | ||||||
|   if (!nodeVersion) nodeVersion = contents.trim(); |  | ||||||
|  |  | ||||||
|   return nodeVersion as string; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| export async function printEnvDetailsAndSetOutput() { | export async function printEnvDetailsAndSetOutput() { | ||||||
|   core.startGroup('Environment details'); |   core.startGroup('Environment details'); | ||||||
|  |  | ||||||
|   const promises = ['node', 'npm', 'yarn'].map(async tool => { |   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}; |     return {tool, output}; | ||||||
|   }); |   }); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user