mirror of
				https://github.com/actions/setup-go.git
				synced 2025-10-22 02:46:23 +00:00 
			
		
		
		
	Compare commits
	
		
			70 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | bfdd3570ce | ||
|  | 44e221478f | ||
|  | 424fc82d43 | ||
|  | 82388ea9d4 | ||
|  | fdeec47002 | ||
|  | 3e9d5483e6 | ||
|  | 02f7ea9f09 | ||
|  | 5805cf725b | ||
|  | 35030c1fd2 | ||
|  | 59d644db2a | ||
|  | 76929df236 | ||
|  | b06835a88c | ||
|  | b8a24202e2 | ||
|  | e234d99c78 | ||
|  | 0ea1f64ec9 | ||
|  | 331ce1d993 | ||
|  | 1087a81afd | ||
|  | ecd878f81d | ||
|  | eca066937b | ||
|  | e816064dae | ||
|  | bba6fe1d58 | ||
|  | 3b4dc6cbed | ||
|  | afe68ffd57 | ||
|  | 6eb700292f | ||
|  | 37335c7bb2 | ||
|  | 7ff6287c80 | ||
|  | 084110f6ed | ||
|  | 4047b11da0 | ||
|  | 23a9878ae4 | ||
|  | 8a3a76c217 | ||
|  | a01ab08f9a | ||
|  | 33cbf07c96 | ||
|  | 8e98458ff1 | ||
|  | d0c5defdf3 | ||
|  | 1616116e1b | ||
|  | 0f551ac199 | ||
|  | e1c0a1665b | ||
|  | 78bd24e01a | ||
|  | 6613fc89fc | ||
|  | 202a594963 | ||
|  | 0dbc7e4965 | ||
|  | 2091469f9f | ||
|  | f32657ccaf | ||
|  | cec6ecefb4 | ||
|  | e36ce1d6cf | ||
|  | 89c89c5036 | ||
|  | 0a62a734da | ||
|  | 5156bc5dd3 | ||
|  | 7837b03976 | ||
|  | 74c8095946 | ||
|  | 34223181a5 | ||
|  | 1c06f0e82e | ||
|  | a030287975 | ||
|  | 3349559e91 | ||
|  | dec4fc5647 | ||
|  | 262468e92f | ||
|  | 4e8106ca18 | ||
|  | 93ddff5bef | ||
|  | 3d89e603f2 | ||
|  | 1fea44b3f0 | ||
|  | 3e014ec8a4 | ||
|  | 75899f8cdf | ||
|  | 1fdcb9b160 | ||
|  | 3d0e3826ed | ||
|  | 9c31f591e9 | ||
|  | e0b6a4d694 | ||
|  | 1295b8c552 | ||
|  | 9b1c41166a | ||
|  | 655555d319 | ||
|  | 2096a2c66a | 
							
								
								
									
										1
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | .licenses/** -diff linguist-generated=true | ||||||
							
								
								
									
										38
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | --- | ||||||
|  | name: Bug report | ||||||
|  | about: Create a bug report | ||||||
|  | title: '' | ||||||
|  | labels: bug, needs triage | ||||||
|  | assignees: '' | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | <!--- Please direct any generic questions related to actions to our support community forum at https://github.community/c/code-to-cloud/github-actions/41 ---> | ||||||
|  | <!--- Before opening up a new bug report, please make sure to check for similar existing issues --> | ||||||
|  |  | ||||||
|  | **Description:** | ||||||
|  | A clear and concise description of what the bug is. | ||||||
|  |  | ||||||
|  | **Action version:** | ||||||
|  | Specify the action version | ||||||
|  |  | ||||||
|  | **Platform:** | ||||||
|  | - [ ] Ubuntu | ||||||
|  | - [ ] macOS | ||||||
|  | - [ ] Windows | ||||||
|  |  | ||||||
|  | **Runner type:** | ||||||
|  | - [ ] Hosted | ||||||
|  | - [ ] Self-hosted | ||||||
|  |  | ||||||
|  | **Tools version:** | ||||||
|  | <!--- Please specify go version --> | ||||||
|  |  | ||||||
|  | **Repro steps:**   | ||||||
|  | A description with steps to reproduce the issue. If your have a public example or repo to share, please provide the link. | ||||||
|  |  | ||||||
|  | **Expected behavior:** | ||||||
|  | A description of what you expected to happen. | ||||||
|  |  | ||||||
|  | **Actual behavior:** | ||||||
|  | A description of what is actually happening. | ||||||
							
								
								
									
										1
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | blank_issues_enabled: false | ||||||
							
								
								
									
										18
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | --- | ||||||
|  | name: Feature request | ||||||
|  | about: Suggest an idea for this project | ||||||
|  | title: '' | ||||||
|  | labels: feature request, needs triage | ||||||
|  | assignees: '' | ||||||
|  | --- | ||||||
|  | <!--- Please direct any generic questions related to actions to our support community forum at https://github.community/c/code-to-cloud/github-actions/41 ---> | ||||||
|  | <!--- Before opening up a new feature request, please make sure to check for similar existing issues and pull requests --> | ||||||
|  |  | ||||||
|  | **Description:** | ||||||
|  | Describe your proposal. | ||||||
|  |  | ||||||
|  | **Justification:** | ||||||
|  | Justification or a use case for your proposal. | ||||||
|  |  | ||||||
|  | **Are you willing to submit a PR?** | ||||||
|  | <!--- We accept contributions! --> | ||||||
							
								
								
									
										9
									
								
								.github/pull_request_template.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								.github/pull_request_template.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | **Description:** | ||||||
|  | Describe your changes. | ||||||
|  |  | ||||||
|  | **Related issue:** | ||||||
|  | Add link to the related issue. | ||||||
|  |  | ||||||
|  | **Check list:** | ||||||
|  | - [ ] Mark if documentation changes are required. | ||||||
|  | - [ ] Mark if tests were added or updated to cover the changes. | ||||||
							
								
								
									
										51
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | # `dist/index.js` is a special file in Actions. | ||||||
|  | # When you reference an action with `uses:` in a workflow, | ||||||
|  | # `index.js` is the code that will run. | ||||||
|  | # For our project, we generate this file through a build process from other source files. | ||||||
|  | # We need to make sure the checked-in `index.js` actually matches what we expect it to be. | ||||||
|  | name: Check dist/ | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |     paths-ignore: | ||||||
|  |       - '**.md' | ||||||
|  |   pull_request: | ||||||
|  |     paths-ignore: | ||||||
|  |       - '**.md' | ||||||
|  |   workflow_dispatch: | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   check-dist: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v2 | ||||||
|  |  | ||||||
|  |       - name: Set Node.js 12.x | ||||||
|  |         uses: actions/setup-node@v2 | ||||||
|  |         with: | ||||||
|  |           node-version: 12.x | ||||||
|  |  | ||||||
|  |       - name: Install dependencies | ||||||
|  |         run: npm ci | ||||||
|  |  | ||||||
|  |       - name: Rebuild the dist/ directory | ||||||
|  |         run: npm run build | ||||||
|  |  | ||||||
|  |       - name: Compare the expected and actual dist/ directories | ||||||
|  |         run: | | ||||||
|  |           if [ "$(git diff --ignore-space-at-eol dist/ | wc -l)" -gt "0" ]; then | ||||||
|  |             echo "Detected uncommitted changes after build.  See status below:" | ||||||
|  |             git diff | ||||||
|  |             exit 1 | ||||||
|  |           fi | ||||||
|  |         id: diff | ||||||
|  |  | ||||||
|  |       # If index.js was different than expected, upload the expected version as an artifact | ||||||
|  |       - uses: actions/upload-artifact@v2 | ||||||
|  |         if: ${{ failure() && steps.diff.conclusion == 'failure' }} | ||||||
|  |         with: | ||||||
|  |           name: dist | ||||||
|  |           path: dist/ | ||||||
							
								
								
									
										24
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | name: Licensed | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |   pull_request: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   test: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     name: Check licenses | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v2 | ||||||
|  |       - run: npm ci | ||||||
|  |       - name: Install licensed | ||||||
|  |         run: | | ||||||
|  |           cd $RUNNER_TEMP | ||||||
|  |           curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.3.1/licensed-3.3.1-linux-x64.tar.gz | ||||||
|  |           sudo tar -xzf licensed.tar.gz | ||||||
|  |           sudo mv licensed /usr/local/bin/licensed | ||||||
|  |       - run: licensed status | ||||||
							
								
								
									
										27
									
								
								.github/workflows/release-new-action-version.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								.github/workflows/release-new-action-version.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | name: Release new action version | ||||||
|  | on: | ||||||
|  |   release: | ||||||
|  |     types: [released] | ||||||
|  |   workflow_dispatch: | ||||||
|  |     inputs: | ||||||
|  |       TAG_NAME: | ||||||
|  |         description: 'Tag name that the major tag will point to' | ||||||
|  |         required: true | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   TAG_NAME: ${{ github.event.inputs.TAG_NAME || github.event.release.tag_name }} | ||||||
|  | permissions: | ||||||
|  |   contents: write | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   update_tag: | ||||||
|  |     name: Update the major tag to include the ${{ github.event.inputs.TAG_NAME || github.event.release.tag_name }} changes | ||||||
|  |     environment: | ||||||
|  |       name: releaseNewActionVersion | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - name: Update the ${{ env.TAG_NAME }} tag | ||||||
|  |         uses: actions/publish-action@v0.1.0 | ||||||
|  |         with: | ||||||
|  |           source-tag: ${{ env.TAG_NAME }} | ||||||
|  |           slack-webhook: ${{ secrets.SLACK_WEBHOOK }} | ||||||
							
								
								
									
										115
									
								
								.github/workflows/versions.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										115
									
								
								.github/workflows/versions.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,44 +1,93 @@ | |||||||
| name: go-versions | name: Validate 'setup-go' | ||||||
| on: | on: | ||||||
|     push: |   push: | ||||||
|       branches: |     branches: | ||||||
|         - master |       - main | ||||||
|       paths-ignore: |     paths-ignore: | ||||||
|         - '**.md' |       - '**.md' | ||||||
|     pull_request: |   pull_request: | ||||||
|       paths-ignore: |     paths-ignore: | ||||||
|         - '**.md' |       - '**.md' | ||||||
|  |   schedule: | ||||||
|  |     - cron: 0 0 * * * | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   run: |   local-cache: | ||||||
|     name: Go |     name: Setup local-cache version | ||||||
|     runs-on: ${{ matrix.operating-system }} |     runs-on: ${{ matrix.os }} | ||||||
|     strategy: |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         operating-system: [ubuntu-latest, windows-latest, macos-latest] |         os: [macos-latest, windows-latest, ubuntu-latest] | ||||||
|  |         go: [1.12, 1.13, 1.14] | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout |       - name: Checkout | ||||||
|       uses: actions/checkout@v2 |         uses: actions/checkout@v2 | ||||||
|  |  | ||||||
|     - name: setup-go ^1.13.6 |       - name: setup-go ${{ matrix.go }} | ||||||
|       uses: ./ |         uses: ./ | ||||||
|       with: |         with: | ||||||
|         go-version: ^1.13.6 |           go-version: ${{ matrix.go }} | ||||||
|  |  | ||||||
|     - name: validate version  |       - name: verify go | ||||||
|       run: go version | grep "go1.13." |         run: __tests__/verify-go.sh ${{ matrix.go }} | ||||||
|  |         shell: bash | ||||||
|  |  | ||||||
|     - name: setup-go 1.13 |   check-latest: | ||||||
|       uses: ./ |     runs-on: ${{ matrix.os }} | ||||||
|       with: |     strategy: | ||||||
|         go-version: 1.13 |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|  |         go-version: [1.16, 1.17] | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v2 | ||||||
|  |       - name: Setup Go and check latest | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           go-version: ${{ matrix.go-version }} | ||||||
|  |           check-latest: true | ||||||
|  |       - name: Verify Go | ||||||
|  |         run: go version | ||||||
|  |  | ||||||
|     - name: validate version  |   setup-versions-from-manifest: | ||||||
|       run: go version | grep "go1.13."       |     name: Setup ${{ matrix.go }} ${{ matrix.os }} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         os: [macos-latest, windows-latest, ubuntu-latest] | ||||||
|  |         go: [1.12.16, 1.13.11, 1.14.3] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v2 | ||||||
|        |        | ||||||
|     - name: setup-go 1.12.9 |       - name: setup-go ${{ matrix.go }} | ||||||
|       uses: ./ |         uses: ./ | ||||||
|       with: |         with: | ||||||
|         go-version: 1.12.9 |           go-version: ${{ matrix.go }} | ||||||
|        |        | ||||||
|     - name: validate version  |       - name: verify go | ||||||
|       run: go version | grep "go1.12.9" |         run: __tests__/verify-go.sh ${{ matrix.go }} | ||||||
|  |         shell: bash | ||||||
|  |  | ||||||
|  |   setup-versions-from-dist: | ||||||
|  |     name: Setup ${{ matrix.go }} ${{ matrix.os }} | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         os: [macos-latest, windows-latest, ubuntu-latest] | ||||||
|  |         go: [1.7, 1.8.6] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v2 | ||||||
|  |  | ||||||
|  |       - name: setup-go ${{ matrix.go }} | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           go-version: ${{ matrix.go }} | ||||||
|  |  | ||||||
|  |       - name: verify go | ||||||
|  |         run: __tests__/verify-go.sh ${{ matrix.go }} | ||||||
|  |         shell: bash | ||||||
|   | |||||||
							
								
								
									
										33
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										33
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							| @@ -2,7 +2,7 @@ name: build-test | |||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - master |       - main | ||||||
|     paths-ignore: |     paths-ignore: | ||||||
|       - '**.md' |       - '**.md' | ||||||
|   pull_request: |   pull_request: | ||||||
| @@ -16,23 +16,24 @@ jobs: | |||||||
|       matrix: |       matrix: | ||||||
|         operating-system: [ubuntu-latest, windows-latest] |         operating-system: [ubuntu-latest, windows-latest] | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout |       - name: Checkout | ||||||
|       uses: actions/checkout@v2 |         uses: actions/checkout@v2 | ||||||
|  |  | ||||||
|     - name: Setup node 12 |       - name: Setup node 12 | ||||||
|       uses: actions/setup-node@v1 |         uses: actions/setup-node@v2 | ||||||
|       with: |         with: | ||||||
|         node-version: 12 |           node-version: 12 | ||||||
|  |           cache: npm | ||||||
|  |  | ||||||
|     - name: npm install |       - name: npm ci | ||||||
|       run: npm install |         run: npm ci | ||||||
|  |  | ||||||
|     - name: Lint |       - name: Lint | ||||||
|       run: npm run format-check |         run: npm run format-check | ||||||
|  |  | ||||||
|     - name: npm test |       - name: npm test | ||||||
|       run: npm test |         run: npm test | ||||||
|  |  | ||||||
|     - name: audit packages |       - name: audit packages | ||||||
|       run: npm audit --audit-level=moderate |         run: npm audit --audit-level=high | ||||||
|       if: matrix.operating-system == 'ubuntu-latest' |         if: matrix.operating-system == 'ubuntu-latest' | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								.licensed.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.licensed.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | sources: | ||||||
|  |   npm: true | ||||||
|  |  | ||||||
|  | allowed: | ||||||
|  |   - apache-2.0 | ||||||
|  |   - bsd-2-clause | ||||||
|  |   - bsd-3-clause | ||||||
|  |   - isc | ||||||
|  |   - mit | ||||||
|  |   - cc0-1.0 | ||||||
|  |   - unlicense | ||||||
|  |  | ||||||
|  | reviewed: | ||||||
|  |   npm: | ||||||
							
								
								
									
										20
									
								
								.licenses/npm/@actions/core.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								.licenses/npm/@actions/core.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | --- | ||||||
|  | name: "@actions/core" | ||||||
|  | version: 1.6.0 | ||||||
|  | type: npm | ||||||
|  | summary: Actions core lib | ||||||
|  | homepage: https://github.com/actions/toolkit/tree/main/packages/core | ||||||
|  | license: mit | ||||||
|  | licenses: | ||||||
|  | - sources: LICENSE.md | ||||||
|  |   text: |- | ||||||
|  |     The MIT License (MIT) | ||||||
|  | 
 | ||||||
|  |     Copyright 2019 GitHub | ||||||
|  | 
 | ||||||
|  |     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||||
|  | 
 | ||||||
|  |     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||||
|  | notices: [] | ||||||
							
								
								
									
										30
									
								
								.licenses/npm/@actions/exec.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								.licenses/npm/@actions/exec.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | --- | ||||||
|  | name: "@actions/exec" | ||||||
|  | version: 1.0.4 | ||||||
|  | type: npm | ||||||
|  | summary: Actions exec lib | ||||||
|  | homepage: https://github.com/actions/toolkit/tree/master/packages/exec | ||||||
|  | license: mit | ||||||
|  | licenses: | ||||||
|  | - sources: Auto-generated MIT license text | ||||||
|  |   text: | | ||||||
|  |     MIT License | ||||||
|  | 
 | ||||||
|  |     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |     of this software and associated documentation files (the "Software"), to deal | ||||||
|  |     in the Software without restriction, including without limitation the rights | ||||||
|  |     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |     copies of the Software, and to permit persons to whom the Software is | ||||||
|  |     furnished to do so, subject to the following conditions: | ||||||
|  | 
 | ||||||
|  |     The above copyright notice and this permission notice shall be included in all | ||||||
|  |     copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  |     SOFTWARE. | ||||||
|  | notices: [] | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@actions/http-client-1.0.11.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@actions/http-client-1.0.11.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | --- | ||||||
|  | name: "@actions/http-client" | ||||||
|  | version: 1.0.11 | ||||||
|  | type: npm | ||||||
|  | summary: Actions Http Client | ||||||
|  | homepage: https://github.com/actions/http-client#readme | ||||||
|  | license: mit | ||||||
|  | licenses: | ||||||
|  | - sources: LICENSE | ||||||
|  |   text: | | ||||||
|  |     Actions Http Client for Node.js | ||||||
|  | 
 | ||||||
|  |     Copyright (c) GitHub, Inc. | ||||||
|  | 
 | ||||||
|  |     All rights reserved. | ||||||
|  | 
 | ||||||
|  |     MIT License | ||||||
|  | 
 | ||||||
|  |     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and | ||||||
|  |     associated documentation files (the "Software"), to deal in the Software without restriction, | ||||||
|  |     including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||||||
|  |     and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, | ||||||
|  |     subject to the following conditions: | ||||||
|  | 
 | ||||||
|  |     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT | ||||||
|  |     LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN | ||||||
|  |     NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | ||||||
|  |     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | ||||||
|  |     SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||||
|  | notices: [] | ||||||
							
								
								
									
										32
									
								
								.licenses/npm/@actions/http-client-1.0.8.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								.licenses/npm/@actions/http-client-1.0.8.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | --- | ||||||
|  | name: "@actions/http-client" | ||||||
|  | version: 1.0.8 | ||||||
|  | type: npm | ||||||
|  | summary: Actions Http Client | ||||||
|  | homepage: https://github.com/actions/http-client#readme | ||||||
|  | license: mit | ||||||
|  | licenses: | ||||||
|  | - sources: LICENSE | ||||||
|  |   text: | | ||||||
|  |     Actions Http Client for Node.js | ||||||
|  | 
 | ||||||
|  |     Copyright (c) GitHub, Inc. | ||||||
|  | 
 | ||||||
|  |     All rights reserved. | ||||||
|  | 
 | ||||||
|  |     MIT License | ||||||
|  | 
 | ||||||
|  |     Permission is hereby granted, free of charge, to any person obtaining a copy of this software and | ||||||
|  |     associated documentation files (the "Software"), to deal in the Software without restriction, | ||||||
|  |     including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||||||
|  |     and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, | ||||||
|  |     subject to the following conditions: | ||||||
|  | 
 | ||||||
|  |     The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT | ||||||
|  |     LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN | ||||||
|  |     NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | ||||||
|  |     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | ||||||
|  |     SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||||
|  | notices: [] | ||||||
							
								
								
									
										30
									
								
								.licenses/npm/@actions/io.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								.licenses/npm/@actions/io.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | --- | ||||||
|  | name: "@actions/io" | ||||||
|  | version: 1.0.2 | ||||||
|  | type: npm | ||||||
|  | summary: Actions io lib | ||||||
|  | homepage: https://github.com/actions/toolkit/tree/master/packages/io | ||||||
|  | license: mit | ||||||
|  | licenses: | ||||||
|  | - sources: Auto-generated MIT license text | ||||||
|  |   text: | | ||||||
|  |     MIT License | ||||||
|  | 
 | ||||||
|  |     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |     of this software and associated documentation files (the "Software"), to deal | ||||||
|  |     in the Software without restriction, including without limitation the rights | ||||||
|  |     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |     copies of the Software, and to permit persons to whom the Software is | ||||||
|  |     furnished to do so, subject to the following conditions: | ||||||
|  | 
 | ||||||
|  |     The above copyright notice and this permission notice shall be included in all | ||||||
|  |     copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  |     SOFTWARE. | ||||||
|  | notices: [] | ||||||
							
								
								
									
										30
									
								
								.licenses/npm/@actions/tool-cache.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								.licenses/npm/@actions/tool-cache.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | --- | ||||||
|  | name: "@actions/tool-cache" | ||||||
|  | version: 1.5.5 | ||||||
|  | type: npm | ||||||
|  | summary: Actions tool-cache lib | ||||||
|  | homepage: https://github.com/actions/toolkit/tree/master/packages/tool-cache | ||||||
|  | license: mit | ||||||
|  | licenses: | ||||||
|  | - sources: Auto-generated MIT license text | ||||||
|  |   text: | | ||||||
|  |     MIT License | ||||||
|  | 
 | ||||||
|  |     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |     of this software and associated documentation files (the "Software"), to deal | ||||||
|  |     in the Software without restriction, including without limitation the rights | ||||||
|  |     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |     copies of the Software, and to permit persons to whom the Software is | ||||||
|  |     furnished to do so, subject to the following conditions: | ||||||
|  | 
 | ||||||
|  |     The above copyright notice and this permission notice shall be included in all | ||||||
|  |     copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  |     SOFTWARE. | ||||||
|  | notices: [] | ||||||
							
								
								
									
										26
									
								
								.licenses/npm/semver.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								.licenses/npm/semver.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | --- | ||||||
|  | name: semver | ||||||
|  | version: 6.3.0 | ||||||
|  | type: npm | ||||||
|  | summary: The semantic version parser used by npm. | ||||||
|  | homepage: https://github.com/npm/node-semver#readme | ||||||
|  | license: isc | ||||||
|  | licenses: | ||||||
|  | - sources: LICENSE | ||||||
|  |   text: | | ||||||
|  |     The ISC License | ||||||
|  | 
 | ||||||
|  |     Copyright (c) Isaac Z. Schlueter and Contributors | ||||||
|  | 
 | ||||||
|  |     Permission to use, copy, modify, and/or distribute this software for any | ||||||
|  |     purpose with or without fee is hereby granted, provided that the above | ||||||
|  |     copyright notice and this permission notice appear in all copies. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||||
|  |     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||||
|  |     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||||
|  |     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||||
|  |     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||||
|  |     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR | ||||||
|  |     IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||||
|  | notices: [] | ||||||
							
								
								
									
										35
									
								
								.licenses/npm/tunnel.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								.licenses/npm/tunnel.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | --- | ||||||
|  | name: tunnel | ||||||
|  | version: 0.0.6 | ||||||
|  | type: npm | ||||||
|  | summary: Node HTTP/HTTPS Agents for tunneling proxies | ||||||
|  | homepage: https://github.com/koichik/node-tunnel/ | ||||||
|  | license: mit | ||||||
|  | licenses: | ||||||
|  | - sources: LICENSE | ||||||
|  |   text: | | ||||||
|  |     The MIT License (MIT) | ||||||
|  | 
 | ||||||
|  |     Copyright (c) 2012 Koichi Kobayashi | ||||||
|  | 
 | ||||||
|  |     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |     of this software and associated documentation files (the "Software"), to deal | ||||||
|  |     in the Software without restriction, including without limitation the rights | ||||||
|  |     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |     copies of the Software, and to permit persons to whom the Software is | ||||||
|  |     furnished to do so, subject to the following conditions: | ||||||
|  | 
 | ||||||
|  |     The above copyright notice and this permission notice shall be included in | ||||||
|  |     all copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||||
|  |     THE SOFTWARE. | ||||||
|  | - sources: README.md | ||||||
|  |   text: Licensed under the [MIT](https://github.com/koichik/node-tunnel/blob/master/LICENSE) | ||||||
|  |     license. | ||||||
|  | notices: [] | ||||||
							
								
								
									
										39
									
								
								.licenses/npm/uuid.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								.licenses/npm/uuid.dep.yml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | |||||||
|  | --- | ||||||
|  | name: uuid | ||||||
|  | version: 3.4.0 | ||||||
|  | type: npm | ||||||
|  | summary: RFC4122 (v1, v4, and v5) UUIDs | ||||||
|  | homepage: https://github.com/uuidjs/uuid#readme | ||||||
|  | license: mit | ||||||
|  | licenses: | ||||||
|  | - sources: LICENSE.md | ||||||
|  |   text: | | ||||||
|  |     The MIT License (MIT) | ||||||
|  | 
 | ||||||
|  |     Copyright (c) 2010-2016 Robert Kieffer and other contributors | ||||||
|  | 
 | ||||||
|  |     Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |     of this software and associated documentation files (the "Software"), to deal | ||||||
|  |     in the Software without restriction, including without limitation the rights | ||||||
|  |     to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |     copies of the Software, and to permit persons to whom the Software is | ||||||
|  |     furnished to do so, subject to the following conditions: | ||||||
|  | 
 | ||||||
|  |     The above copyright notice and this permission notice shall be included in all | ||||||
|  |     copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  |     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |     IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |     FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |     AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |     LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |     OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  |     SOFTWARE. | ||||||
|  | notices: | ||||||
|  | - sources: AUTHORS | ||||||
|  |   text: |- | ||||||
|  |     Robert Kieffer <robert@broofa.com> | ||||||
|  |     Christoph Tavan <dev@tavan.de> | ||||||
|  |     AJ ONeal <coolaj86@gmail.com> | ||||||
|  |     Vincent Voyer <vincent@zeroload.net> | ||||||
|  |     Roman Shtylman <shtylman@gmail.com> | ||||||
							
								
								
									
										1
									
								
								CODEOWNERS
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								CODEOWNERS
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * @actions/spark | ||||||
							
								
								
									
										80
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										80
									
								
								README.md
									
									
									
									
									
								
							| @@ -11,66 +11,96 @@ This action sets up a go environment for use in actions by: | |||||||
| - optionally downloading and caching a version of Go by version and adding to PATH | - optionally downloading and caching a version of Go by version and adding to PATH | ||||||
| - registering problem matchers for error output | - registering problem matchers for error output | ||||||
|  |  | ||||||
| # V2 Beta | # V2 | ||||||
|  |  | ||||||
| The V2 beta offers: | The V2 offers: | ||||||
|  | - Adds GOBIN to the PATH | ||||||
| - Proxy Support | - Proxy Support | ||||||
| - stable input  | - `stable` input  | ||||||
|  | - Check latest version | ||||||
| - Bug Fixes (including issues around version matching and semver) | - Bug Fixes (including issues around version matching and semver) | ||||||
|  |  | ||||||
| Matching by semver spec: | The action will first check the local cache for a version match. If a version is not found locally, it will pull it from the `main` branch of the [go-versions](https://github.com/actions/go-versions/blob/main/versions-manifest.json) repository. On miss or failure, it will fall back to downloading directly from [go dist](https://storage.googleapis.com/golang). To change the default behavior, please use the [check-latest input](#check-latest-version). | ||||||
|  |  | ||||||
|  | Matching by [semver spec](https://github.com/npm/node-semver): | ||||||
| ```yaml | ```yaml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v2 |   - uses: actions/checkout@v2 | ||||||
| - uses: actions/setup-go@v2-beta |   - uses: actions/setup-go@v2 | ||||||
|   with: |     with: | ||||||
|     go-version: '^1.13.1' # The Go version to download (if necessary) and use. |       go-version: '^1.13.1' # The Go version to download (if necessary) and use. | ||||||
| - run: go version |   - run: go version | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Matching an unstable pre-release: | Matching an unstable pre-release: | ||||||
| ```yaml | ```yaml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v2 |   - uses: actions/checkout@v2 | ||||||
| - uses: actions/setup-go@v2-beta |   - uses: actions/setup-go@v2 | ||||||
|   with: |     with: | ||||||
|     stable: 'false' |       stable: 'false' | ||||||
|     go-version: '1.14.0-rc1' # The Go version to download (if necessary) and use. |       go-version: '1.14.0-rc1' # The Go version to download (if necessary) and use. | ||||||
| - run: go version |   - run: go version | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| # Usage | # Usage | ||||||
|  |  | ||||||
| See [action.yml](action.yml) | See [action.yml](action.yml) | ||||||
|  |  | ||||||
| Basic: | ## Basic: | ||||||
| ```yaml | ```yaml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@master |   - uses: actions/checkout@v2 | ||||||
| - uses: actions/setup-go@v1 |   - uses: actions/setup-go@v2 | ||||||
|   with: |     with: | ||||||
|     go-version: '1.9.3' # The Go version to download (if necessary) and use. |       go-version: '1.16.1' # The Go version to download (if necessary) and use. | ||||||
| - run: go run hello.go |   - run: go run hello.go | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Matrix Testing: |  | ||||||
|  | ## Check latest version:   | ||||||
|  |  | ||||||
|  | The `check-latest` flag defaults to `false`. Use the default or set `check-latest` to `false` if you prefer stability and if you want to ensure a specific Go version is always used. | ||||||
|  |  | ||||||
|  | If `check-latest` is set to `true`, the action first checks if the cached version is the latest one. If the locally cached version is not the most up-to-date, a Go version will then be downloaded. Set `check-latest` to `true` if you want the most up-to-date Go version to always be used. | ||||||
|  |  | ||||||
|  | > Setting `check-latest` to `true` has performance implications as downloading Go versions is slower than using cached versions. | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | steps: | ||||||
|  |   - uses: actions/checkout@v2 | ||||||
|  |   - uses: actions/setup-go@v2 | ||||||
|  |     with: | ||||||
|  |       go-version: '1.14' | ||||||
|  |       check-latest: true | ||||||
|  |   - run: go run hello.go | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Matrix Testing: | ||||||
| ```yaml | ```yaml | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     runs-on: ubuntu-16.04 |     runs-on: ubuntu-latest | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         go: [ '1.13', '1.12' ] |         go: [ '1.14', '1.13' ] | ||||||
|     name: Go ${{ matrix.go }} sample |     name: Go ${{ matrix.go }} sample | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v2 |       - uses: actions/checkout@v2 | ||||||
|       - name: Setup go |       - name: Setup go | ||||||
|         uses: actions/setup-go@v1 |         uses: actions/setup-go@v2 | ||||||
|         with: |         with: | ||||||
|           go-version: ${{ matrix.go }} |           go-version: ${{ matrix.go }} | ||||||
|       - run: go run hello.go |       - run: go run hello.go | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ### Supported version syntax | ||||||
|  | The `go-version` input supports the following syntax: | ||||||
|  |  | ||||||
|  | Specific versions: `1.15`, `1.16.1`, `1.17.0-rc2`, `1.16.0-beta1`   | ||||||
|  | SemVer's version range syntax: `^1.13.1`   | ||||||
|  | For more information about semantic versioning please refer [semver](https://github.com/npm/node-semver) documentation | ||||||
|  |  | ||||||
| # License | # License | ||||||
|  |  | ||||||
| The scripts and documentation in this project are released under the [MIT License](LICENSE) | The scripts and documentation in this project are released under the [MIT License](LICENSE) | ||||||
|   | |||||||
							
								
								
									
										102
									
								
								__tests__/data/versions-manifest.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								__tests__/data/versions-manifest.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | |||||||
|  | [ | ||||||
|  |     { | ||||||
|  |       "version": "1.17.6", | ||||||
|  |       "stable": true, | ||||||
|  |       "release_url": "https://github.com/actions/go-versions/releases/tag/1.17.6-1668090892", | ||||||
|  |       "files": [ | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.17.6-darwin-x64.tar.gz", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "darwin", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.17.6-1668090892/go-1.17.6-darwin-x64.tar.gz" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.17.6-linux-x64.tar.gz", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "linux", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.17.6-1668090892/go-1.17.6-linux-x64.tar.gz" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.17.6-win32-x64.zip", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "win32", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.17.6-1668090892/go-1.17.6-win32-x64.zip" | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "version": "1.12.17", | ||||||
|  |       "stable": true, | ||||||
|  |       "release_url": "https://github.com/actions/go-versions/releases/tag/1.12.17-20200616.21", | ||||||
|  |       "files": [ | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.12.17-darwin-x64.tar.gz", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "darwin", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.12.17-20200616.21/go-1.12.17-darwin-x64.tar.gz" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.12.17-linux-x64.tar.gz", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "linux", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.12.17-20200616.21/go-1.12.17-linux-x64.tar.gz" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.12.17-win32-x64.zip", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "win32", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.12.17-20200616.21/go-1.12.17-win32-x64.zip" | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "version": "1.12.16", | ||||||
|  |       "stable": true, | ||||||
|  |       "release_url": "https://github.com/actions/go-versions/releases/tag/1.12.16-20200616.20", | ||||||
|  |       "files": [ | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.12.16-darwin-x64.tar.gz", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "darwin", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.12.16-20200616.20/go-1.12.16-darwin-x64.tar.gz" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.12.16-linux-x64.tar.gz", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "linux", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.12.16-20200616.20/go-1.12.16-linux-x64.tar.gz" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.12.16-win32-x64.zip", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "win32", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.12.16-20200616.20/go-1.12.16-win32-x64.zip" | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "version": "1.9.7", | ||||||
|  |       "stable": true, | ||||||
|  |       "release_url": "https://github.com/actions/go-versions/releases/tag/1.9.7-20200616.1", | ||||||
|  |       "files": [ | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.9.7-darwin-x64.tar.gz", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "darwin", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.9.7/go-1.9.7-darwin-x64.tar.gz" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.9.7-linux-x64.tar.gz", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "linux", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.9.7/go-1.9.7-linux-x64.tar.gz" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "filename": "go-1.9.7-win32-x64.zip", | ||||||
|  |           "arch": "x64", | ||||||
|  |           "platform": "win32", | ||||||
|  |           "download_url": "https://github.com/actions/go-versions/releases/download/1.9.7/go-1.9.7-win32-x64.zip" | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   ] | ||||||
| @@ -1,21 +1,25 @@ | |||||||
| import * as tc from '@actions/tool-cache'; |  | ||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
| import fs = require('fs'); | import * as io from '@actions/io'; | ||||||
| import osm = require('os'); | import * as tc from '@actions/tool-cache'; | ||||||
| import path = require('path'); | import fs from 'fs'; | ||||||
| import {run} from '../src/main'; | import cp from 'child_process'; | ||||||
| import * as httpm from '@actions/http-client'; | import osm from 'os'; | ||||||
|  | import path from 'path'; | ||||||
|  | import * as main from '../src/main'; | ||||||
| import * as im from '../src/installer'; | import * as im from '../src/installer'; | ||||||
| import * as sys from '../src/system'; |  | ||||||
| import {ITypedResponse} from '@actions/http-client/interfaces'; |  | ||||||
|  |  | ||||||
| let goJsonData = require('./data/golang-dl.json'); | let goJsonData = require('./data/golang-dl.json'); | ||||||
|  | let matchers = require('../matchers.json'); | ||||||
|  | let goTestManifest = require('./data/versions-manifest.json'); | ||||||
|  | let matcherPattern = matchers.problemMatcher[0].pattern[0]; | ||||||
|  | let matcherRegExp = new RegExp(matcherPattern.regexp); | ||||||
|  |  | ||||||
| describe('setup-go', () => { | describe('setup-go', () => { | ||||||
|   let inputs = {} as any; |   let inputs = {} as any; | ||||||
|   let os = {} as any; |   let os = {} as any; | ||||||
|  |  | ||||||
|   let inSpy: jest.SpyInstance; |   let inSpy: jest.SpyInstance; | ||||||
|  |   let getBooleanInputSpy: jest.SpyInstance; | ||||||
|   let findSpy: jest.SpyInstance; |   let findSpy: jest.SpyInstance; | ||||||
|   let cnSpy: jest.SpyInstance; |   let cnSpy: jest.SpyInstance; | ||||||
|   let logSpy: jest.SpyInstance; |   let logSpy: jest.SpyInstance; | ||||||
| @@ -25,69 +29,117 @@ describe('setup-go', () => { | |||||||
|   let dlSpy: jest.SpyInstance; |   let dlSpy: jest.SpyInstance; | ||||||
|   let exSpy: jest.SpyInstance; |   let exSpy: jest.SpyInstance; | ||||||
|   let cacheSpy: jest.SpyInstance; |   let cacheSpy: jest.SpyInstance; | ||||||
|  |   let dbgSpy: jest.SpyInstance; | ||||||
|  |   let whichSpy: jest.SpyInstance; | ||||||
|  |   let existsSpy: jest.SpyInstance; | ||||||
|  |   let mkdirpSpy: jest.SpyInstance; | ||||||
|  |   let execSpy: jest.SpyInstance; | ||||||
|  |   let getManifestSpy: jest.SpyInstance; | ||||||
|  |  | ||||||
|  |   beforeAll(async () => { | ||||||
|  |     process.env['GITHUB_ENV'] = ''; // Stub out Environment file functionality so we can verify it writes to standard out (toolkit is backwards compatible) | ||||||
|  |   }, 100000); | ||||||
|  |  | ||||||
|   beforeEach(() => { |   beforeEach(() => { | ||||||
|  |     process.env['GITHUB_PATH'] = ''; // Stub out ENV file functionality so we can verify it writes to standard out | ||||||
|  |  | ||||||
|     // @actions/core |     // @actions/core | ||||||
|     inputs = {}; |     inputs = {}; | ||||||
|     inSpy = jest.spyOn(core, 'getInput'); |     inSpy = jest.spyOn(core, 'getInput'); | ||||||
|     inSpy.mockImplementation(name => inputs[name]); |     inSpy.mockImplementation(name => inputs[name]); | ||||||
|  |     getBooleanInputSpy = jest.spyOn(core, 'getBooleanInput'); | ||||||
|  |     getBooleanInputSpy.mockImplementation(name => inputs[name]); | ||||||
|  |  | ||||||
|     // node 'os' |     // node | ||||||
|     os = {}; |     os = {}; | ||||||
|     platSpy = jest.spyOn(osm, 'platform'); |     platSpy = jest.spyOn(osm, 'platform'); | ||||||
|     platSpy.mockImplementation(() => os['platform']); |     platSpy.mockImplementation(() => os['platform']); | ||||||
|     archSpy = jest.spyOn(osm, 'arch'); |     archSpy = jest.spyOn(osm, 'arch'); | ||||||
|     archSpy.mockImplementation(() => os['arch']); |     archSpy.mockImplementation(() => os['arch']); | ||||||
|  |     execSpy = jest.spyOn(cp, 'execSync'); | ||||||
|  |  | ||||||
|     // @actions/tool-cache |     // @actions/tool-cache | ||||||
|     findSpy = jest.spyOn(tc, 'find'); |     findSpy = jest.spyOn(tc, 'find'); | ||||||
|     dlSpy = jest.spyOn(tc, 'downloadTool'); |     dlSpy = jest.spyOn(tc, 'downloadTool'); | ||||||
|     exSpy = jest.spyOn(tc, 'extractTar'); |     exSpy = jest.spyOn(tc, 'extractTar'); | ||||||
|     cacheSpy = jest.spyOn(tc, 'cacheDir'); |     cacheSpy = jest.spyOn(tc, 'cacheDir'); | ||||||
|     getSpy = jest.spyOn(im, 'getVersions'); |     getSpy = jest.spyOn(im, 'getVersionsDist'); | ||||||
|  |     getManifestSpy = jest.spyOn(tc, 'getManifestFromRepo'); | ||||||
|  |  | ||||||
|  |     // io | ||||||
|  |     whichSpy = jest.spyOn(io, 'which'); | ||||||
|  |     existsSpy = jest.spyOn(fs, 'existsSync'); | ||||||
|  |     mkdirpSpy = jest.spyOn(io, 'mkdirP'); | ||||||
|  |  | ||||||
|  |     // gets | ||||||
|  |     getManifestSpy.mockImplementation(() => <tc.IToolRelease[]>goTestManifest); | ||||||
|  |  | ||||||
|     // writes |     // writes | ||||||
|     cnSpy = jest.spyOn(process.stdout, 'write'); |     cnSpy = jest.spyOn(process.stdout, 'write'); | ||||||
|     logSpy = jest.spyOn(console, 'log'); |     logSpy = jest.spyOn(core, 'info'); | ||||||
|     getSpy.mockImplementation(() => <im.IGoVersion[]>goJsonData); |     dbgSpy = jest.spyOn(core, 'debug'); | ||||||
|  |     getSpy.mockImplementation(() => <im.IGoVersion[] | null>goJsonData); | ||||||
|     cnSpy.mockImplementation(line => { |     cnSpy.mockImplementation(line => { | ||||||
|       // uncomment to debug |       // uncomment to debug | ||||||
|       // process.stderr.write('write:' + line + '\n'); |       // process.stderr.write('write:' + line + '\n'); | ||||||
|     }); |     }); | ||||||
|     logSpy.mockImplementation(line => { |     logSpy.mockImplementation(line => { | ||||||
|       // uncomment to debug |       // uncomment to debug | ||||||
|       // process.stderr.write('log:' + line + '\n'); |       process.stderr.write('log:' + line + '\n'); | ||||||
|  |     }); | ||||||
|  |     dbgSpy.mockImplementation(msg => { | ||||||
|  |       // uncomment to see debug output | ||||||
|  |       // process.stderr.write(msg + '\n'); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   afterEach(() => { |   afterEach(() => { | ||||||
|     jest.resetAllMocks(); |     jest.resetAllMocks(); | ||||||
|     jest.clearAllMocks(); |     jest.clearAllMocks(); | ||||||
|  |     //jest.restoreAllMocks(); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   afterAll(async () => {}, 100000); |   afterAll(async () => { | ||||||
|  |     jest.restoreAllMocks(); | ||||||
|  |   }, 100000); | ||||||
|  |  | ||||||
|   it('can query versions', async () => { |   it('can find 1.9.7 from manifest on osx', async () => { | ||||||
|     let versions: im.IGoVersion[] | null = await im.getVersions( |     os.platform = 'darwin'; | ||||||
|       'https://non.existant.com/path' |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |     let match = await im.getInfoFromManifest('1.9.7', true, 'mocktoken'); | ||||||
|  |     expect(match).toBeDefined(); | ||||||
|  |     expect(match!.resolvedVersion).toBe('1.9.7'); | ||||||
|  |     expect(match!.type).toBe('manifest'); | ||||||
|  |     expect(match!.downloadUrl).toBe( | ||||||
|  |       'https://github.com/actions/go-versions/releases/download/1.9.7/go-1.9.7-darwin-x64.tar.gz' | ||||||
|     ); |     ); | ||||||
|     expect(versions).toBeDefined(); |  | ||||||
|     let l: number = versions ? versions.length : 0; |  | ||||||
|     expect(l).toBe(91); |  | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('finds stable match for exact version', async () => { |   it('can find 1.9 from manifest on linux', async () => { | ||||||
|  |     os.platform = 'linux'; | ||||||
|  |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |     let match = await im.getInfoFromManifest('1.9.7', true, 'mocktoken'); | ||||||
|  |     expect(match).toBeDefined(); | ||||||
|  |     expect(match!.resolvedVersion).toBe('1.9.7'); | ||||||
|  |     expect(match!.type).toBe('manifest'); | ||||||
|  |     expect(match!.downloadUrl).toBe( | ||||||
|  |       'https://github.com/actions/go-versions/releases/download/1.9.7/go-1.9.7-linux-x64.tar.gz' | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('can find 1.9 from manifest on windows', async () => { | ||||||
|     os.platform = 'win32'; |     os.platform = 'win32'; | ||||||
|     os.arch = 'x64'; |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|     // get request is already mocked |     let match = await im.getInfoFromManifest('1.9.7', true, 'mocktoken'); | ||||||
|     // spec: 1.13.7 => 1.13.7 (exact) |  | ||||||
|     let match: im.IGoVersion | undefined = await im.findMatch('1.13.7', true); |  | ||||||
|     expect(match).toBeDefined(); |     expect(match).toBeDefined(); | ||||||
|     let version: string = match ? match.version : ''; |     expect(match!.resolvedVersion).toBe('1.9.7'); | ||||||
|     expect(version).toBe('go1.13.7'); |     expect(match!.type).toBe('manifest'); | ||||||
|     let fileName = match ? match.files[0].filename : ''; |     expect(match!.downloadUrl).toBe( | ||||||
|     expect(fileName).toBe('go1.13.7.windows-amd64.zip'); |       'https://github.com/actions/go-versions/releases/download/1.9.7/go-1.9.7-win32-x64.zip' | ||||||
|  |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('finds stable match for exact dot zero version', async () => { |   it('finds stable match for exact dot zero version', async () => { | ||||||
| @@ -164,7 +216,7 @@ describe('setup-go', () => { | |||||||
|  |  | ||||||
|     let toolPath = path.normalize('/cache/go/1.13.0/x64'); |     let toolPath = path.normalize('/cache/go/1.13.0/x64'); | ||||||
|     findSpy.mockImplementation(() => toolPath); |     findSpy.mockImplementation(() => toolPath); | ||||||
|     await run(); |     await main.run(); | ||||||
|  |  | ||||||
|     expect(logSpy).toHaveBeenCalledWith(`Setup go stable version spec 1.13.0`); |     expect(logSpy).toHaveBeenCalledWith(`Setup go stable version spec 1.13.0`); | ||||||
|   }); |   }); | ||||||
| @@ -176,7 +228,7 @@ describe('setup-go', () => { | |||||||
|  |  | ||||||
|     let toolPath = path.normalize('/cache/go/1.13.0/x64'); |     let toolPath = path.normalize('/cache/go/1.13.0/x64'); | ||||||
|     findSpy.mockImplementation(() => toolPath); |     findSpy.mockImplementation(() => toolPath); | ||||||
|     await run(); |     await main.run(); | ||||||
|  |  | ||||||
|     expect(logSpy).toHaveBeenCalledWith(`Setup go stable version spec 1.13.0`); |     expect(logSpy).toHaveBeenCalledWith(`Setup go stable version spec 1.13.0`); | ||||||
|   }); |   }); | ||||||
| @@ -186,16 +238,17 @@ describe('setup-go', () => { | |||||||
|  |  | ||||||
|     let toolPath = path.normalize('/cache/go/1.13.0/x64'); |     let toolPath = path.normalize('/cache/go/1.13.0/x64'); | ||||||
|     findSpy.mockImplementation(() => toolPath); |     findSpy.mockImplementation(() => toolPath); | ||||||
|     await run(); |     await main.run(); | ||||||
|  |  | ||||||
|     let expPath = path.join(toolPath, 'bin'); |     let expPath = path.join(toolPath, 'bin'); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith(`Found in cache @ ${toolPath}`); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('finds a version in the cache and adds it to the path', async () => { |   it('finds a version in the cache and adds it to the path', async () => { | ||||||
|     inputs['go-version'] = '1.13.0'; |     inputs['go-version'] = '1.13.0'; | ||||||
|     let toolPath = path.normalize('/cache/go/1.13.0/x64'); |     let toolPath = path.normalize('/cache/go/1.13.0/x64'); | ||||||
|     findSpy.mockImplementation(() => toolPath); |     findSpy.mockImplementation(() => toolPath); | ||||||
|     await run(); |     await main.run(); | ||||||
|  |  | ||||||
|     let expPath = path.join(toolPath, 'bin'); |     let expPath = path.join(toolPath, 'bin'); | ||||||
|     expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); |     expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); | ||||||
| @@ -208,7 +261,7 @@ describe('setup-go', () => { | |||||||
|     findSpy.mockImplementation(() => { |     findSpy.mockImplementation(() => { | ||||||
|       throw new Error(errMsg); |       throw new Error(errMsg); | ||||||
|     }); |     }); | ||||||
|     await run(); |     await main.run(); | ||||||
|     expect(cnSpy).toHaveBeenCalledWith('::error::' + errMsg + osm.EOL); |     expect(cnSpy).toHaveBeenCalledWith('::error::' + errMsg + osm.EOL); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -223,7 +276,7 @@ describe('setup-go', () => { | |||||||
|     let toolPath = path.normalize('/cache/go/1.13.0/x64'); |     let toolPath = path.normalize('/cache/go/1.13.0/x64'); | ||||||
|     exSpy.mockImplementation(() => '/some/other/temp/path'); |     exSpy.mockImplementation(() => '/some/other/temp/path'); | ||||||
|     cacheSpy.mockImplementation(() => toolPath); |     cacheSpy.mockImplementation(() => toolPath); | ||||||
|     await run(); |     await main.run(); | ||||||
|  |  | ||||||
|     let expPath = path.join(toolPath, 'bin'); |     let expPath = path.join(toolPath, 'bin'); | ||||||
|  |  | ||||||
| @@ -239,13 +292,124 @@ describe('setup-go', () => { | |||||||
|     inputs['go-version'] = '9.99.9'; |     inputs['go-version'] = '9.99.9'; | ||||||
|  |  | ||||||
|     findSpy.mockImplementation(() => ''); |     findSpy.mockImplementation(() => ''); | ||||||
|     await run(); |     await main.run(); | ||||||
|  |  | ||||||
|     expect(cnSpy).toHaveBeenCalledWith( |     expect(cnSpy).toHaveBeenCalledWith( | ||||||
|       `::error::Could not find a version that satisfied version spec: 9.99.9${osm.EOL}` |       `::error::Unable to find Go version '9.99.9' for platform linux and architecture x64.${osm.EOL}` | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  |   it('downloads a version from a manifest match', async () => { | ||||||
|  |     os.platform = 'linux'; | ||||||
|  |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |     let versionSpec = '1.12.16'; | ||||||
|  |  | ||||||
|  |     inputs['go-version'] = versionSpec; | ||||||
|  |     inputs['token'] = 'faketoken'; | ||||||
|  |  | ||||||
|  |     let expectedUrl = | ||||||
|  |       'https://github.com/actions/go-versions/releases/download/1.12.16-20200616.20/go-1.12.16-linux-x64.tar.gz'; | ||||||
|  |  | ||||||
|  |     // ... but not in the local cache | ||||||
|  |     findSpy.mockImplementation(() => ''); | ||||||
|  |  | ||||||
|  |     dlSpy.mockImplementation(async () => '/some/temp/path'); | ||||||
|  |     let toolPath = path.normalize('/cache/go/1.12.16/x64'); | ||||||
|  |     exSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |     cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |     await main.run(); | ||||||
|  |  | ||||||
|  |     let expPath = path.join(toolPath, 'bin'); | ||||||
|  |  | ||||||
|  |     expect(dlSpy).toHaveBeenCalled(); | ||||||
|  |     expect(exSpy).toHaveBeenCalled(); | ||||||
|  |     expect(logSpy).not.toHaveBeenCalledWith( | ||||||
|  |       'Not found in manifest.  Falling back to download directly from Go' | ||||||
|  |     ); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |       `Acquiring 1.12.16 from ${expectedUrl}` | ||||||
|  |     ); | ||||||
|  |  | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith(`Added go to the path`); | ||||||
|  |     expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('downloads a major and minor from a manifest match', async () => { | ||||||
|  |     os.platform = 'linux'; | ||||||
|  |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |     let versionSpec = '1.12'; | ||||||
|  |  | ||||||
|  |     inputs['go-version'] = versionSpec; | ||||||
|  |     inputs['token'] = 'faketoken'; | ||||||
|  |  | ||||||
|  |     let expectedUrl = | ||||||
|  |       'https://github.com/actions/go-versions/releases/download/1.12.17-20200616.21/go-1.12.17-linux-x64.tar.gz'; | ||||||
|  |  | ||||||
|  |     // ... but not in the local cache | ||||||
|  |     findSpy.mockImplementation(() => ''); | ||||||
|  |  | ||||||
|  |     dlSpy.mockImplementation(async () => '/some/temp/path'); | ||||||
|  |     let toolPath = path.normalize('/cache/go/1.12.17/x64'); | ||||||
|  |     exSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |     cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |     await main.run(); | ||||||
|  |  | ||||||
|  |     let expPath = path.join(toolPath, 'bin'); | ||||||
|  |  | ||||||
|  |     expect(dlSpy).toHaveBeenCalled(); | ||||||
|  |     expect(exSpy).toHaveBeenCalled(); | ||||||
|  |     expect(logSpy).not.toHaveBeenCalledWith( | ||||||
|  |       'Not found in manifest.  Falling back to download directly from Go' | ||||||
|  |     ); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |       `Acquiring 1.12.17 from ${expectedUrl}` | ||||||
|  |     ); | ||||||
|  |  | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith(`Added go to the path`); | ||||||
|  |     expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('falls back to a version from node dist', async () => { | ||||||
|  |     os.platform = 'linux'; | ||||||
|  |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |     let versionSpec = '1.12.14'; | ||||||
|  |  | ||||||
|  |     inputs['go-version'] = versionSpec; | ||||||
|  |     inputs['token'] = 'faketoken'; | ||||||
|  |  | ||||||
|  |     let expectedUrl = | ||||||
|  |       'https://github.com/actions/go-versions/releases/download/1.12.14-20200616.18/go-1.12.14-linux-x64.tar.gz'; | ||||||
|  |  | ||||||
|  |     // ... but not in the local cache | ||||||
|  |     findSpy.mockImplementation(() => ''); | ||||||
|  |  | ||||||
|  |     dlSpy.mockImplementation(async () => '/some/temp/path'); | ||||||
|  |     let toolPath = path.normalize('/cache/go/1.12.14/x64'); | ||||||
|  |     exSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |     cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |     await main.run(); | ||||||
|  |  | ||||||
|  |     let expPath = path.join(toolPath, 'bin'); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith('Setup go stable version spec 1.12.14'); | ||||||
|  |     expect(findSpy).toHaveBeenCalled(); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith('Attempting to download 1.12.14...'); | ||||||
|  |     expect(dlSpy).toHaveBeenCalled(); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith('matching 1.12.14...'); | ||||||
|  |     expect(exSpy).toHaveBeenCalled(); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |       'Not found in manifest.  Falling back to download directly from Go' | ||||||
|  |     ); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith(`Install from dist`); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith(`Added go to the path`); | ||||||
|  |     expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|   it('reports a failed download', async () => { |   it('reports a failed download', async () => { | ||||||
|     let errMsg = 'unhandled download message'; |     let errMsg = 'unhandled download message'; | ||||||
|     os.platform = 'linux'; |     os.platform = 'linux'; | ||||||
| @@ -257,27 +421,141 @@ describe('setup-go', () => { | |||||||
|     dlSpy.mockImplementation(() => { |     dlSpy.mockImplementation(() => { | ||||||
|       throw new Error(errMsg); |       throw new Error(errMsg); | ||||||
|     }); |     }); | ||||||
|     await run(); |     await main.run(); | ||||||
|  |  | ||||||
|     expect(cnSpy).toHaveBeenCalledWith( |     expect(cnSpy).toHaveBeenCalledWith( | ||||||
|       `::error::Failed to download version 1.13.1: Error: ${errMsg}${osm.EOL}` |       `::error::Failed to download version 1.13.1: Error: ${errMsg}${osm.EOL}` | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('reports empty query results', async () => { |   it('does not add BIN if go is not in path', async () => { | ||||||
|     let errMsg = 'unhandled download message'; |     whichSpy.mockImplementation(async () => { | ||||||
|     os.platform = 'linux'; |       return ''; | ||||||
|     os.arch = 'x64'; |     }); | ||||||
|  |     let added = await main.addBinToPath(); | ||||||
|  |     expect(added).toBeFalsy(); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|     inputs['go-version'] = '1.13.1'; |   it('adds bin if dir not exists', async () => { | ||||||
|  |     whichSpy.mockImplementation(async () => { | ||||||
|  |       return '/usr/local/go/bin/go'; | ||||||
|  |     }); | ||||||
|  |  | ||||||
|     findSpy.mockImplementation(() => ''); |     execSpy.mockImplementation(() => { | ||||||
|     getSpy.mockImplementation(() => null); |       return '/Users/testuser/go'; | ||||||
|     await run(); |     }); | ||||||
|  |  | ||||||
|     expect(cnSpy).toHaveBeenCalledWith( |     mkdirpSpy.mockImplementation(async () => {}); | ||||||
|       `::error::Failed to download version 1.13.1: Error: golang download url did not return results${osm.EOL}` |     existsSpy.mockImplementation(path => { | ||||||
|     ); |       return false; | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     let added = await main.addBinToPath(); | ||||||
|  |     expect(added).toBeTruthy; | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   interface Annotation { | ||||||
|  |     file: string; | ||||||
|  |     line: number; | ||||||
|  |     column: number; | ||||||
|  |     message: string; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // | ||||||
|  |   // problem matcher regex pattern tests | ||||||
|  |  | ||||||
|  |   function testMatch(line: string): Annotation { | ||||||
|  |     let annotation = <Annotation>{}; | ||||||
|  |  | ||||||
|  |     let match = matcherRegExp.exec(line); | ||||||
|  |     if (match) { | ||||||
|  |       annotation.line = parseInt(match[matcherPattern.line], 10); | ||||||
|  |       annotation.column = parseInt(match[matcherPattern.column], 10); | ||||||
|  |       annotation.file = match[matcherPattern.file].trim(); | ||||||
|  |       annotation.message = match[matcherPattern.message].trim(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return annotation; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   it('matches on relative unix path', async () => { | ||||||
|  |     let line = './main.go:13:2: undefined: fmt.Printl'; | ||||||
|  |     let annotation = testMatch(line); | ||||||
|  |     expect(annotation).toBeDefined(); | ||||||
|  |     expect(annotation.line).toBe(13); | ||||||
|  |     expect(annotation.column).toBe(2); | ||||||
|  |     expect(annotation.file).toBe('./main.go'); | ||||||
|  |     expect(annotation.message).toBe('undefined: fmt.Printl'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('matches on unix path up the tree', async () => { | ||||||
|  |     let line = '../main.go:13:2: undefined: fmt.Printl'; | ||||||
|  |     let annotation = testMatch(line); | ||||||
|  |     expect(annotation).toBeDefined(); | ||||||
|  |     expect(annotation.line).toBe(13); | ||||||
|  |     expect(annotation.column).toBe(2); | ||||||
|  |     expect(annotation.file).toBe('../main.go'); | ||||||
|  |     expect(annotation.message).toBe('undefined: fmt.Printl'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('matches on unix path down the tree', async () => { | ||||||
|  |     let line = 'foo/main.go:13:2: undefined: fmt.Printl'; | ||||||
|  |     let annotation = testMatch(line); | ||||||
|  |     expect(annotation).toBeDefined(); | ||||||
|  |     expect(annotation.line).toBe(13); | ||||||
|  |     expect(annotation.column).toBe(2); | ||||||
|  |     expect(annotation.file).toBe('foo/main.go'); | ||||||
|  |     expect(annotation.message).toBe('undefined: fmt.Printl'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('matches on rooted unix path', async () => { | ||||||
|  |     let line = '/assert.go:4:1: missing return at end of function'; | ||||||
|  |     let annotation = testMatch(line); | ||||||
|  |     expect(annotation).toBeDefined(); | ||||||
|  |     expect(annotation.line).toBe(4); | ||||||
|  |     expect(annotation.column).toBe(1); | ||||||
|  |     expect(annotation.file).toBe('/assert.go'); | ||||||
|  |     expect(annotation.message).toBe('missing return at end of function'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('matches on unix path with spaces', async () => { | ||||||
|  |     let line = '   ./assert.go:5:2: missing return at end of function   '; | ||||||
|  |     let annotation = testMatch(line); | ||||||
|  |     expect(annotation).toBeDefined(); | ||||||
|  |     expect(annotation.line).toBe(5); | ||||||
|  |     expect(annotation.column).toBe(2); | ||||||
|  |     expect(annotation.file).toBe('./assert.go'); | ||||||
|  |     expect(annotation.message).toBe('missing return at end of function'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('matches on unix path with tabs', async () => { | ||||||
|  |     let line = '\t./assert.go:5:2: missing return at end of function   '; | ||||||
|  |     let annotation = testMatch(line); | ||||||
|  |     expect(annotation).toBeDefined(); | ||||||
|  |     expect(annotation.line).toBe(5); | ||||||
|  |     expect(annotation.column).toBe(2); | ||||||
|  |     expect(annotation.file).toBe('./assert.go'); | ||||||
|  |     expect(annotation.message).toBe('missing return at end of function'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('matches on relative windows path', async () => { | ||||||
|  |     let line = '.\\main.go:13:2: undefined: fmt.Printl'; | ||||||
|  |     let annotation = testMatch(line); | ||||||
|  |     expect(annotation).toBeDefined(); | ||||||
|  |     expect(annotation.line).toBe(13); | ||||||
|  |     expect(annotation.column).toBe(2); | ||||||
|  |     expect(annotation.file).toBe('.\\main.go'); | ||||||
|  |     expect(annotation.message).toBe('undefined: fmt.Printl'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('matches on windows path up the tree', async () => { | ||||||
|  |     let line = '..\\main.go:13:2: undefined: fmt.Printl'; | ||||||
|  |     let annotation = testMatch(line); | ||||||
|  |     expect(annotation).toBeDefined(); | ||||||
|  |     expect(annotation.line).toBe(13); | ||||||
|  |     expect(annotation.column).toBe(2); | ||||||
|  |     expect(annotation.file).toBe('..\\main.go'); | ||||||
|  |     expect(annotation.message).toBe('undefined: fmt.Printl'); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   // 1.13.1 => 1.13.1 |   // 1.13.1 => 1.13.1 | ||||||
| @@ -296,4 +574,166 @@ describe('setup-go', () => { | |||||||
|   it('does not convert exact versions', async () => { |   it('does not convert exact versions', async () => { | ||||||
|     expect(im.makeSemver('1.13.1')).toBe('1.13.1'); |     expect(im.makeSemver('1.13.1')).toBe('1.13.1'); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  |   describe('check-latest flag', () => { | ||||||
|  |     it("use local version and don't check manifest if check-latest is not specified", async () => { | ||||||
|  |       os.platform = 'linux'; | ||||||
|  |       os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |       inputs['go-version'] = '1.16'; | ||||||
|  |       inputs['check-latest'] = false; | ||||||
|  |  | ||||||
|  |       const toolPath = path.normalize('/cache/go/1.16.1/x64'); | ||||||
|  |       findSpy.mockReturnValue(toolPath); | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith(`Found in cache @ ${toolPath}`); | ||||||
|  |       expect(logSpy).not.toHaveBeenCalledWith( | ||||||
|  |         'Attempting to resolve the latest version from the manifest...' | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('check latest version and resolve it from local cache', async () => { | ||||||
|  |       os.platform = 'linux'; | ||||||
|  |       os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |       inputs['go-version'] = '1.16'; | ||||||
|  |       inputs['check-latest'] = true; | ||||||
|  |  | ||||||
|  |       const toolPath = path.normalize('/cache/go/1.16.1/x64'); | ||||||
|  |       findSpy.mockReturnValue(toolPath); | ||||||
|  |       dlSpy.mockImplementation(async () => '/some/temp/path'); | ||||||
|  |       exSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |       cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Setup go stable version spec 1.16'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith(`Found in cache @ ${toolPath}`); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('check latest version and install it from manifest', async () => { | ||||||
|  |       os.platform = 'linux'; | ||||||
|  |       os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |       const versionSpec = '1.17'; | ||||||
|  |       const patchVersion = '1.17.6'; | ||||||
|  |       inputs['go-version'] = versionSpec; | ||||||
|  |       inputs['stable'] = 'true'; | ||||||
|  |       inputs['check-latest'] = true; | ||||||
|  |  | ||||||
|  |       findSpy.mockImplementation(() => ''); | ||||||
|  |       dlSpy.mockImplementation(async () => '/some/temp/path'); | ||||||
|  |       const toolPath = path.normalize('/cache/go/1.17.5/x64'); | ||||||
|  |       exSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |       cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |       const expectedUrl = | ||||||
|  |         'https://github.com/actions/go-versions/releases/download/1.17.6-1668090892/go-1.17.6-darwin-x64.tar.gz'; | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         `Setup go stable version spec ${versionSpec}` | ||||||
|  |       ); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         'Attempting to resolve the latest version from the manifest...' | ||||||
|  |       ); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith(`Resolved as '${patchVersion}'`); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         `Attempting to download ${patchVersion}...` | ||||||
|  |       ); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Extracting Go...'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Adding to the cache ...'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Added go to the path'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         `Successfully setup go version ${versionSpec}` | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('fallback to dist if version is not found in manifest', async () => { | ||||||
|  |       os.platform = 'linux'; | ||||||
|  |       os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |       let versionSpec = '1.13'; | ||||||
|  |  | ||||||
|  |       inputs['go-version'] = versionSpec; | ||||||
|  |       inputs['check-latest'] = true; | ||||||
|  |       inputs['always-auth'] = false; | ||||||
|  |       inputs['token'] = 'faketoken'; | ||||||
|  |  | ||||||
|  |       // ... but not in the local cache | ||||||
|  |       findSpy.mockImplementation(() => ''); | ||||||
|  |  | ||||||
|  |       dlSpy.mockImplementation(async () => '/some/temp/path'); | ||||||
|  |       let toolPath = path.normalize('/cache/go/1.13.7/x64'); | ||||||
|  |       exSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |       cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       let expPath = path.join(toolPath, 'bin'); | ||||||
|  |  | ||||||
|  |       expect(dlSpy).toHaveBeenCalled(); | ||||||
|  |       expect(exSpy).toHaveBeenCalled(); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         'Attempting to resolve the latest version from the manifest...' | ||||||
|  |       ); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         `Failed to resolve version ${versionSpec} from manifest` | ||||||
|  |       ); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         `Attempting to download ${versionSpec}...` | ||||||
|  |       ); | ||||||
|  |       expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('fallback to dist if manifest is not available', async () => { | ||||||
|  |       os.platform = 'linux'; | ||||||
|  |       os.arch = 'x64'; | ||||||
|  |  | ||||||
|  |       let versionSpec = '1.13'; | ||||||
|  |  | ||||||
|  |       process.env['GITHUB_PATH'] = ''; | ||||||
|  |  | ||||||
|  |       inputs['go-version'] = versionSpec; | ||||||
|  |       inputs['check-latest'] = true; | ||||||
|  |       inputs['always-auth'] = false; | ||||||
|  |       inputs['token'] = 'faketoken'; | ||||||
|  |  | ||||||
|  |       // ... but not in the local cache | ||||||
|  |       findSpy.mockImplementation(() => ''); | ||||||
|  |       getManifestSpy.mockImplementation(() => { | ||||||
|  |         throw new Error('Unable to download manifest'); | ||||||
|  |       }); | ||||||
|  |  | ||||||
|  |       dlSpy.mockImplementation(async () => '/some/temp/path'); | ||||||
|  |       let toolPath = path.normalize('/cache/go/1.13.7/x64'); | ||||||
|  |       exSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |       cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       let expPath = path.join(toolPath, 'bin'); | ||||||
|  |  | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         `Failed to resolve version ${versionSpec} from manifest` | ||||||
|  |       ); | ||||||
|  |       expect(dlSpy).toHaveBeenCalled(); | ||||||
|  |       expect(exSpy).toHaveBeenCalled(); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         'Attempting to resolve the latest version from the manifest...' | ||||||
|  |       ); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         'Unable to resolve a version from the manifest...' | ||||||
|  |       ); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         `Failed to resolve version ${versionSpec} from manifest` | ||||||
|  |       ); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith( | ||||||
|  |         `Attempting to download ${versionSpec}...` | ||||||
|  |       ); | ||||||
|  |  | ||||||
|  |       expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								__tests__/verify-go.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										14
									
								
								__tests__/verify-go.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  |    | ||||||
|  | #!/bin/sh | ||||||
|  |  | ||||||
|  | if [ -z "$1" ]; then | ||||||
|  |   echo "Must supply go version argument" | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | go_version="$(go version)" | ||||||
|  | echo "Found go version '$go_version'" | ||||||
|  | if [ -z "$(echo $go_version | grep $1)" ]; then | ||||||
|  |   echo "Unexpected version" | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
| @@ -4,9 +4,15 @@ author: 'GitHub' | |||||||
| inputs:  | inputs:  | ||||||
|   go-version: |   go-version: | ||||||
|     description: 'The Go version to download (if necessary) and use. Supports semver spec and ranges.' |     description: 'The Go version to download (if necessary) and use. Supports semver spec and ranges.' | ||||||
|  |   check-latest: | ||||||
|  |     description: 'Set this option to true if you want the action to always check for the latest available version that satisfies the version spec' | ||||||
|  |     default: false | ||||||
|   stable: |   stable: | ||||||
|     description: 'Whether to download only stable versions' |     description: 'Whether to download only stable versions' | ||||||
|     default: 'true' |     default: 'true' | ||||||
|  |   token: | ||||||
|  |     description: Used to pull node distributions from go-versions.  Since there's a default, this is typically not supplied by the user. | ||||||
|  |     default: ${{ github.token }} | ||||||
| runs: | runs: | ||||||
|   using: 'node12' |   using: 'node12' | ||||||
|   main: 'dist/index.js' |   main: 'dist/index.js' | ||||||
|   | |||||||
							
								
								
									
										1958
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1958
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -4,11 +4,11 @@ | |||||||
|             "owner": "go", |             "owner": "go", | ||||||
|             "pattern": [ |             "pattern": [ | ||||||
|                 { |                 { | ||||||
|                     "regexp": "^([^:]*: )?((.:)?[^:]*):(\\d+)(:(\\d+))?: (.*)$", |                     "regexp": "^\\s*(.+\\.go):(?:(\\d+):(\\d+):)? (.*)", | ||||||
|                     "file": 2, |                     "file": 1, | ||||||
|                     "line": 4, |                     "line": 2, | ||||||
|                     "column": 6, |                     "column": 3, | ||||||
|                     "message": 7 |                     "message": 4 | ||||||
|                 } |                 } | ||||||
|             ] |             ] | ||||||
|         } |         } | ||||||
|   | |||||||
							
								
								
									
										5797
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										5797
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										15
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								package.json
									
									
									
									
									
								
							| @@ -23,21 +23,22 @@ | |||||||
|   "author": "GitHub", |   "author": "GitHub", | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@actions/core": "^1.2.2", |     "@actions/core": "^1.6.0", | ||||||
|     "@actions/http-client": "^1.0.6", |     "@actions/http-client": "^1.0.6", | ||||||
|     "@actions/tool-cache": "^1.3.1", |     "@actions/io": "^1.0.2", | ||||||
|  |     "@actions/tool-cache": "^1.5.5", | ||||||
|     "semver": "^6.1.1" |     "semver": "^6.1.1" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/jest": "^24.0.13", |     "@types/jest": "^27.0.2", | ||||||
|     "@types/node": "^12.0.4", |     "@types/node": "^12.0.4", | ||||||
|     "@types/semver": "^6.0.0", |     "@types/semver": "^6.0.0", | ||||||
|     "@zeit/ncc": "^0.21.0", |     "@zeit/ncc": "^0.21.0", | ||||||
|     "jest": "^24.8.0", |     "jest": "^27.2.5", | ||||||
|     "jest-circus": "^24.7.1", |     "jest-circus": "^27.2.5", | ||||||
|     "nock": "^10.0.6", |     "nock": "^10.0.6", | ||||||
|     "prettier": "^1.17.1", |     "prettier": "^1.17.1", | ||||||
|     "ts-jest": "^24.0.2", |     "ts-jest": "^27.0.5", | ||||||
|     "typescript": "^3.5.1" |     "typescript": "^3.8.3" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										250
									
								
								src/installer.ts
									
									
									
									
									
								
							
							
						
						
									
										250
									
								
								src/installer.ts
									
									
									
									
									
								
							| @@ -1,46 +1,12 @@ | |||||||
| import * as tc from '@actions/tool-cache'; | import * as tc from '@actions/tool-cache'; | ||||||
|  | import * as core from '@actions/core'; | ||||||
| import * as path from 'path'; | import * as path from 'path'; | ||||||
| import * as semver from 'semver'; | import * as semver from 'semver'; | ||||||
| import * as httpm from '@actions/http-client'; | import * as httpm from '@actions/http-client'; | ||||||
| import * as sys from './system'; | import * as sys from './system'; | ||||||
| import {debug} from '@actions/core'; | import os from 'os'; | ||||||
|  |  | ||||||
| export async function downloadGo( | type InstallationType = 'dist' | 'manifest'; | ||||||
|   versionSpec: string, |  | ||||||
|   stable: boolean |  | ||||||
| ): Promise<string | undefined> { |  | ||||||
|   let toolPath: string | undefined; |  | ||||||
|  |  | ||||||
|   try { |  | ||||||
|     let match: IGoVersion | undefined = await findMatch(versionSpec, stable); |  | ||||||
|  |  | ||||||
|     if (match) { |  | ||||||
|       // download |  | ||||||
|       debug(`match ${match.version}`); |  | ||||||
|       let downloadUrl: string = `https://storage.googleapis.com/golang/${match.files[0].filename}`; |  | ||||||
|       console.log(`Downloading from ${downloadUrl}`); |  | ||||||
|  |  | ||||||
|       let downloadPath: string = await tc.downloadTool(downloadUrl); |  | ||||||
|       debug(`downloaded to ${downloadPath}`); |  | ||||||
|  |  | ||||||
|       // extract |  | ||||||
|       console.log('Extracting ...'); |  | ||||||
|       let extPath: string = |  | ||||||
|         sys.getPlatform() == 'windows' |  | ||||||
|           ? await tc.extractZip(downloadPath) |  | ||||||
|           : await tc.extractTar(downloadPath); |  | ||||||
|       debug(`extracted to ${extPath}`); |  | ||||||
|  |  | ||||||
|       // extracts with a root folder that matches the fileName downloaded |  | ||||||
|       const toolRoot = path.join(extPath, 'go'); |  | ||||||
|       toolPath = await tc.cacheDir(toolRoot, 'go', versionSpec); |  | ||||||
|     } |  | ||||||
|   } catch (error) { |  | ||||||
|     throw new Error(`Failed to download version ${versionSpec}: ${error}`); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return toolPath; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export interface IGoVersionFile { | export interface IGoVersionFile { | ||||||
|   filename: string; |   filename: string; | ||||||
| @@ -55,6 +21,195 @@ export interface IGoVersion { | |||||||
|   files: IGoVersionFile[]; |   files: IGoVersionFile[]; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | export interface IGoVersionInfo { | ||||||
|  |   type: InstallationType; | ||||||
|  |   downloadUrl: string; | ||||||
|  |   resolvedVersion: string; | ||||||
|  |   fileName: string; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export async function getGo( | ||||||
|  |   versionSpec: string, | ||||||
|  |   stable: boolean, | ||||||
|  |   checkLatest: boolean, | ||||||
|  |   auth: string | undefined | ||||||
|  | ) { | ||||||
|  |   let osPlat: string = os.platform(); | ||||||
|  |   let osArch: string = os.arch(); | ||||||
|  |  | ||||||
|  |   if (checkLatest) { | ||||||
|  |     core.info('Attempting to resolve the latest version from the manifest...'); | ||||||
|  |     const resolvedVersion = await resolveVersionFromManifest( | ||||||
|  |       versionSpec, | ||||||
|  |       stable, | ||||||
|  |       auth | ||||||
|  |     ); | ||||||
|  |     if (resolvedVersion) { | ||||||
|  |       versionSpec = resolvedVersion; | ||||||
|  |       core.info(`Resolved as '${versionSpec}'`); | ||||||
|  |     } else { | ||||||
|  |       core.info(`Failed to resolve version ${versionSpec} from manifest`); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // check cache | ||||||
|  |   let toolPath: string; | ||||||
|  |   toolPath = tc.find('go', versionSpec); | ||||||
|  |   // If not found in cache, download | ||||||
|  |   if (toolPath) { | ||||||
|  |     core.info(`Found in cache @ ${toolPath}`); | ||||||
|  |     return toolPath; | ||||||
|  |   } | ||||||
|  |   core.info(`Attempting to download ${versionSpec}...`); | ||||||
|  |   let downloadPath = ''; | ||||||
|  |   let info: IGoVersionInfo | null = null; | ||||||
|  |  | ||||||
|  |   // | ||||||
|  |   // Try download from internal distribution (popular versions only) | ||||||
|  |   // | ||||||
|  |   try { | ||||||
|  |     info = await getInfoFromManifest(versionSpec, stable, auth); | ||||||
|  |     if (info) { | ||||||
|  |       downloadPath = await installGoVersion(info, auth); | ||||||
|  |     } else { | ||||||
|  |       core.info( | ||||||
|  |         'Not found in manifest.  Falling back to download directly from Go' | ||||||
|  |       ); | ||||||
|  |     } | ||||||
|  |   } catch (err) { | ||||||
|  |     if ( | ||||||
|  |       err instanceof tc.HTTPError && | ||||||
|  |       (err.httpStatusCode === 403 || err.httpStatusCode === 429) | ||||||
|  |     ) { | ||||||
|  |       core.info( | ||||||
|  |         `Received HTTP status code ${err.httpStatusCode}.  This usually indicates the rate limit has been exceeded` | ||||||
|  |       ); | ||||||
|  |     } else { | ||||||
|  |       core.info(err.message); | ||||||
|  |     } | ||||||
|  |     core.debug(err.stack); | ||||||
|  |     core.info('Falling back to download directly from Go'); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // | ||||||
|  |   // Download from storage.googleapis.com | ||||||
|  |   // | ||||||
|  |   if (!downloadPath) { | ||||||
|  |     info = await getInfoFromDist(versionSpec, stable); | ||||||
|  |     if (!info) { | ||||||
|  |       throw new Error( | ||||||
|  |         `Unable to find Go version '${versionSpec}' for platform ${osPlat} and architecture ${osArch}.` | ||||||
|  |       ); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     try { | ||||||
|  |       core.info('Install from dist'); | ||||||
|  |       downloadPath = await installGoVersion(info, undefined); | ||||||
|  |     } catch (err) { | ||||||
|  |       throw new Error(`Failed to download version ${versionSpec}: ${err}`); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return downloadPath; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function resolveVersionFromManifest( | ||||||
|  |   versionSpec: string, | ||||||
|  |   stable: boolean, | ||||||
|  |   auth: string | undefined | ||||||
|  | ): Promise<string | undefined> { | ||||||
|  |   try { | ||||||
|  |     const info = await getInfoFromManifest(versionSpec, stable, auth); | ||||||
|  |     return info?.resolvedVersion; | ||||||
|  |   } catch (err) { | ||||||
|  |     core.info('Unable to resolve a version from the manifest...'); | ||||||
|  |     core.debug(err.message); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function installGoVersion( | ||||||
|  |   info: IGoVersionInfo, | ||||||
|  |   auth: string | undefined | ||||||
|  | ): Promise<string> { | ||||||
|  |   core.info(`Acquiring ${info.resolvedVersion} from ${info.downloadUrl}`); | ||||||
|  |   const downloadPath = await tc.downloadTool(info.downloadUrl, undefined, auth); | ||||||
|  |  | ||||||
|  |   core.info('Extracting Go...'); | ||||||
|  |   let extPath = await extractGoArchive(downloadPath); | ||||||
|  |   core.info(`Successfully extracted go to ${extPath}`); | ||||||
|  |   if (info.type === 'dist') { | ||||||
|  |     extPath = path.join(extPath, 'go'); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   core.info('Adding to the cache ...'); | ||||||
|  |   const cachedDir = await tc.cacheDir( | ||||||
|  |     extPath, | ||||||
|  |     'go', | ||||||
|  |     makeSemver(info.resolvedVersion) | ||||||
|  |   ); | ||||||
|  |   core.info(`Successfully cached go to ${cachedDir}`); | ||||||
|  |   return cachedDir; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export async function extractGoArchive(archivePath: string): Promise<string> { | ||||||
|  |   const platform = os.platform(); | ||||||
|  |   let extPath: string; | ||||||
|  |  | ||||||
|  |   if (platform === 'win32') { | ||||||
|  |     extPath = await tc.extractZip(archivePath); | ||||||
|  |   } else { | ||||||
|  |     extPath = await tc.extractTar(archivePath); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return extPath; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export async function getInfoFromManifest( | ||||||
|  |   versionSpec: string, | ||||||
|  |   stable: boolean, | ||||||
|  |   auth: string | undefined | ||||||
|  | ): Promise<IGoVersionInfo | null> { | ||||||
|  |   let info: IGoVersionInfo | null = null; | ||||||
|  |   const releases = await tc.getManifestFromRepo( | ||||||
|  |     'actions', | ||||||
|  |     'go-versions', | ||||||
|  |     auth, | ||||||
|  |     'main' | ||||||
|  |   ); | ||||||
|  |   core.info(`matching ${versionSpec}...`); | ||||||
|  |   const rel = await tc.findFromManifest(versionSpec, stable, releases); | ||||||
|  |  | ||||||
|  |   if (rel && rel.files.length > 0) { | ||||||
|  |     info = <IGoVersionInfo>{}; | ||||||
|  |     info.type = 'manifest'; | ||||||
|  |     info.resolvedVersion = rel.version; | ||||||
|  |     info.downloadUrl = rel.files[0].download_url; | ||||||
|  |     info.fileName = rel.files[0].filename; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return info; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function getInfoFromDist( | ||||||
|  |   versionSpec: string, | ||||||
|  |   stable: boolean | ||||||
|  | ): Promise<IGoVersionInfo | null> { | ||||||
|  |   let version: IGoVersion | undefined; | ||||||
|  |   version = await findMatch(versionSpec, stable); | ||||||
|  |   if (!version) { | ||||||
|  |     return null; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   let downloadUrl: string = `https://storage.googleapis.com/golang/${version.files[0].filename}`; | ||||||
|  |  | ||||||
|  |   return <IGoVersionInfo>{ | ||||||
|  |     type: 'dist', | ||||||
|  |     downloadUrl: downloadUrl, | ||||||
|  |     resolvedVersion: version.version, | ||||||
|  |     fileName: version.files[0].filename | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  |  | ||||||
| export async function findMatch( | export async function findMatch( | ||||||
|   versionSpec: string, |   versionSpec: string, | ||||||
|   stable: boolean |   stable: boolean | ||||||
| @@ -66,7 +221,9 @@ export async function findMatch( | |||||||
|   let match: IGoVersion | undefined; |   let match: IGoVersion | undefined; | ||||||
|  |  | ||||||
|   const dlUrl: string = 'https://golang.org/dl/?mode=json&include=all'; |   const dlUrl: string = 'https://golang.org/dl/?mode=json&include=all'; | ||||||
|   let candidates: IGoVersion[] | null = await module.exports.getVersions(dlUrl); |   let candidates: IGoVersion[] | null = await module.exports.getVersionsDist( | ||||||
|  |     dlUrl | ||||||
|  |   ); | ||||||
|   if (!candidates) { |   if (!candidates) { | ||||||
|     throw new Error(`golang download url did not return results`); |     throw new Error(`golang download url did not return results`); | ||||||
|   } |   } | ||||||
| @@ -83,18 +240,20 @@ export async function findMatch( | |||||||
|       version = version + '.0'; |       version = version + '.0'; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     debug(`check ${version} satisfies ${versionSpec}`); |     core.debug(`check ${version} satisfies ${versionSpec}`); | ||||||
|     if ( |     if ( | ||||||
|       semver.satisfies(version, versionSpec) && |       semver.satisfies(version, versionSpec) && | ||||||
|       (!stable || candidate.stable === stable) |       (!stable || candidate.stable === stable) | ||||||
|     ) { |     ) { | ||||||
|       goFile = candidate.files.find(file => { |       goFile = candidate.files.find(file => { | ||||||
|         debug(`${file.arch}===${archFilter} && ${file.os}===${platFilter}`); |         core.debug( | ||||||
|  |           `${file.arch}===${archFilter} && ${file.os}===${platFilter}` | ||||||
|  |         ); | ||||||
|         return file.arch === archFilter && file.os === platFilter; |         return file.arch === archFilter && file.os === platFilter; | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|       if (goFile) { |       if (goFile) { | ||||||
|         debug(`matched ${candidate.version}`); |         core.debug(`matched ${candidate.version}`); | ||||||
|         match = candidate; |         match = candidate; | ||||||
|         break; |         break; | ||||||
|       } |       } | ||||||
| @@ -110,9 +269,14 @@ export async function findMatch( | |||||||
|   return result; |   return result; | ||||||
| } | } | ||||||
|  |  | ||||||
| export async function getVersions(dlUrl: string): Promise<IGoVersion[] | null> { | export async function getVersionsDist( | ||||||
|  |   dlUrl: string | ||||||
|  | ): Promise<IGoVersion[] | null> { | ||||||
|   // this returns versions descending so latest is first |   // this returns versions descending so latest is first | ||||||
|   let http: httpm.HttpClient = new httpm.HttpClient('setup-go'); |   let http: httpm.HttpClient = new httpm.HttpClient('setup-go', [], { | ||||||
|  |     allowRedirects: true, | ||||||
|  |     maxRedirects: 3 | ||||||
|  |   }); | ||||||
|   return (await http.getJson<IGoVersion[]>(dlUrl)).result; |   return (await http.getJson<IGoVersion[]>(dlUrl)).result; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										94
									
								
								src/main.ts
									
									
									
									
									
								
							
							
						
						
									
										94
									
								
								src/main.ts
									
									
									
									
									
								
							| @@ -1,7 +1,10 @@ | |||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
| import * as tc from '@actions/tool-cache'; | import * as io from '@actions/io'; | ||||||
| import * as installer from './installer'; | import * as installer from './installer'; | ||||||
| import * as path from 'path'; | import path from 'path'; | ||||||
|  | import cp from 'child_process'; | ||||||
|  | import fs from 'fs'; | ||||||
|  | import {URL} from 'url'; | ||||||
|  |  | ||||||
| export async function run() { | export async function run() { | ||||||
|   try { |   try { | ||||||
| @@ -15,36 +18,81 @@ export async function run() { | |||||||
|     // since getting unstable versions should be explicit |     // since getting unstable versions should be explicit | ||||||
|     let stable = (core.getInput('stable') || 'true').toUpperCase() === 'TRUE'; |     let stable = (core.getInput('stable') || 'true').toUpperCase() === 'TRUE'; | ||||||
|  |  | ||||||
|     console.log( |     core.info(`Setup go ${stable ? 'stable' : ''} version spec ${versionSpec}`); | ||||||
|       `Setup go ${stable ? 'stable' : ''} version spec ${versionSpec}` |  | ||||||
|     ); |  | ||||||
|  |  | ||||||
|     if (versionSpec) { |     if (versionSpec) { | ||||||
|       let installDir: string | undefined = tc.find('go', versionSpec); |       let token = core.getInput('token'); | ||||||
|  |       let auth = !token || isGhes() ? undefined : `token ${token}`; | ||||||
|  |  | ||||||
|       if (!installDir) { |       const checkLatest = core.getBooleanInput('check-latest'); | ||||||
|         console.log( |       const installDir = await installer.getGo( | ||||||
|           `A version satisfying ${versionSpec} not found locally, attempting to download ...` |         versionSpec, | ||||||
|         ); |         stable, | ||||||
|         installDir = await installer.downloadGo(versionSpec, stable); |         checkLatest, | ||||||
|         console.log('Installed'); |         auth | ||||||
|       } |       ); | ||||||
|  |  | ||||||
|       if (installDir) { |       core.exportVariable('GOROOT', installDir); | ||||||
|         core.exportVariable('GOROOT', installDir); |       core.addPath(path.join(installDir, 'bin')); | ||||||
|         core.addPath(path.join(installDir, 'bin')); |       core.info('Added go to the path'); | ||||||
|         console.log('Added go to the path'); |  | ||||||
|       } else { |       let added = await addBinToPath(); | ||||||
|         throw new Error( |       core.debug(`add bin ${added}`); | ||||||
|           `Could not find a version that satisfied version spec: ${versionSpec}` |       core.info(`Successfully setup go version ${versionSpec}`); | ||||||
|         ); |  | ||||||
|       } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // add problem matchers |     // add problem matchers | ||||||
|     const matchersPath = path.join(__dirname, '..', 'matchers.json'); |     const matchersPath = path.join(__dirname, '..', 'matchers.json'); | ||||||
|     console.log(`##[add-matcher]${matchersPath}`); |     core.info(`##[add-matcher]${matchersPath}`); | ||||||
|  |  | ||||||
|  |     // output the version actually being used | ||||||
|  |     let goPath = await io.which('go'); | ||||||
|  |     let goVersion = (cp.execSync(`${goPath} version`) || '').toString(); | ||||||
|  |     core.info(goVersion); | ||||||
|  |  | ||||||
|  |     core.startGroup('go env'); | ||||||
|  |     let goEnv = (cp.execSync(`${goPath} env`) || '').toString(); | ||||||
|  |     core.info(goEnv); | ||||||
|  |     core.endGroup(); | ||||||
|   } catch (error) { |   } catch (error) { | ||||||
|     core.setFailed(error.message); |     core.setFailed(error.message); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | export async function addBinToPath(): Promise<boolean> { | ||||||
|  |   let added = false; | ||||||
|  |   let g = await io.which('go'); | ||||||
|  |   core.debug(`which go :${g}:`); | ||||||
|  |   if (!g) { | ||||||
|  |     core.debug('go not in the path'); | ||||||
|  |     return added; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   let buf = cp.execSync('go env GOPATH'); | ||||||
|  |   if (buf) { | ||||||
|  |     let gp = buf.toString().trim(); | ||||||
|  |     core.debug(`go env GOPATH :${gp}:`); | ||||||
|  |     if (!fs.existsSync(gp)) { | ||||||
|  |       // some of the hosted images have go install but not profile dir | ||||||
|  |       core.debug(`creating ${gp}`); | ||||||
|  |       io.mkdirP(gp); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     let bp = path.join(gp, 'bin'); | ||||||
|  |     if (!fs.existsSync(bp)) { | ||||||
|  |       core.debug(`creating ${bp}`); | ||||||
|  |       io.mkdirP(bp); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     core.addPath(bp); | ||||||
|  |     added = true; | ||||||
|  |   } | ||||||
|  |   return added; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function isGhes(): boolean { | ||||||
|  |   const ghUrl = new URL( | ||||||
|  |     process.env['GITHUB_SERVER_URL'] || 'https://github.com' | ||||||
|  |   ); | ||||||
|  |   return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'; | ||||||
|  | } | ||||||
|   | |||||||
| @@ -4,9 +4,6 @@ | |||||||
|     // "incremental": true,                   /* Enable incremental compilation */ |     // "incremental": true,                   /* Enable incremental compilation */ | ||||||
|     "target": "es6",                          /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019' or 'ESNEXT'. */ |     "target": "es6",                          /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019' or 'ESNEXT'. */ | ||||||
|     "module": "commonjs",                     /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */ |     "module": "commonjs",                     /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */ | ||||||
|     "lib": [ |  | ||||||
|       "es6" |  | ||||||
|     ], |  | ||||||
|     // "allowJs": true,                       /* Allow javascript files to be compiled. */ |     // "allowJs": true,                       /* Allow javascript files to be compiled. */ | ||||||
|     // "checkJs": true,                       /* Report errors in .js files. */ |     // "checkJs": true,                       /* Report errors in .js files. */ | ||||||
|     // "jsx": "preserve",                     /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ |     // "jsx": "preserve",                     /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ | ||||||
| @@ -48,7 +45,8 @@ | |||||||
|     // "typeRoots": [],                       /* List of folders to include type definitions from. */ |     // "typeRoots": [],                       /* List of folders to include type definitions from. */ | ||||||
|     // "types": [],                           /* Type declaration files to be included in compilation. */ |     // "types": [],                           /* Type declaration files to be included in compilation. */ | ||||||
|     // "allowSyntheticDefaultImports": true,  /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ |     // "allowSyntheticDefaultImports": true,  /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ | ||||||
|     "esModuleInterop": true                   /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */ |     "esModuleInterop": true,                  /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */ | ||||||
|  |     "sourceMap": true, | ||||||
|     // "preserveSymlinks": true,              /* Do not resolve the real path of symlinks. */ |     // "preserveSymlinks": true,              /* Do not resolve the real path of symlinks. */ | ||||||
|     // "allowUmdGlobalAccess": true,          /* Allow accessing UMD globals from modules. */ |     // "allowUmdGlobalAccess": true,          /* Allow accessing UMD globals from modules. */ | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user