4a4352b330
* Add go-version to action outputs This provides the semver version of Go that has been installed. This is useful if only a major or minor version has been provided as the input go-version value. * 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> Co-authored-by: Peter Mescalchin <peter@magnetikonline.com> Co-authored-by: Brian Cristante <33549821+brcrista@users.noreply.github.com>
107 lines
3.2 KiB
TypeScript
107 lines
3.2 KiB
TypeScript
import * as core from '@actions/core';
|
|
import * as io from '@actions/io';
|
|
import * as installer from './installer';
|
|
import * as semver from 'semver';
|
|
import path from 'path';
|
|
import cp from 'child_process';
|
|
import fs from 'fs';
|
|
import {URL} from 'url';
|
|
|
|
export async function run() {
|
|
try {
|
|
//
|
|
// 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.
|
|
//
|
|
let versionSpec = core.getInput('go-version');
|
|
|
|
core.info(`Setup go version spec ${versionSpec}`);
|
|
|
|
if (versionSpec) {
|
|
let token = core.getInput('token');
|
|
let auth = !token || isGhes() ? undefined : `token ${token}`;
|
|
|
|
const checkLatest = core.getBooleanInput('check-latest');
|
|
const installDir = await installer.getGo(versionSpec, checkLatest, auth);
|
|
|
|
core.addPath(path.join(installDir, 'bin'));
|
|
core.info('Added go to the path');
|
|
|
|
const version = installer.makeSemver(versionSpec);
|
|
// Go versions less than 1.9 require GOROOT to be set
|
|
if (semver.lt(version, '1.9.0')) {
|
|
core.info('Setting GOROOT for Go version < 1.9');
|
|
core.exportVariable('GOROOT', installDir);
|
|
}
|
|
|
|
let added = await addBinToPath();
|
|
core.debug(`add bin ${added}`);
|
|
core.info(`Successfully setup go version ${versionSpec}`);
|
|
}
|
|
|
|
// add problem matchers
|
|
const matchersPath = path.join(__dirname, '..', 'matchers.json');
|
|
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) {
|
|
core.setFailed(error.message);
|
|
}
|
|
}
|
|
|
|
export async function addBinToPath(): Promise<boolean> {
|
|
let added = false;
|
|
let g = await io.which('go');
|
|
core.debug(`which go :${g}:`);
|
|
if (!g) {
|
|
core.debug('go not in the path');
|
|
return added;
|
|
}
|
|
|
|
let buf = cp.execSync('go env GOPATH');
|
|
if (buf) {
|
|
let gp = buf.toString().trim();
|
|
core.debug(`go env GOPATH :${gp}:`);
|
|
if (!fs.existsSync(gp)) {
|
|
// some of the hosted images have go install but not profile dir
|
|
core.debug(`creating ${gp}`);
|
|
await io.mkdirP(gp);
|
|
}
|
|
|
|
let bp = path.join(gp, 'bin');
|
|
if (!fs.existsSync(bp)) {
|
|
core.debug(`creating ${bp}`);
|
|
await io.mkdirP(bp);
|
|
}
|
|
|
|
core.addPath(bp);
|
|
added = true;
|
|
}
|
|
return added;
|
|
}
|
|
|
|
function isGhes(): boolean {
|
|
const ghUrl = new URL(
|
|
process.env['GITHUB_SERVER_URL'] || 'https://github.com'
|
|
);
|
|
return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM';
|
|
}
|
|
|
|
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);
|
|
}
|