mirror of
https://github.com/actions/setup-go.git
synced 2025-04-23 17:40:50 +00:00
get latest release for .x syntax version
This commit is contained in:
parent
818723587f
commit
cd143b4bb4
2 changed files with 117 additions and 0 deletions
|
@ -22,6 +22,8 @@ const tc = __importStar(require("@actions/tool-cache"));
|
||||||
const os = __importStar(require("os"));
|
const os = __importStar(require("os"));
|
||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
const util = __importStar(require("util"));
|
const util = __importStar(require("util"));
|
||||||
|
const semver = __importStar(require("semver"));
|
||||||
|
const httpm = __importStar(require("typed-rest-client/HttpClient"));
|
||||||
let osPlat = os.platform();
|
let osPlat = os.platform();
|
||||||
let osArch = os.arch();
|
let osArch = os.arch();
|
||||||
if (!tempDirectory) {
|
if (!tempDirectory) {
|
||||||
|
@ -42,6 +44,7 @@ if (!tempDirectory) {
|
||||||
}
|
}
|
||||||
function getGo(version) {
|
function getGo(version) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
version = yield determineVersion(version);
|
||||||
// check cache
|
// check cache
|
||||||
let toolPath;
|
let toolPath;
|
||||||
toolPath = tc.find('go', normalizeVersion(version));
|
toolPath = tc.find('go', normalizeVersion(version));
|
||||||
|
@ -127,8 +130,59 @@ function normalizeVersion(version) {
|
||||||
return version.concat('.0.0');
|
return version.concat('.0.0');
|
||||||
}
|
}
|
||||||
else if (versionPart[2] == null) {
|
else if (versionPart[2] == null) {
|
||||||
|
// handle beta and rc: 1.10beta1 => 1.10.0-beta1, 1.10rc1 => 1.10.0-rc1
|
||||||
|
if (versionPart[1].includes('beta') || versionPart[1].includes('rc')) {
|
||||||
|
versionPart[1] = versionPart[1]
|
||||||
|
.replace('beta', '.0-beta')
|
||||||
|
.replace('rc', '.0-rc');
|
||||||
|
return versionPart.join('.');
|
||||||
|
}
|
||||||
//append patch version if not available
|
//append patch version if not available
|
||||||
return version.concat('.0');
|
return version.concat('.0');
|
||||||
}
|
}
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
|
function determineVersion(version) {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
if (!version.endsWith('.x')) {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
return yield getLatestVersion(version);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function getLatestVersion(version) {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
// clean .x syntax: 1.10.x -> 1.10
|
||||||
|
const trimmedVersion = version.slice(0, version.length - 2);
|
||||||
|
const versions = yield getPossibleVersions(trimmedVersion);
|
||||||
|
if (version.length === 0) {
|
||||||
|
return trimmedVersion;
|
||||||
|
}
|
||||||
|
return versions[0];
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function unique(value, index, self) {
|
||||||
|
return self.indexOf(value) === index;
|
||||||
|
}
|
||||||
|
function getAvailableVersions() {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
let http = new httpm.HttpClient('setup-java');
|
||||||
|
let contents = yield (yield http.get('https://api.github.com/repos/golang/go/git/refs/tags')).readBody();
|
||||||
|
const matches = contents.match(/go\d+\.[\w\.]+/g) || [];
|
||||||
|
const versions = matches
|
||||||
|
.map(version => version.replace('go', ''))
|
||||||
|
.filter(unique);
|
||||||
|
return versions;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function getPossibleVersions(version) {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
const versions = yield getAvailableVersions();
|
||||||
|
const possibleVersions = versions.filter(v => v.startsWith(version));
|
||||||
|
const versionMap = new Map();
|
||||||
|
possibleVersions.forEach(v => versionMap.set(normalizeVersion(v), v));
|
||||||
|
return Array.from(versionMap.keys())
|
||||||
|
.sort(semver.rcompare)
|
||||||
|
.map(v => versionMap.get(v));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
|
@ -5,6 +5,8 @@ import * as tc from '@actions/tool-cache';
|
||||||
import * as os from 'os';
|
import * as os from 'os';
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as util from 'util';
|
import * as util from 'util';
|
||||||
|
import * as semver from 'semver';
|
||||||
|
import * as httpm from 'typed-rest-client/HttpClient';
|
||||||
|
|
||||||
let osPlat: string = os.platform();
|
let osPlat: string = os.platform();
|
||||||
let osArch: string = os.arch();
|
let osArch: string = os.arch();
|
||||||
|
@ -25,6 +27,8 @@ if (!tempDirectory) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getGo(version: string) {
|
export async function getGo(version: string) {
|
||||||
|
version = await determineVersion(version);
|
||||||
|
|
||||||
// check cache
|
// check cache
|
||||||
let toolPath: string;
|
let toolPath: string;
|
||||||
toolPath = tc.find('go', normalizeVersion(version));
|
toolPath = tc.find('go', normalizeVersion(version));
|
||||||
|
@ -123,8 +127,67 @@ function normalizeVersion(version: string): string {
|
||||||
//append minor and patch version if not available
|
//append minor and patch version if not available
|
||||||
return version.concat('.0.0');
|
return version.concat('.0.0');
|
||||||
} else if (versionPart[2] == null) {
|
} else if (versionPart[2] == null) {
|
||||||
|
// handle beta and rc: 1.10beta1 => 1.10.0-beta1, 1.10rc1 => 1.10.0-rc1
|
||||||
|
if (versionPart[1].includes('beta') || versionPart[1].includes('rc')) {
|
||||||
|
versionPart[1] = versionPart[1]
|
||||||
|
.replace('beta', '.0-beta')
|
||||||
|
.replace('rc', '.0-rc');
|
||||||
|
return versionPart.join('.');
|
||||||
|
}
|
||||||
|
|
||||||
//append patch version if not available
|
//append patch version if not available
|
||||||
return version.concat('.0');
|
return version.concat('.0');
|
||||||
}
|
}
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function determineVersion(version: string): Promise<string> {
|
||||||
|
if (!version.endsWith('.x')) {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
return await getLatestVersion(version);
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getLatestVersion(version: string): Promise<string> {
|
||||||
|
// clean .x syntax: 1.10.x -> 1.10
|
||||||
|
const trimmedVersion = version.slice(0, version.length - 2);
|
||||||
|
|
||||||
|
const versions = await getPossibleVersions(trimmedVersion);
|
||||||
|
|
||||||
|
if (version.length === 0) {
|
||||||
|
return trimmedVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
return versions[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
function unique(value: string, index: number, self: string[]) {
|
||||||
|
return self.indexOf(value) === index;
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getAvailableVersions(): Promise<string[]> {
|
||||||
|
let http: httpm.HttpClient = new httpm.HttpClient('setup-java');
|
||||||
|
let contents = await (await http.get(
|
||||||
|
'https://api.github.com/repos/golang/go/git/refs/tags'
|
||||||
|
)).readBody();
|
||||||
|
|
||||||
|
const matches = contents.match(/go\d+\.[\w\.]+/g) || [];
|
||||||
|
const versions = matches
|
||||||
|
.map(version => version.replace('go', ''))
|
||||||
|
.filter(unique);
|
||||||
|
|
||||||
|
return versions;
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getPossibleVersions(version: string): Promise<string[]> {
|
||||||
|
const versions = await getAvailableVersions();
|
||||||
|
const possibleVersions = versions.filter(v => v.startsWith(version));
|
||||||
|
|
||||||
|
const versionMap = new Map();
|
||||||
|
possibleVersions.forEach(v => versionMap.set(normalizeVersion(v), v));
|
||||||
|
|
||||||
|
return Array.from(versionMap.keys())
|
||||||
|
.sort(semver.rcompare)
|
||||||
|
.map(v => versionMap.get(v));
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue