mirror of
				https://github.com/actions/setup-go.git
				synced 2025-10-22 02:46:23 +00:00 
			
		
		
		
	Compare commits
	
		
			88 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | fcdc43634a | ||
|  | 265edc1beb | ||
|  | 193b404f8a | ||
|  | 56a61c9834 | ||
|  | b46db954a1 | ||
|  | 3332358454 | ||
|  | 46eabca1ab | ||
|  | 07948221be | ||
|  | ad70bef2ef | ||
|  | 4a4352b330 | ||
|  | 115d6e6004 | ||
|  | bf7ccf173e | ||
|  | dcb4ec94ce | ||
|  | 341b20ac36 | ||
|  | a5865a93f2 | ||
|  | 13df686579 | ||
|  | 8e9a229830 | ||
|  | 0b4fbc55f6 | ||
|  | acdbc5377c | ||
|  | 3e6475c089 | ||
|  | 65771601ff | ||
|  | fcc0174ef2 | ||
|  | 75726802f3 | ||
|  | 0c03929337 | ||
|  | 229eefa42b | ||
|  | 802876f7c7 | ||
|  | 2a34c33bd7 | ||
|  | 83124a14b6 | ||
|  | 9a1626044c | ||
|  | 24c791c06c | ||
|  | ec07be593a | ||
|  | f6164bd8c8 | ||
|  | 2bb2aab2fd | ||
|  | edcbc0c2cd | ||
|  | fb9a043dd8 | ||
|  | 5b0ae0e97d | ||
|  | 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 | 
							
								
								
									
										2
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | * text=auto | ||||||
|  | .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@v3 | ||||||
|  |  | ||||||
|  |       - name: Set Node.js 16.x | ||||||
|  |         uses: actions/setup-node@v3 | ||||||
|  |         with: | ||||||
|  |           node-version: 16.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@v3 | ||||||
|  |         if: ${{ failure() && steps.diff.conclusion == 'failure' }} | ||||||
|  |         with: | ||||||
|  |           name: dist | ||||||
|  |           path: dist/ | ||||||
							
								
								
									
										28
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | name: Licensed | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |   pull_request: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   test: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     name: Check licenses | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v3 | ||||||
|  |       - name: Set Node.js 16.x | ||||||
|  |         uses: actions/setup-node@v3 | ||||||
|  |         with: | ||||||
|  |           node-version: 16.x | ||||||
|  |       - run: npm ci | ||||||
|  |       - name: Install licensed | ||||||
|  |         run: | | ||||||
|  |           cd $RUNNER_TEMP | ||||||
|  |           curl -Lfs -o licensed.tar.gz https://github.com/github/licensed/releases/download/3.4.4/licensed-3.4.4-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 }} | ||||||
							
								
								
									
										124
									
								
								.github/workflows/versions.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										124
									
								
								.github/workflows/versions.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,51 +1,109 @@ | |||||||
| 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@v3 | ||||||
|  |  | ||||||
|     - 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." |         run: __tests__/verify-go.sh ${{ matrix.go }} | ||||||
|  |         shell: bash | ||||||
|     - name: setup-go 1.13 |  | ||||||
|       uses: ./ |   check-latest: | ||||||
|       with: |     runs-on: ${{ matrix.os }} | ||||||
|         go-version: 1.13 |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|     - name: validate version  |       matrix: | ||||||
|       run: go version | grep "go1.13."       |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|  |         go-version: [1.16, 1.17] | ||||||
|     - name: setup-go 1.12.9 |     steps: | ||||||
|       uses: ./ |       - uses: actions/checkout@v3 | ||||||
|       with: |       - name: Setup Go and check latest | ||||||
|         go-version: 1.12.9 |         uses: ./ | ||||||
|  |         with: | ||||||
|     - name: validate version  |           go-version: ${{ matrix.go-version }} | ||||||
|       run: go version | grep "go1.12.9" |           check-latest: true | ||||||
|  |       - name: Verify Go | ||||||
|     - name: dump env |         run: go version | ||||||
|  |  | ||||||
|  |   go-version-file: | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v3 | ||||||
|  |       - name: Setup Go and check latest | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           go-version-file: __tests__/data/go.mod | ||||||
|  |       - name: verify go | ||||||
|  |         run: __tests__/verify-go.sh 1.14 | ||||||
|  |         shell: bash | ||||||
|  |  | ||||||
|  |   setup-versions-from-manifest: | ||||||
|  |     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@v3 | ||||||
|  |  | ||||||
|  |       - name: setup-go ${{ matrix.go }} | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           go-version: ${{ matrix.go }} | ||||||
|  |  | ||||||
|  |       - name: verify go | ||||||
|  |         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.9, 1.8.6] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|  |       - name: setup-go ${{ matrix.go }} | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           go-version: ${{ matrix.go }} | ||||||
|  |  | ||||||
|  |       - name: verify go | ||||||
|  |         run: __tests__/verify-go.sh ${{ matrix.go }} | ||||||
|         shell: bash |         shell: bash | ||||||
|       run: | |  | ||||||
|         echo $PATH |  | ||||||
|         echo go versions in tool cache:  |  | ||||||
|         echo $(ls $RUNNER_TOOL_CACHE/go)        |  | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								.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: | ||||||
| @@ -17,15 +17,16 @@ jobs: | |||||||
|         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@v3 | ||||||
|  |  | ||||||
|     - name: Setup node 12 |       - name: Setup node 16 | ||||||
|       uses: actions/setup-node@v1 |         uses: actions/setup-node@v3 | ||||||
|         with: |         with: | ||||||
|         node-version: 12 |           node-version: 16 | ||||||
|  |           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 | ||||||
|   | |||||||
							
								
								
									
										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/actions-service | ||||||
| @@ -55,7 +55,7 @@ a project may be further defined and clarified by project maintainers. | |||||||
| ## Enforcement | ## Enforcement | ||||||
| 
 | 
 | ||||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be | Instances of abusive, harassing, or otherwise unacceptable behavior may be | ||||||
| reported by contacting the project team at opensource@github.com. All | reported by contacting the project team at opensource+actions/setup-go@github.com. All | ||||||
| complaints will be reviewed and investigated and will result in a response that | complaints will be reviewed and investigated and will result in a response that | ||||||
| is deemed necessary and appropriate to the circumstances. The project team is | is deemed necessary and appropriate to the circumstances. The project team is | ||||||
| obligated to maintain confidentiality with regard to the reporter of an incident. | obligated to maintain confidentiality with regard to the reporter of an incident. | ||||||
							
								
								
									
										125
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										125
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,41 +1,63 @@ | |||||||
| # setup-go | # setup-go | ||||||
|  |  | ||||||
| <p align="left"> | [](https://github.com/actions/setup-go/actions/workflows/workflow.yml) | ||||||
|   <a href="https://github.com/actions/setup-go/actions"><img alt="GitHub Actions status" src="https://github.com/actions/setup-go/workflows/build-test/badge.svg"></a> | [](https://github.com/actions/setup-go/actions/workflows/versions.yml) | ||||||
|  |  | ||||||
|   <a href="https://github.com/actions/setup-go/actions"><img alt="versions status" src="https://github.com/actions/setup-go/workflows/go-versions/badge.svg"></a>   |  | ||||||
| </p> |  | ||||||
|  |  | ||||||
| This action sets up a go environment for use in actions by: | 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 | # V3 | ||||||
|  |  | ||||||
| The V2 beta offers: | The V3 edition of the action offers: | ||||||
| - Proxy Support |  | ||||||
| - stable input  | - Adds `GOBIN` to the `PATH` | ||||||
| - Bug Fixes (including issues around version matching and semver) | - Proxy support | ||||||
|  | - Check latest version | ||||||
|  | - Bug fixes (including issues around version matching and semver) | ||||||
|  |  | ||||||
|  | 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). | ||||||
|  |  | ||||||
|  | **Note:** The `setup-go` action uses executable binaries which are built by Golang side. The action does not build golang from source code. | ||||||
|  |  | ||||||
|  | Matching by [semver spec](https://github.com/npm/node-semver): | ||||||
|  |  | ||||||
| Matching by semver spec: |  | ||||||
| ```yaml | ```yaml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v2 |   - uses: actions/checkout@v3 | ||||||
| - uses: actions/setup-go@v2-beta |   - uses: actions/setup-go@v3 | ||||||
|     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: |  | ||||||
| ```yaml | ```yaml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@v2 |   - uses: actions/checkout@v3 | ||||||
| - uses: actions/setup-go@v2-beta |   - uses: actions/setup-go@v3 | ||||||
|     with: |     with: | ||||||
|     stable: 'false' |       go-version: '>=1.17.0' | ||||||
|     go-version: '1.14.0-rc1' # The Go version to download (if necessary) and use. |   - run: go version | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Matching an unstable pre-release: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | steps: | ||||||
|  |   - uses: actions/checkout@v3 | ||||||
|  |   - uses: actions/setup-go@v3 | ||||||
|  |     with: | ||||||
|  |       go-version: '1.18.0-rc.1' # The Go version to download (if necessary) and use. | ||||||
|  |   - run: go version | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | steps: | ||||||
|  |   - uses: actions/checkout@v3 | ||||||
|  |   - uses: actions/setup-go@v3 | ||||||
|  |     with: | ||||||
|  |       go-version: '1.16.0-beta.1' # The Go version to download (if necessary) and use. | ||||||
|   - run: go version |   - run: go version | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -43,34 +65,79 @@ steps: | |||||||
|  |  | ||||||
| See [action.yml](action.yml) | See [action.yml](action.yml) | ||||||
|  |  | ||||||
| Basic: | ## Basic | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| steps: | steps: | ||||||
| - uses: actions/checkout@master |   - uses: actions/checkout@v3 | ||||||
| - uses: actions/setup-go@v1 |   - uses: actions/setup-go@v3 | ||||||
|     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@v3 | ||||||
|  |   - uses: actions/setup-go@v3 | ||||||
|  |     with: | ||||||
|  |       go-version: '1.14' | ||||||
|  |       check-latest: true | ||||||
|  |   - run: go run hello.go | ||||||
|  | ``` | ||||||
|  | ## Getting go version from the go.mod file | ||||||
|  |  | ||||||
|  | The `go-version-file` input accepts a path to a `go.mod` file containing the version of Go to be used by a project. As the `go.mod` file contains only major and minor (e.g. 1.18) tags, the action will search for the latest available patch version sequentially in the runner's directory with the cached tools, in the [version-manifest.json](https://github.com/actions/go-versions/blob/main/versions-manifest.json) file or at the go servers. | ||||||
|  |  | ||||||
|  | If both the `go-version` and the `go-version-file` inputs are provided then the `go-version` input is used. | ||||||
|  | > The action will search for the `go.mod` file relative to the repository root | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | steps: | ||||||
|  | - uses: actions/checkout@v3 | ||||||
|  | - uses: actions/setup-go@v3 | ||||||
|  |   with: | ||||||
|  |     go-version-file: 'path/to/go.mod' | ||||||
|  | - run: go version | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## 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@v3 | ||||||
|       - name: Setup go |       - name: Setup go | ||||||
|         uses: actions/setup-go@v1 |         uses: actions/setup-go@v3 | ||||||
|         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-rc.2`, `1.16.0-beta.1` | ||||||
|  | - SemVer's version range syntax: `^1.13.1`, `>=1.18.0-rc.1` | ||||||
|  |  | ||||||
|  | For more information about semantic versioning, please refer to [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) | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								__tests__/data/go.mod
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								__tests__/data/go.mod
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | module example.com/mymodule | ||||||
|  |  | ||||||
|  | go 1.14 | ||||||
|  |  | ||||||
|  | require ( | ||||||
|  | 	example.com/othermodule v1.2.3 | ||||||
|  | 	example.com/thismodule v1.2.3 | ||||||
|  | 	example.com/thatmodule v1.2.3 | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | replace example.com/thatmodule => ../thatmodule | ||||||
|  | exclude example.com/thismodule v1.3.0 | ||||||
							
								
								
									
										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,26 @@ | |||||||
| 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 exportVarSpy: 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; | ||||||
| @@ -23,71 +28,127 @@ describe('setup-go', () => { | |||||||
|   let platSpy: jest.SpyInstance; |   let platSpy: jest.SpyInstance; | ||||||
|   let archSpy: jest.SpyInstance; |   let archSpy: jest.SpyInstance; | ||||||
|   let dlSpy: jest.SpyInstance; |   let dlSpy: jest.SpyInstance; | ||||||
|   let exSpy: jest.SpyInstance; |   let extractTarSpy: jest.SpyInstance; | ||||||
|   let cacheSpy: jest.SpyInstance; |   let cacheSpy: jest.SpyInstance; | ||||||
|  |   let dbgSpy: jest.SpyInstance; | ||||||
|  |   let whichSpy: jest.SpyInstance; | ||||||
|  |   let existsSpy: jest.SpyInstance; | ||||||
|  |   let readFileSpy: 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]); | ||||||
|  |     exportVarSpy = jest.spyOn(core, 'exportVariable'); | ||||||
|  |  | ||||||
|     // 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'); |     extractTarSpy = 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'); | ||||||
|  |     readFileSpy = jest.spyOn(fs, 'readFileSync'); | ||||||
|  |     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 extract the major.minor.patch version from a given Go version string', async () => { | ||||||
|     let versions: im.IGoVersion[] | null = await im.getVersions( |     const goVersionOutput = 'go version go1.16.6 darwin/amd64'; | ||||||
|       'https://non.existant.com/path' |     expect(main.parseGoVersion(goVersionOutput)).toBe('1.16.6'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('can find 1.9.7 from manifest on osx', async () => { | ||||||
|  |     os.platform = 'darwin'; | ||||||
|  |     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 () => { | ||||||
| @@ -95,7 +156,7 @@ describe('setup-go', () => { | |||||||
|     os.arch = 'x64'; |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|     // spec: 1.13.0 => 1.13 |     // spec: 1.13.0 => 1.13 | ||||||
|     let match: im.IGoVersion | undefined = await im.findMatch('1.13.0', true); |     let match: im.IGoVersion | undefined = await im.findMatch('1.13.0'); | ||||||
|     expect(match).toBeDefined(); |     expect(match).toBeDefined(); | ||||||
|     let version: string = match ? match.version : ''; |     let version: string = match ? match.version : ''; | ||||||
|     expect(version).toBe('go1.13'); |     expect(version).toBe('go1.13'); | ||||||
| @@ -108,7 +169,7 @@ describe('setup-go', () => { | |||||||
|     os.arch = 'x64'; |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|     // spec: 1.13 => 1.13.7 (latest) |     // spec: 1.13 => 1.13.7 (latest) | ||||||
|     let match: im.IGoVersion | undefined = await im.findMatch('1.13', true); |     let match: im.IGoVersion | undefined = await im.findMatch('1.13'); | ||||||
|     expect(match).toBeDefined(); |     expect(match).toBeDefined(); | ||||||
|     let version: string = match ? match.version : ''; |     let version: string = match ? match.version : ''; | ||||||
|     expect(version).toBe('go1.13.7'); |     expect(version).toBe('go1.13.7'); | ||||||
| @@ -121,7 +182,7 @@ describe('setup-go', () => { | |||||||
|     os.arch = 'x64'; |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|     // spec: ^1.13.6 => 1.13.7 |     // spec: ^1.13.6 => 1.13.7 | ||||||
|     let match: im.IGoVersion | undefined = await im.findMatch('^1.13.6', true); |     let match: im.IGoVersion | undefined = await im.findMatch('^1.13.6'); | ||||||
|     expect(match).toBeDefined(); |     expect(match).toBeDefined(); | ||||||
|     let version: string = match ? match.version : ''; |     let version: string = match ? match.version : ''; | ||||||
|     expect(version).toBe('go1.13.7'); |     expect(version).toBe('go1.13.7'); | ||||||
| @@ -134,7 +195,7 @@ describe('setup-go', () => { | |||||||
|     os.arch = 'x32'; |     os.arch = 'x32'; | ||||||
|  |  | ||||||
|     // spec: 1 => 1.13.7 (latest) |     // spec: 1 => 1.13.7 (latest) | ||||||
|     let match: im.IGoVersion | undefined = await im.findMatch('1', true); |     let match: im.IGoVersion | undefined = await im.findMatch('1'); | ||||||
|     expect(match).toBeDefined(); |     expect(match).toBeDefined(); | ||||||
|     let version: string = match ? match.version : ''; |     let version: string = match ? match.version : ''; | ||||||
|     expect(version).toBe('go1.13.7'); |     expect(version).toBe('go1.13.7'); | ||||||
| @@ -147,10 +208,7 @@ describe('setup-go', () => { | |||||||
|     os.arch = 'x64'; |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|     // spec: 1.14, stable=false => go1.14rc1 |     // spec: 1.14, stable=false => go1.14rc1 | ||||||
|     let match: im.IGoVersion | undefined = await im.findMatch( |     let match: im.IGoVersion | undefined = await im.findMatch('1.14.0-rc.1'); | ||||||
|       '1.14.0-rc1', |  | ||||||
|       false |  | ||||||
|     ); |  | ||||||
|     expect(match).toBeDefined(); |     expect(match).toBeDefined(); | ||||||
|     let version: string = match ? match.version : ''; |     let version: string = match ? match.version : ''; | ||||||
|     expect(version).toBe('go1.14rc1'); |     expect(version).toBe('go1.14rc1'); | ||||||
| @@ -164,9 +222,9 @@ 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 version spec 1.13.0`); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('evaluates to stable with no input', async () => { |   it('evaluates to stable with no input', async () => { | ||||||
| @@ -176,9 +234,43 @@ 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 version spec 1.13.0`); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('does not export any variables for Go versions >=1.9', async () => { | ||||||
|  |     inputs['go-version'] = '1.13.0'; | ||||||
|  |     inSpy.mockImplementation(name => inputs[name]); | ||||||
|  |  | ||||||
|  |     let toolPath = path.normalize('/cache/go/1.13.0/x64'); | ||||||
|  |     findSpy.mockImplementation(() => toolPath); | ||||||
|  |  | ||||||
|  |     let vars: {[key: string]: string} = {}; | ||||||
|  |     exportVarSpy.mockImplementation((name: string, val: string) => { | ||||||
|  |       vars[name] = val; | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     await main.run(); | ||||||
|  |     expect(vars).toStrictEqual({}); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('exports GOROOT for Go versions <1.9', async () => { | ||||||
|  |     inputs['go-version'] = '1.8'; | ||||||
|  |     inSpy.mockImplementation(name => inputs[name]); | ||||||
|  |  | ||||||
|  |     let toolPath = path.normalize('/cache/go/1.8.0/x64'); | ||||||
|  |     findSpy.mockImplementation(() => toolPath); | ||||||
|  |  | ||||||
|  |     let vars: {[key: string]: string} = {}; | ||||||
|  |     exportVarSpy.mockImplementation((name: string, val: string) => { | ||||||
|  |       vars[name] = val; | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     await main.run(); | ||||||
|  |     expect(vars).toStrictEqual({ | ||||||
|  |       GOROOT: toolPath | ||||||
|  |     }); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('finds a version of go already in the cache', async () => { |   it('finds a version of go already in the cache', async () => { | ||||||
| @@ -186,16 +278,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 +301,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); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -221,14 +314,14 @@ describe('setup-go', () => { | |||||||
|     findSpy.mockImplementation(() => ''); |     findSpy.mockImplementation(() => ''); | ||||||
|     dlSpy.mockImplementation(() => '/some/temp/path'); |     dlSpy.mockImplementation(() => '/some/temp/path'); | ||||||
|     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'); |     extractTarSpy.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'); | ||||||
|  |  | ||||||
|     expect(dlSpy).toHaveBeenCalled(); |     expect(dlSpy).toHaveBeenCalled(); | ||||||
|     expect(exSpy).toHaveBeenCalled(); |     expect(extractTarSpy).toHaveBeenCalled(); | ||||||
|     expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); |     expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -239,13 +332,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'); | ||||||
|  |     extractTarSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |     cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |     await main.run(); | ||||||
|  |  | ||||||
|  |     let expPath = path.join(toolPath, 'bin'); | ||||||
|  |  | ||||||
|  |     expect(dlSpy).toHaveBeenCalled(); | ||||||
|  |     expect(extractTarSpy).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'); | ||||||
|  |     extractTarSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |     cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |     await main.run(); | ||||||
|  |  | ||||||
|  |     let expPath = path.join(toolPath, 'bin'); | ||||||
|  |  | ||||||
|  |     expect(dlSpy).toHaveBeenCalled(); | ||||||
|  |     expect(extractTarSpy).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'); | ||||||
|  |     extractTarSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |     cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |     await main.run(); | ||||||
|  |  | ||||||
|  |     let expPath = path.join(toolPath, 'bin'); | ||||||
|  |     expect(logSpy).toHaveBeenCalledWith('Setup go 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(extractTarSpy).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,36 +461,150 @@ 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 | ||||||
|   // 1.13 => 1.13.0 |   // 1.13 => 1.13.0 | ||||||
|   // 1.10beta1 => 1.10.0-beta1, 1.10rc1 => 1.10.0-rc1 |   // 1.10beta1 => 1.10.0-beta.1, 1.10rc1 => 1.10.0-rc.1 | ||||||
|   // 1.8.5beta1 => 1.8.5-beta1, 1.8.5rc1 => 1.8.5-rc1 |   // 1.8.5beta1 => 1.8.5-beta.1, 1.8.5rc1 => 1.8.5-rc.1 | ||||||
|   it('converts prerelease versions', async () => { |   it('converts prerelease versions', async () => { | ||||||
|     expect(im.makeSemver('1.10beta1')).toBe('1.10.0-beta1'); |     expect(im.makeSemver('1.10beta1')).toBe('1.10.0-beta.1'); | ||||||
|     expect(im.makeSemver('1.10rc1')).toBe('1.10.0-rc1'); |     expect(im.makeSemver('1.10rc1')).toBe('1.10.0-rc.1'); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('converts dot zero versions', async () => { |   it('converts dot zero versions', async () => { | ||||||
| @@ -296,4 +614,230 @@ 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'); | ||||||
|  |       extractTarSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |       cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Setup go 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'); | ||||||
|  |       extractTarSpy.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 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 set up 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'); | ||||||
|  |       extractTarSpy.mockImplementation(async () => '/some/other/temp/path'); | ||||||
|  |       cacheSpy.mockImplementation(async () => toolPath); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       let expPath = path.join(toolPath, 'bin'); | ||||||
|  |  | ||||||
|  |       expect(dlSpy).toHaveBeenCalled(); | ||||||
|  |       expect(extractTarSpy).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'); | ||||||
|  |       extractTarSpy.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(extractTarSpy).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}`); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   describe('go-version-file', () => { | ||||||
|  |     const goModContents = `module example.com/mymodule | ||||||
|  |  | ||||||
|  | go 1.14 | ||||||
|  |  | ||||||
|  | require ( | ||||||
|  | 	example.com/othermodule v1.2.3 | ||||||
|  | 	example.com/thismodule v1.2.3 | ||||||
|  | 	example.com/thatmodule v1.2.3 | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | replace example.com/thatmodule => ../thatmodule | ||||||
|  | exclude example.com/thismodule v1.3.0 | ||||||
|  | `; | ||||||
|  |  | ||||||
|  |     it('reads version from go.mod', async () => { | ||||||
|  |       inputs['go-version-file'] = 'go.mod'; | ||||||
|  |       existsSpy.mockImplementation(path => true); | ||||||
|  |       readFileSpy.mockImplementation(() => Buffer.from(goModContents)); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Setup go version spec 1.14'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Attempting to download 1.14...'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('matching 1.14...'); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('reads version from .go-version', async () => { | ||||||
|  |       inputs['go-version-file'] = '.go-version'; | ||||||
|  |       existsSpy.mockImplementation(path => true); | ||||||
|  |       readFileSpy.mockImplementation(() => Buffer.from(`1.13.0${osm.EOL}`)); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Setup go version spec 1.13.0'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Attempting to download 1.13.0...'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('matching 1.13.0...'); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('is overwritten by go-version', async () => { | ||||||
|  |       inputs['go-version'] = '1.13.1'; | ||||||
|  |       inputs['go-version-file'] = 'go.mod'; | ||||||
|  |       existsSpy.mockImplementation(path => true); | ||||||
|  |       readFileSpy.mockImplementation(() => Buffer.from(goModContents)); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Setup go version spec 1.13.1'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('Attempting to download 1.13.1...'); | ||||||
|  |       expect(logSpy).toHaveBeenCalledWith('matching 1.13.1...'); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('reports a read failure', async () => { | ||||||
|  |       inputs['go-version-file'] = 'go.mod'; | ||||||
|  |       existsSpy.mockImplementation(path => false); | ||||||
|  |  | ||||||
|  |       await main.run(); | ||||||
|  |  | ||||||
|  |       expect(cnSpy).toHaveBeenCalledWith( | ||||||
|  |         `::error::The specified go version file at: go.mod does not exist${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 | ||||||
							
								
								
									
										16
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								action.yml
									
									
									
									
									
								
							| @@ -4,9 +4,17 @@ 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.' | ||||||
|   stable: |   go-version-file: | ||||||
|     description: 'Whether to download only stable versions' |     description: 'Path to the go.mod file.' | ||||||
|     default: 'true' |   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 | ||||||
|  |   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 }} | ||||||
|  | outputs: | ||||||
|  |   go-version: | ||||||
|  |     description: 'The installed Go version. Useful when given a version range as input.' | ||||||
| runs: | runs: | ||||||
|   using: 'node12' |   using: 'node16' | ||||||
|   main: 'dist/index.js' |   main: 'dist/index.js' | ||||||
|   | |||||||
							
								
								
									
										6557
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6557
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										69
									
								
								docs/adrs/0000-caching-dependencies.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								docs/adrs/0000-caching-dependencies.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | |||||||
|  | # 0. Caching dependencies | ||||||
|  | Date: 2022-04-13 | ||||||
|  |  | ||||||
|  | Status: Accepted | ||||||
|  |  | ||||||
|  | # Context | ||||||
|  | `actions/setup-go` is the one of the most popular action related to Golang in GitHub Actions. Many customers use it in conjunction with [actions/cache](https://github.com/actions/cache) to speed up dependency installation process.   | ||||||
|  | See more examples on proper usage in [actions/cache documentation](https://github.com/actions/cache/blob/main/examples.md#go---modules). | ||||||
|  |  | ||||||
|  | # Goals & Anti-Goals | ||||||
|  | Integration of caching functionality into `actions/setup-go` action will bring the following benefits for action users: | ||||||
|  | - Decrease the entry threshold for using the cache for Go dependencies and simplify initial configuration | ||||||
|  | - Simplify YAML pipelines because there will be no need for additional steps to enable caching | ||||||
|  | - More users will use cache for Go so more customers will have fast builds! | ||||||
|  |  | ||||||
|  | We don't pursue the goal to provide wide customization of caching in scope of `actions/setup-go` action. The purpose of this integration is covering ~90% of basic use-cases. If user needs flexible customization, we should advice them to use `actions/cache` directly. | ||||||
|  |  | ||||||
|  | # Decision | ||||||
|  | - Add `cache` input parameter to `actions/setup-go`. For now, input will accept the following values:  | ||||||
|  |   - `true` - enable caching for go dependencies | ||||||
|  |   - `false`- disable caching for go dependencies. This value will be set as default value | ||||||
|  | - Cache feature will be disabled by default to make sure that we don't break existing customers. We will consider enabling cache by default in next major releases | ||||||
|  | - Action will try to search a go.sum files in the repository and throw error in the scenario that it was not found | ||||||
|  | - The hash of found file will be used as cache key (the same approach like [actions/cache](https://github.com/actions/cache/blob/main/examples.md#go---modules) recommends) | ||||||
|  | - The following key cache will be used `${{ runner.os }}-go${{ go-version }}-${{ hashFiles('<go.sum-path>') }}` | ||||||
|  | - Action will cache global cache from the `go env GOMODCACHE` and `go env GOCACHE` commands. | ||||||
|  | - Add a `cache-dependency-path` input parameter to `actions/setup-go`. The new input will accept an array or regex of dependency files. The field will accept a path (relative to the repository root) to dependency files. If the provided path contains wildcards, the action will search all matching files and calculate a common hash like the ${{ hashFiles('**/go.sum') }} YAML construction does. | ||||||
|  |  | ||||||
|  | # Example of real use-cases | ||||||
|  |  | ||||||
|  |  - With cache | ||||||
|  |  | ||||||
|  | ```yml | ||||||
|  | steps: | ||||||
|  | - uses: actions/checkout@v3 | ||||||
|  | - uses: actions/setup-go@v3 | ||||||
|  |   with: | ||||||
|  |     go-version: '18' | ||||||
|  |     cache: true | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  - With cache-dependency-path | ||||||
|  |  | ||||||
|  |  ```yml | ||||||
|  | steps: | ||||||
|  | - uses: actions/checkout@v3 | ||||||
|  | - uses: actions/setup-go@v3 | ||||||
|  |   with: | ||||||
|  |     go-version: '18' | ||||||
|  |     cache: true | ||||||
|  |     cache-dependency-path: **/go.sum | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  ```yml | ||||||
|  | steps: | ||||||
|  | - uses: actions/checkout@v3 | ||||||
|  | - uses: actions/setup-go@v3 | ||||||
|  |   with: | ||||||
|  |     go-version: '18' | ||||||
|  |     cache: true | ||||||
|  |     cache-dependency-path: | | ||||||
|  |         **/go.sum | ||||||
|  |         **/go.mod | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | # Release process | ||||||
|  |  | ||||||
|  | As soon as functionality is implemented, we will release minor update of action. No need to bump major version since there are no breaking changes for existing users. | ||||||
|  | After that, we will update [starter-workflows](https://github.com/actions/starter-workflows/blob/main/ci/go.yml) | ||||||
| @@ -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 | ||||||
|                 } |                 } | ||||||
|             ] |             ] | ||||||
|         } |         } | ||||||
|   | |||||||
							
								
								
									
										18792
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										18792
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										18
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								package.json
									
									
									
									
									
								
							| @@ -23,22 +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/io": "^1.0.2", |     "@actions/io": "^1.0.2", | ||||||
|     "@actions/tool-cache": "^1.3.3", |     "@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": "^16.11.25", | ||||||
|     "@types/semver": "^6.0.0", |     "@types/semver": "^6.0.0", | ||||||
|     "@zeit/ncc": "^0.21.0", |     "@vercel/ncc": "^0.33.4", | ||||||
|     "jest": "^25.2.1", |     "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" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										305
									
								
								src/installer.ts
									
									
									
									
									
								
							
							
						
						
									
										305
									
								
								src/installer.ts
									
									
									
									
									
								
							| @@ -1,46 +1,13 @@ | |||||||
| 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 fs from 'fs'; | ||||||
|  | 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', makeSemver(match.version)); |  | ||||||
|     } |  | ||||||
|   } catch (error) { |  | ||||||
|     throw new Error(`Failed to download version ${versionSpec}: ${error}`); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return toolPath; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export interface IGoVersionFile { | export interface IGoVersionFile { | ||||||
|   filename: string; |   filename: string; | ||||||
| @@ -55,9 +22,195 @@ export interface IGoVersion { | |||||||
|   files: IGoVersionFile[]; |   files: IGoVersionFile[]; | ||||||
| } | } | ||||||
|  |  | ||||||
| export async function findMatch( | export interface IGoVersionInfo { | ||||||
|  |   type: InstallationType; | ||||||
|  |   downloadUrl: string; | ||||||
|  |   resolvedVersion: string; | ||||||
|  |   fileName: string; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export async function getGo( | ||||||
|   versionSpec: string, |   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, | ||||||
|  |       true, | ||||||
|  |       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, true, 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); | ||||||
|  |     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 | ||||||
|  | ): Promise<IGoVersionInfo | null> { | ||||||
|  |   let version: IGoVersion | undefined; | ||||||
|  |   version = await findMatch(versionSpec); | ||||||
|  |   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( | ||||||
|  |   versionSpec: string | ||||||
| ): Promise<IGoVersion | undefined> { | ): Promise<IGoVersion | undefined> { | ||||||
|   let archFilter = sys.getArch(); |   let archFilter = sys.getArch(); | ||||||
|   let platFilter = sys.getPlatform(); |   let platFilter = sys.getPlatform(); | ||||||
| @@ -66,7 +219,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`); | ||||||
|   } |   } | ||||||
| @@ -76,25 +231,17 @@ export async function findMatch( | |||||||
|     let candidate: IGoVersion = candidates[i]; |     let candidate: IGoVersion = candidates[i]; | ||||||
|     let version = makeSemver(candidate.version); |     let version = makeSemver(candidate.version); | ||||||
|  |  | ||||||
|     // 1.13.0 is advertised as 1.13 preventing being able to match exactly 1.13.0 |     core.debug(`check ${version} satisfies ${versionSpec}`); | ||||||
|     // since a semver of 1.13 would match latest 1.13 |     if (semver.satisfies(version, versionSpec)) { | ||||||
|     let parts: string[] = version.split('.'); |  | ||||||
|     if (parts.length == 2) { |  | ||||||
|       version = version + '.0'; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     debug(`check ${version} satisfies ${versionSpec}`); |  | ||||||
|     if ( |  | ||||||
|       semver.satisfies(version, versionSpec) && |  | ||||||
|       (!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 +257,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; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -120,20 +272,41 @@ export async function getVersions(dlUrl: string): Promise<IGoVersion[] | null> { | |||||||
| // Convert the go version syntax into semver for semver matching | // Convert the go version syntax into semver for semver matching | ||||||
| // 1.13.1 => 1.13.1 | // 1.13.1 => 1.13.1 | ||||||
| // 1.13 => 1.13.0 | // 1.13 => 1.13.0 | ||||||
| // 1.10beta1 => 1.10.0-beta1, 1.10rc1 => 1.10.0-rc1 | // 1.10beta1 => 1.10.0-beta.1, 1.10rc1 => 1.10.0-rc.1 | ||||||
| // 1.8.5beta1 => 1.8.5-beta1, 1.8.5rc1 => 1.8.5-rc1 | // 1.8.5beta1 => 1.8.5-beta.1, 1.8.5rc1 => 1.8.5-rc.1 | ||||||
| export function makeSemver(version: string): string { | export function makeSemver(version: string): string { | ||||||
|   version = version.replace('go', ''); |   version = version.replace('go', ''); | ||||||
|   version = version.replace('beta', '-beta').replace('rc', '-rc'); |   version = version.replace('beta', '-beta.').replace('rc', '-rc.'); | ||||||
|   let parts = version.split('-'); |   let parts = version.split('-'); | ||||||
|  |  | ||||||
|   let verPart: string = parts[0]; |   let semVersion = semver.coerce(parts[0])?.version; | ||||||
|   let prereleasePart = parts.length > 1 ? `-${parts[1]}` : ''; |   if (!semVersion) { | ||||||
|  |     throw new Error( | ||||||
|   let verParts: string[] = verPart.split('.'); |       `The version: ${version} can't be changed to SemVer notation` | ||||||
|   if (verParts.length == 2) { |     ); | ||||||
|     verPart += '.0'; |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   return `${verPart}${prereleasePart}`; |   if (!parts[1]) { | ||||||
|  |     return semVersion; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const fullVersion = semver.valid(`${semVersion}-${parts[1]}`); | ||||||
|  |  | ||||||
|  |   if (!fullVersion) { | ||||||
|  |     throw new Error( | ||||||
|  |       `The version: ${version} can't be changed to SemVer notation` | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |   return fullVersion; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function parseGoVersionFile(versionFilePath: string): string { | ||||||
|  |   const contents = fs.readFileSync(versionFilePath).toString(); | ||||||
|  |  | ||||||
|  |   if (path.basename(versionFilePath) === 'go.mod') { | ||||||
|  |     const match = contents.match(/^go (\d+(\.\d+)*)/m); | ||||||
|  |     return match ? match[1] : ''; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return contents.trim(); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										113
									
								
								src/main.ts
									
									
									
									
									
								
							
							
						
						
									
										113
									
								
								src/main.ts
									
									
									
									
									
								
							| @@ -1,10 +1,11 @@ | |||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
| import * as io from '@actions/io'; | import * as io from '@actions/io'; | ||||||
| import * as tc from '@actions/tool-cache'; |  | ||||||
| import * as installer from './installer'; | import * as installer from './installer'; | ||||||
| import * as path from 'path'; | import * as semver from 'semver'; | ||||||
| import * as cp from 'child_process'; | import path from 'path'; | ||||||
| import * as fs from 'fs'; | import cp from 'child_process'; | ||||||
|  | import fs from 'fs'; | ||||||
|  | import {URL} from 'url'; | ||||||
|  |  | ||||||
| export async function run() { | export async function run() { | ||||||
|   try { |   try { | ||||||
| @@ -12,50 +13,53 @@ export async function run() { | |||||||
|     // versionSpec is optional.  If supplied, install / use from the tool cache |     // versionSpec is optional.  If supplied, install / use from the tool cache | ||||||
|     // If not supplied then problem matchers will still be setup.  Useful for self-hosted. |     // If not supplied then problem matchers will still be setup.  Useful for self-hosted. | ||||||
|     // |     // | ||||||
|     let versionSpec = core.getInput('go-version'); |     const versionSpec = resolveVersionInput(); | ||||||
|  |  | ||||||
|     // stable will be true unless false is the exact input |     core.info(`Setup go version spec ${versionSpec}`); | ||||||
|     // since getting unstable versions should be explicit |  | ||||||
|     let stable = (core.getInput('stable') || 'true').toUpperCase() === 'TRUE'; |  | ||||||
|  |  | ||||||
|     console.log( |  | ||||||
|       `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(versionSpec, checkLatest, auth); | ||||||
|           `A version satisfying ${versionSpec} not found locally, attempting to download ...` |  | ||||||
|         ); |  | ||||||
|         installDir = await installer.downloadGo(versionSpec, stable); |  | ||||||
|         console.log('Installed'); |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|       if (installDir) { |  | ||||||
|         core.exportVariable('GOROOT', installDir); |  | ||||||
|       core.addPath(path.join(installDir, 'bin')); |       core.addPath(path.join(installDir, 'bin')); | ||||||
|         console.log('Added go to the path'); |       core.info('Added go to the path'); | ||||||
|  |  | ||||||
|         let added = addBinToPath(); |       const version = installer.makeSemver(versionSpec); | ||||||
|         core.debug(`add bin ${added}`); |       // Go versions less than 1.9 require GOROOT to be set | ||||||
|       } else { |       if (semver.lt(version, '1.9.0')) { | ||||||
|         throw new Error( |         core.info('Setting GOROOT for Go version < 1.9'); | ||||||
|           `Could not find a version that satisfied version spec: ${versionSpec}` |         core.exportVariable('GOROOT', installDir); | ||||||
|         ); |  | ||||||
|       } |       } | ||||||
|  |  | ||||||
|  |       let added = await addBinToPath(); | ||||||
|  |       core.debug(`add bin ${added}`); | ||||||
|  |       core.info(`Successfully set up 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.setOutput('go-version', parseGoVersion(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); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| async function addBinToPath(): Promise<boolean> { | export async function addBinToPath(): Promise<boolean> { | ||||||
|   let added = false; |   let added = false; | ||||||
|   let g = await io.which('go'); |   let g = await io.which('go'); | ||||||
|   core.debug(`which go :${g}:`); |   core.debug(`which go :${g}:`); | ||||||
| @@ -65,19 +69,19 @@ async function addBinToPath(): Promise<boolean> { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   let buf = cp.execSync('go env GOPATH'); |   let buf = cp.execSync('go env GOPATH'); | ||||||
|   if (buf) { |   if (buf.length > 1) { | ||||||
|     let gp = buf.toString().trim(); |     let gp = buf.toString().trim(); | ||||||
|     core.debug(`go env GOPATH :${gp}:`); |     core.debug(`go env GOPATH :${gp}:`); | ||||||
|     if (!fs.existsSync(gp)) { |     if (!fs.existsSync(gp)) { | ||||||
|       // some of the hosted images have go install but not profile dir |       // some of the hosted images have go install but not profile dir | ||||||
|       core.debug(`creating ${gp}`); |       core.debug(`creating ${gp}`); | ||||||
|       io.mkdirP(gp); |       await io.mkdirP(gp); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     let bp = path.join(gp, 'bin'); |     let bp = path.join(gp, 'bin'); | ||||||
|     if (!fs.existsSync(bp)) { |     if (!fs.existsSync(bp)) { | ||||||
|       core.debug(`creating ${bp}`); |       core.debug(`creating ${bp}`); | ||||||
|       io.mkdirP(bp); |       await io.mkdirP(bp); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     core.addPath(bp); |     core.addPath(bp); | ||||||
| @@ -85,3 +89,44 @@ async function addBinToPath(): Promise<boolean> { | |||||||
|   } |   } | ||||||
|   return added; |   return added; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function isGhes(): boolean { | ||||||
|  |   const ghUrl = new URL( | ||||||
|  |     process.env['GITHUB_SERVER_URL'] || 'https://github.com' | ||||||
|  |   ); | ||||||
|  |   return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function parseGoVersion(versionString: string): string { | ||||||
|  |   // get the installed version as an Action output | ||||||
|  |   // based on go/src/cmd/go/internal/version/version.go: | ||||||
|  |   // fmt.Printf("go version %s %s/%s\n", runtime.Version(), runtime.GOOS, runtime.GOARCH) | ||||||
|  |   // expecting go<version> for runtime.Version() | ||||||
|  |   return versionString.split(' ')[2].slice('go'.length); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function resolveVersionInput(): string { | ||||||
|  |   let version = core.getInput('go-version'); | ||||||
|  |   const versionFilePath = core.getInput('go-version-file'); | ||||||
|  |  | ||||||
|  |   if (version && versionFilePath) { | ||||||
|  |     core.warning( | ||||||
|  |       'Both go-version and go-version-file inputs are specified, only go-version will be used' | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (version) { | ||||||
|  |     return version; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (versionFilePath) { | ||||||
|  |     if (!fs.existsSync(versionFilePath)) { | ||||||
|  |       throw new Error( | ||||||
|  |         `The specified go version file at: ${versionFilePath} does not exist` | ||||||
|  |       ); | ||||||
|  |     } | ||||||
|  |     version = installer.parseGoVersionFile(versionFilePath); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return version; | ||||||
|  | } | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| let os = require('os'); | const os = require('os'); | ||||||
|  |  | ||||||
| export function getPlatform(): string { | export function getPlatform(): string { | ||||||
|   // darwin and linux match already |   // darwin and linux match already | ||||||
|   | |||||||
| @@ -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