mirror of https://github.com/actions/setup-go.git
				
				
				
			Convert version extraction to a function
Simplify how the version is extracted and add a simple test at the same time. Co-authored-by: Peter Mescalchin <peter@magnetikonline.com> Co-authored-by: Brian Cristante <33549821+brcrista@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									2930331465
								
							
						
					
					
						commit
						b2f8b6e6e0
					
				|  | @ -105,6 +105,11 @@ describe('setup-go', () => { | ||||||
|     jest.restoreAllMocks(); |     jest.restoreAllMocks(); | ||||||
|   }, 100000); |   }, 100000); | ||||||
| 
 | 
 | ||||||
|  |   it('can extract the major.minor.patch version from a given Go version string', async () => { | ||||||
|  |     const goVersionOutput = 'go version go1.16.6 darwin/amd64'; | ||||||
|  |     expect(main.parseGoVersion(goVersionOutput)).toBe('1.16.6'); | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|   it('can find 1.9.7 from manifest on osx', async () => { |   it('can find 1.9.7 from manifest on osx', async () => { | ||||||
|     os.platform = 'darwin'; |     os.platform = 'darwin'; | ||||||
|     os.arch = 'x64'; |     os.arch = 'x64'; | ||||||
|  |  | ||||||
|  | @ -2058,7 +2058,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) { | ||||||
|     return (mod && mod.__esModule) ? mod : { "default": mod }; |     return (mod && mod.__esModule) ? mod : { "default": mod }; | ||||||
| }; | }; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| exports.addBinToPath = exports.run = void 0; | exports.parseGoVersion = exports.addBinToPath = exports.run = void 0; | ||||||
| const core = __importStar(__webpack_require__(470)); | const core = __importStar(__webpack_require__(470)); | ||||||
| const io = __importStar(__webpack_require__(1)); | const io = __importStar(__webpack_require__(1)); | ||||||
| const installer = __importStar(__webpack_require__(749)); | const installer = __importStar(__webpack_require__(749)); | ||||||
|  | @ -2100,12 +2100,7 @@ function run() { | ||||||
|             let goPath = yield io.which('go'); |             let goPath = yield io.which('go'); | ||||||
|             let goVersion = (child_process_1.default.execSync(`${goPath} version`) || '').toString(); |             let goVersion = (child_process_1.default.execSync(`${goPath} version`) || '').toString(); | ||||||
|             core.info(goVersion); |             core.info(goVersion); | ||||||
|             // get the installed version as an Action output
 |             core.setOutput('go-version', parseGoVersion(goVersion)); | ||||||
|             // 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()
 |  | ||||||
|             let goVersionOutput = [...goVersion.split(' ')[2]].slice(2).join(''); |  | ||||||
|             core.setOutput('go-version', goVersionOutput); |  | ||||||
|             core.startGroup('go env'); |             core.startGroup('go env'); | ||||||
|             let goEnv = (child_process_1.default.execSync(`${goPath} env`) || '').toString(); |             let goEnv = (child_process_1.default.execSync(`${goPath} env`) || '').toString(); | ||||||
|             core.info(goEnv); |             core.info(goEnv); | ||||||
|  | @ -2151,6 +2146,14 @@ function isGhes() { | ||||||
|     const ghUrl = new url_1.URL(process.env['GITHUB_SERVER_URL'] || 'https://github.com'); |     const ghUrl = new url_1.URL(process.env['GITHUB_SERVER_URL'] || 'https://github.com'); | ||||||
|     return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'; |     return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'; | ||||||
| } | } | ||||||
|  | function parseGoVersion(versionString) { | ||||||
|  |     // 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); | ||||||
|  | } | ||||||
|  | exports.parseGoVersion = parseGoVersion; | ||||||
| //# sourceMappingURL=main.js.map
 | //# sourceMappingURL=main.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
|  |  | ||||||
							
								
								
									
										15
									
								
								src/main.ts
								
								
								
								
							
							
						
						
									
										15
									
								
								src/main.ts
								
								
								
								
							|  | @ -48,12 +48,7 @@ export async function run() { | ||||||
|     let goVersion = (cp.execSync(`${goPath} version`) || '').toString(); |     let goVersion = (cp.execSync(`${goPath} version`) || '').toString(); | ||||||
|     core.info(goVersion); |     core.info(goVersion); | ||||||
| 
 | 
 | ||||||
|     // get the installed version as an Action output
 |     core.setOutput('go-version', parseGoVersion(goVersion)); | ||||||
|     // 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()
 |  | ||||||
|     let goVersionOutput = [...goVersion.split(' ')[2]].slice(2).join(''); |  | ||||||
|     core.setOutput('go-version', goVersionOutput); |  | ||||||
| 
 | 
 | ||||||
|     core.startGroup('go env'); |     core.startGroup('go env'); | ||||||
|     let goEnv = (cp.execSync(`${goPath} env`) || '').toString(); |     let goEnv = (cp.execSync(`${goPath} env`) || '').toString(); | ||||||
|  | @ -101,3 +96,11 @@ function isGhes(): boolean { | ||||||
|   ); |   ); | ||||||
|   return ghUrl.hostname.toUpperCase() !== '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); | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Nicholas McDonnell
						Nicholas McDonnell