mirror of https://github.com/actions/setup-go.git
Add check latest check
This commit is contained in:
parent
46c78a9b17
commit
ee153a708d
|
@ -25,10 +25,44 @@ jobs:
|
||||||
with:
|
with:
|
||||||
go-version: stable
|
go-version: stable
|
||||||
architecture: x64
|
architecture: x64
|
||||||
|
check-latest: true
|
||||||
- name: Verify Go
|
- name: Verify Go
|
||||||
run: go version
|
run: go version
|
||||||
|
|
||||||
oldstable:
|
oldstable:
|
||||||
|
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: oldstable
|
||||||
|
architecture: x64
|
||||||
|
check-latest: true
|
||||||
|
- name: Verify Go
|
||||||
|
run: go version
|
||||||
|
|
||||||
|
stable-no-check-latest:
|
||||||
|
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: stable
|
||||||
|
architecture: x64
|
||||||
|
- name: Verify Go
|
||||||
|
run: go version
|
||||||
|
|
||||||
|
oldstable-no-check-latest:
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
|
|
|
@ -84,7 +84,7 @@ describe('setup-go', () => {
|
||||||
cacheSpy = jest.spyOn(tc, 'cacheDir');
|
cacheSpy = jest.spyOn(tc, 'cacheDir');
|
||||||
getSpy = jest.spyOn(im, 'getVersionsDist');
|
getSpy = jest.spyOn(im, 'getVersionsDist');
|
||||||
getManifestSpy = jest.spyOn(tc, 'getManifestFromRepo');
|
getManifestSpy = jest.spyOn(tc, 'getManifestFromRepo');
|
||||||
getAllVersionsSpy = jest.spyOn(im, 'getAllReleases');
|
getAllVersionsSpy = jest.spyOn(im, 'getAllManifestReleases');
|
||||||
|
|
||||||
// io
|
// io
|
||||||
whichSpy = jest.spyOn(io, 'which');
|
whichSpy = jest.spyOn(io, 'which');
|
||||||
|
|
|
@ -63213,7 +63213,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.parseGoVersionFile = exports.makeSemver = exports.getVersionsDist = exports.findMatch = exports.getInfoFromManifest = exports.getAllReleases = exports.extractGoArchive = exports.resolveVersionFromManifest = exports.getGo = void 0;
|
exports.parseGoVersionFile = exports.makeSemver = exports.getVersionsDist = exports.findMatch = exports.getInfoFromManifest = exports.getAllToolCacheReleases = exports.getAllManifestReleases = exports.extractGoArchive = exports.resolveVersionFromManifest = exports.getGo = void 0;
|
||||||
const tc = __importStar(__nccwpck_require__(7784));
|
const tc = __importStar(__nccwpck_require__(7784));
|
||||||
const core = __importStar(__nccwpck_require__(2186));
|
const core = __importStar(__nccwpck_require__(2186));
|
||||||
const path = __importStar(__nccwpck_require__(1017));
|
const path = __importStar(__nccwpck_require__(1017));
|
||||||
|
@ -63337,16 +63337,22 @@ function extractGoArchive(archivePath) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
exports.extractGoArchive = extractGoArchive;
|
exports.extractGoArchive = extractGoArchive;
|
||||||
function getAllReleases(auth) {
|
function getAllManifestReleases(auth) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
return yield tc.getManifestFromRepo('actions', 'go-versions', auth, 'main');
|
return tc.getManifestFromRepo('actions', 'go-versions', auth, 'main');
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
exports.getAllReleases = getAllReleases;
|
exports.getAllManifestReleases = getAllManifestReleases;
|
||||||
|
function getAllToolCacheReleases(arch = os_1.default.arch()) {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
return tc.findAllVersions('go', arch);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
exports.getAllToolCacheReleases = getAllToolCacheReleases;
|
||||||
function getInfoFromManifest(versionSpec, stable, auth, arch = os_1.default.arch(), releases) {
|
function getInfoFromManifest(versionSpec, stable, auth, arch = os_1.default.arch(), releases) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
let info = null;
|
let info = null;
|
||||||
releases = releases ? releases : yield getAllReleases(auth);
|
releases = releases ? releases : yield getAllManifestReleases(auth);
|
||||||
core.info(`matching ${versionSpec}...`);
|
core.info(`matching ${versionSpec}...`);
|
||||||
let rel = yield tc.findFromManifest(versionSpec, stable, releases, arch);
|
let rel = yield tc.findFromManifest(versionSpec, stable, releases, arch);
|
||||||
if (rel && rel.files.length > 0) {
|
if (rel && rel.files.length > 0) {
|
||||||
|
@ -63529,11 +63535,11 @@ function run() {
|
||||||
if (versionSpec) {
|
if (versionSpec) {
|
||||||
let token = core.getInput('token');
|
let token = core.getInput('token');
|
||||||
let auth = !token ? undefined : `token ${token}`;
|
let auth = !token ? undefined : `token ${token}`;
|
||||||
const releases = yield installer.getAllReleases(auth);
|
const releases = yield installer.getAllManifestReleases(auth);
|
||||||
const checkLatest = core.getBooleanInput('check-latest');
|
const checkLatest = core.getBooleanInput('check-latest');
|
||||||
if (versionSpec === utils_1.StableReleaseAlias.Stable ||
|
if (versionSpec === utils_1.StableReleaseAlias.Stable ||
|
||||||
versionSpec === utils_1.StableReleaseAlias.OldStable) {
|
versionSpec === utils_1.StableReleaseAlias.OldStable) {
|
||||||
versionSpec = yield resolveStableVersionInput(versionSpec, auth, arch, releases);
|
versionSpec = yield resolveStableVersionInput(versionSpec, auth, arch, releases, checkLatest);
|
||||||
}
|
}
|
||||||
const installDir = yield installer.getGo(versionSpec, checkLatest, auth, arch, releases);
|
const installDir = yield installer.getGo(versionSpec, checkLatest, auth, arch, releases);
|
||||||
core.addPath(path_1.default.join(installDir, 'bin'));
|
core.addPath(path_1.default.join(installDir, 'bin'));
|
||||||
|
@ -63627,21 +63633,35 @@ function resolveVersionInput() {
|
||||||
}
|
}
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
function resolveStableVersionInput(versionSpec, auth, arch = os_1.default.arch(), releases) {
|
function resolveStableVersionInput(versionSpec, auth, arch = os_1.default.arch(), manifestReleases, checkLatest = false) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
if (versionSpec === utils_1.StableReleaseAlias.Stable) {
|
let releases;
|
||||||
core.info(`Stable version resolved as ${releases[0].version}`);
|
if (checkLatest) {
|
||||||
return releases[0].version;
|
releases = manifestReleases.map(release => release.version);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
const versions = releases.map(release => `${semver.major(release.version)}.${semver.minor(release.version)}`);
|
releases = yield installer.getAllToolCacheReleases(arch);
|
||||||
|
}
|
||||||
|
if (versionSpec === utils_1.StableReleaseAlias.Stable) {
|
||||||
|
core.info(`Stable version resolved as ${releases[0]}`);
|
||||||
|
return releases[0];
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
const versions = releases.map(release => `${semver.major(release)}.${semver.minor(release)}`);
|
||||||
const uniqueVersions = Array.from(new Set(versions));
|
const uniqueVersions = Array.from(new Set(versions));
|
||||||
core.info(`Oldstable version resolved as ${uniqueVersions[1]}`);
|
let oldstableVersion;
|
||||||
const oldstableVersion = yield installer.getInfoFromManifest(uniqueVersions[1], true, auth, arch, releases);
|
if (checkLatest) {
|
||||||
|
oldstableVersion = yield installer.getInfoFromManifest(uniqueVersions[1], true, auth, arch, manifestReleases);
|
||||||
|
oldstableVersion = oldstableVersion === null || oldstableVersion === void 0 ? void 0 : oldstableVersion.resolvedVersion;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
oldstableVersion = uniqueVersions[1];
|
||||||
|
}
|
||||||
|
core.info(`Oldstable version resolved as ${oldstableVersion}`);
|
||||||
if (!oldstableVersion) {
|
if (!oldstableVersion) {
|
||||||
return versionSpec;
|
return versionSpec;
|
||||||
}
|
}
|
||||||
return oldstableVersion.resolvedVersion;
|
return oldstableVersion;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@ 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 fs from 'fs';
|
import fs from 'fs';
|
||||||
import os from 'os';
|
import os, {arch} from 'os';
|
||||||
|
|
||||||
type InstallationType = 'dist' | 'manifest';
|
type InstallationType = 'dist' | 'manifest';
|
||||||
|
|
||||||
|
@ -183,8 +183,12 @@ export async function extractGoArchive(archivePath: string): Promise<string> {
|
||||||
return extPath;
|
return extPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getAllReleases(auth: string | undefined) {
|
export async function getAllManifestReleases(auth: string | undefined) {
|
||||||
return await tc.getManifestFromRepo('actions', 'go-versions', auth, 'main');
|
return tc.getManifestFromRepo('actions', 'go-versions', auth, 'main');
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function getAllToolCacheReleases(arch = os.arch()) {
|
||||||
|
return tc.findAllVersions('go', arch);
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getInfoFromManifest(
|
export async function getInfoFromManifest(
|
||||||
|
@ -195,7 +199,7 @@ export async function getInfoFromManifest(
|
||||||
releases?: tc.IToolRelease[] | undefined
|
releases?: tc.IToolRelease[] | undefined
|
||||||
): Promise<IGoVersionInfo | null> {
|
): Promise<IGoVersionInfo | null> {
|
||||||
let info: IGoVersionInfo | null = null;
|
let info: IGoVersionInfo | null = null;
|
||||||
releases = releases ? releases : await getAllReleases(auth);
|
releases = releases ? releases : await getAllManifestReleases(auth);
|
||||||
|
|
||||||
core.info(`matching ${versionSpec}...`);
|
core.info(`matching ${versionSpec}...`);
|
||||||
|
|
||||||
|
|
49
src/main.ts
49
src/main.ts
|
@ -32,7 +32,7 @@ export async function run() {
|
||||||
let token = core.getInput('token');
|
let token = core.getInput('token');
|
||||||
let auth = !token ? undefined : `token ${token}`;
|
let auth = !token ? undefined : `token ${token}`;
|
||||||
|
|
||||||
const releases = await installer.getAllReleases(auth);
|
const releases = await installer.getAllManifestReleases(auth);
|
||||||
|
|
||||||
const checkLatest = core.getBooleanInput('check-latest');
|
const checkLatest = core.getBooleanInput('check-latest');
|
||||||
|
|
||||||
|
@ -44,7 +44,8 @@ export async function run() {
|
||||||
versionSpec,
|
versionSpec,
|
||||||
auth,
|
auth,
|
||||||
arch,
|
arch,
|
||||||
releases
|
releases,
|
||||||
|
checkLatest
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -166,33 +167,47 @@ async function resolveStableVersionInput(
|
||||||
versionSpec: string,
|
versionSpec: string,
|
||||||
auth: string | undefined,
|
auth: string | undefined,
|
||||||
arch = os.arch(),
|
arch = os.arch(),
|
||||||
releases: IToolRelease[]
|
manifestReleases: IToolRelease[],
|
||||||
|
checkLatest = false
|
||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
if (versionSpec === StableReleaseAlias.Stable) {
|
let releases;
|
||||||
core.info(`Stable version resolved as ${releases[0].version}`);
|
if (checkLatest) {
|
||||||
|
releases = manifestReleases.map(release => release.version);
|
||||||
|
} else {
|
||||||
|
releases = await installer.getAllToolCacheReleases(arch);
|
||||||
|
}
|
||||||
|
|
||||||
return releases[0].version;
|
if (versionSpec === StableReleaseAlias.Stable) {
|
||||||
|
core.info(`Stable version resolved as ${releases[0]}`);
|
||||||
|
|
||||||
|
return releases[0];
|
||||||
} else {
|
} else {
|
||||||
const versions = releases.map(
|
const versions = releases.map(
|
||||||
release =>
|
release => `${semver.major(release)}.${semver.minor(release)}`
|
||||||
`${semver.major(release.version)}.${semver.minor(release.version)}`
|
|
||||||
);
|
);
|
||||||
const uniqueVersions = Array.from(new Set(versions));
|
const uniqueVersions = Array.from(new Set(versions));
|
||||||
|
|
||||||
core.info(`Oldstable version resolved as ${uniqueVersions[1]}`);
|
let oldstableVersion;
|
||||||
|
|
||||||
const oldstableVersion = await installer.getInfoFromManifest(
|
if (checkLatest) {
|
||||||
uniqueVersions[1],
|
oldstableVersion = await installer.getInfoFromManifest(
|
||||||
true,
|
uniqueVersions[1],
|
||||||
auth,
|
true,
|
||||||
arch,
|
auth,
|
||||||
releases
|
arch,
|
||||||
);
|
manifestReleases
|
||||||
|
);
|
||||||
|
oldstableVersion = oldstableVersion?.resolvedVersion;
|
||||||
|
} else {
|
||||||
|
oldstableVersion = uniqueVersions[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
core.info(`Oldstable version resolved as ${oldstableVersion}`);
|
||||||
|
|
||||||
if (!oldstableVersion) {
|
if (!oldstableVersion) {
|
||||||
return versionSpec;
|
return versionSpec;
|
||||||
}
|
}
|
||||||
|
|
||||||
return oldstableVersion.resolvedVersion;
|
return oldstableVersion;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue