Fix linting

This commit is contained in:
Imran Ismail
2020-03-31 02:55:38 +08:00
parent 155078e948
commit b03ae87368
5 changed files with 195 additions and 181 deletions

View File

@@ -1,197 +1,202 @@
// Load tempDirectory before it gets wiped by tool-cache
let tempDirectory = process.env['RUNNER_TEMPDIRECTORY'] || '';
import * as core from '@actions/core';
import * as tc from '@actions/tool-cache';
import * as restm from 'typed-rest-client/RestClient';
import * as os from 'os';
import * as path from 'path';
import * as semver from 'semver';
import * as core from '@actions/core'
import * as tc from '@actions/tool-cache'
import * as restm from 'typed-rest-client/RestClient'
import * as os from 'os'
import * as path from 'path'
import * as semver from 'semver'
import * as fs from 'fs'
let tempDirectory = process.env['RUNNER_TEMPDIRECTORY'] || ''
let osPlat: string = os.platform();
let osArch: string = os.arch();
const osPlat: string = os.platform()
const osArch: string = os.arch()
if (!tempDirectory) {
let baseLocation;
let baseLocation
if (process.platform === 'win32') {
// On windows use the USERPROFILE env variable
baseLocation = process.env['USERPROFILE'] || 'C:\\';
baseLocation = process.env['USERPROFILE'] || 'C:\\'
} else {
if (process.platform === 'darwin') {
baseLocation = '/Users';
baseLocation = '/Users'
} else {
baseLocation = '/home';
baseLocation = '/home'
}
}
tempDirectory = path.join(baseLocation, 'actions', 'temp');
tempDirectory = path.join(baseLocation, 'actions', 'temp')
}
export async function getKustomize(versionSpec: string) {
export async function getKustomize(versionSpec: string): Promise<void> {
// check cache
let toolPath: string;
let toolPath: string
toolPath = tc.find('kustomize', versionSpec);
toolPath = tc.find('kustomize', versionSpec)
// If not found in cache, download
if (!toolPath) {
let version: string;
const c = semver.clean(versionSpec) || '';
let version: string
const c = semver.clean(versionSpec) || ''
// If explicit version
if (semver.valid(c) != null) {
// version to download
version = versionSpec;
version = versionSpec
} else {
// query kustomize for a matching version
version = await queryLatestMatch(versionSpec);
version = await queryLatestMatch(versionSpec)
if (!version) {
throw new Error(
`Unable to find Kustomize version '${versionSpec}' for platform ${osPlat} and architecture ${osArch}.`
);
)
}
// check cache
toolPath = tc.find('kustomize', version);
toolPath = tc.find('kustomize', version)
}
if (!toolPath) {
// download, extract, cache
toolPath = await acquireKustomize(version);
toolPath = await acquireKustomize(version)
}
}
core.addPath(toolPath);
core.addPath(toolPath)
}
interface IAsset {
browser_download_url: string;
name: string;
browser_download_url: string
name: string
}
interface IKustomizeVersion {
name: string;
assets: IAsset[];
name: string
assets: IAsset[]
}
async function queryLatestMatch(versionSpec: string): Promise<string> {
let dataFileName: string;
let dataFileName: string
switch (osPlat) {
case 'linux':
case 'darwin':
case 'win32':
dataFileName = osPlat;
break;
dataFileName = osPlat
break
default:
throw new Error(`Unexpected OS '${osPlat}'`);
throw new Error(`Unexpected OS '${osPlat}'`)
}
switch (osArch) {
case 'x64':
dataFileName = `${dataFileName}_amd64`;
break;
dataFileName = `${dataFileName}_amd64`
break
default:
dataFileName = `${dataFileName}_${osArch}`;
dataFileName = `${dataFileName}_${osArch}`
}
let versions: string[] = [];
let dataUrl = 'https://api.github.com/repos/kubernetes-sigs/kustomize/releases';
let rest: restm.RestClient = new restm.RestClient('setup-kustomize');
let kustomizeVersions: IKustomizeVersion[] = (await rest.get<IKustomizeVersion[]>(dataUrl)).result || [];
const versions: string[] = []
const dataUrl =
'https://api.github.com/repos/kubernetes-sigs/kustomize/releases'
const rest: restm.RestClient = new restm.RestClient('setup-kustomize')
const kustomizeVersions: IKustomizeVersion[] =
(await rest.get<IKustomizeVersion[]>(dataUrl)).result || []
kustomizeVersions.forEach((kustomizeVersion: IKustomizeVersion) => {
if (kustomizeVersion.assets.some(asset => asset.name.includes(dataFileName))) {
let version = semver.clean(kustomizeVersion.name);
for (const kustomizeVersion of kustomizeVersions) {
if (
kustomizeVersion.assets.some(asset => asset.name.includes(dataFileName))
) {
const version = semver.clean(kustomizeVersion.name)
if (version != null) {
versions.push(version);
versions.push(version)
}
}
});
}
return evaluateVersions(versions, versionSpec);
return evaluateVersions(versions, versionSpec)
}
function evaluateVersions(versions: string[], versionSpec: string): string {
let version = '';
let version = ''
core.debug(`evaluating ${versions.length} versions`);
core.debug(`evaluating ${versions.length} versions`)
versions = versions.sort((a, b) => {
if (semver.gt(a, b)) {
return 1;
return 1
}
return -1;
});
return -1
})
for (let i = versions.length - 1; i >= 0; i--) {
const potential: string = versions[i];
const satisfied: boolean = semver.satisfies(potential, versionSpec);
const potential: string = versions[i]
const satisfied: boolean = semver.satisfies(potential, versionSpec)
if (satisfied) {
version = potential;
break;
version = potential
break
}
}
if (version) {
core.debug(`matched: ${version}`);
core.debug(`matched: ${version}`)
} else {
core.debug('match not found');
core.debug('match not found')
}
return version;
return version
}
async function acquireKustomize(version: string): Promise<string> {
version = semver.clean(version) || '';
version = semver.clean(version) || ''
let downloadUrl: string;
let toolPath: string;
let toolFilename = "kustomize";
let toolName = "kustomize";
let downloadUrl: string
let toolPath: string
let toolFilename = 'kustomize'
const toolName = 'kustomize'
if (osPlat == "win32") {
if (osPlat === 'win32') {
toolFilename = `${toolFilename}.exe`
}
if (semver.gte(version, "3.3.0")) {
downloadUrl = `https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize/v${version}/kustomize_v${version}_%{os}_%{arch}.tar.gz`;
} else if (semver.gte(version, "3.2.1")) {
downloadUrl = `https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize/v${version}/kustomize_kustomize.v${version}_%{os}_%{arch}`;
if (semver.gte(version, '3.3.0')) {
downloadUrl = `https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize/v${version}/kustomize_v${version}_%{os}_%{arch}.tar.gz`
} else if (semver.gte(version, '3.2.1')) {
downloadUrl = `https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize/v${version}/kustomize_kustomize.v${version}_%{os}_%{arch}`
} else {
downloadUrl = `https://github.com/kubernetes-sigs/kustomize/releases/download/v${version}/kustomize_${version}_%{os}_%{arch}`
}
switch (osPlat) {
case 'win32':
if (semver.lte(version, "3.2.1")) throw new Error(`Unexpected OS '${osPlat}'`);
downloadUrl = downloadUrl.replace('%{os}', 'windows');
if (semver.lt(version, "3.3.0")) downloadUrl = `${downloadUrl}.exe`;
break;
if (semver.lte(version, '3.2.1'))
throw new Error(`Unexpected OS '${osPlat}'`)
downloadUrl = downloadUrl.replace('%{os}', 'windows')
if (semver.lt(version, '3.3.0')) downloadUrl = `${downloadUrl}.exe`
break
case 'linux':
case 'darwin':
downloadUrl = downloadUrl.replace('%{os}', osPlat);
break;
downloadUrl = downloadUrl.replace('%{os}', osPlat)
break
default:
throw new Error(`Unexpected OS '${osPlat}'`);
throw new Error(`Unexpected OS '${osPlat}'`)
}
switch (osArch) {
case 'x64':
downloadUrl = downloadUrl.replace('%{arch}', 'amd64');
break;
downloadUrl = downloadUrl.replace('%{arch}', 'amd64')
break
default:
throw new Error(`Unexpected Arch '${osArch}'`);
throw new Error(`Unexpected Arch '${osArch}'`)
}
try {
toolPath = await tc.downloadTool(downloadUrl);
toolPath = await tc.downloadTool(downloadUrl)
} catch (err) {
core.debug(err);
throw `Failed to download version ${version}: ${err}`;
core.debug(err)
throw new Error(`Failed to download version ${version}: ${err}`)
}
if (downloadUrl.endsWith('.tar.gz')) {
toolPath = await tc.extractTar(toolPath);
toolPath = await tc.extractTar(toolPath)
toolPath = path.join(toolPath, toolFilename)
}
@@ -199,8 +204,8 @@ async function acquireKustomize(version: string): Promise<string> {
case 'linux':
case 'darwin':
fs.chmodSync(toolPath, 0o755)
break;
break
}
return await tc.cacheFile(toolPath, toolFilename, toolName, version);
}
return await tc.cacheFile(toolPath, toolFilename, toolName, version)
}

View File

@@ -1,20 +1,20 @@
import * as core from '@actions/core';
import * as installer from './installer';
import * as core from '@actions/core'
import * as installer from './installer'
async function run() {
async function run(): Promise<void> {
try {
//
// Version is optional. If supplied, install / use from the tool cache
// If not supplied then task is still used to setup proxy, auth, etc...
//
let version = core.getInput('kustomize-version');
const version = core.getInput('kustomize-version')
if (version) {
await installer.getKustomize(version);
await installer.getKustomize(version)
}
} catch (error) {
core.setFailed(error.message);
core.setFailed(error.message)
}
}
run();
run()