setup-node/src/setup-node.ts

50 lines
1.5 KiB
TypeScript
Raw Normal View History

2019-08-04 09:49:54 +08:00
import * as core from '@actions/core';
2020-04-22 02:03:26 +08:00
import * as exec from '@actions/exec';
2020-04-16 22:45:55 +08:00
import * as io from '@actions/io';
2019-08-04 09:49:54 +08:00
import * as installer from './installer';
import * as auth from './authutil';
2019-08-04 09:49:54 +08:00
import * as path from 'path';
async function run() {
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('version');
if (!version) {
version = core.getInput('node-version');
}
2019-08-04 09:49:54 +08:00
if (version) {
await installer.getNode(version);
}
2020-04-16 22:45:55 +08:00
// Output version of node and npm that are being used
2020-04-22 02:03:26 +08:00
const nodeVersion = exec.exec(`"$ --version`);
2020-04-16 22:45:55 +08:00
2020-04-22 02:03:26 +08:00
// Older versions of Node don't include npm, so don't let this call fail
const npmVersion = exec.exec(`npm --version`, undefined, {
ignoreReturnCode: true
});
2020-04-16 22:45:55 +08:00
const registryUrl: string = core.getInput('registry-url');
const alwaysAuth: string = core.getInput('always-auth');
if (registryUrl) {
auth.configAuthentication(registryUrl, alwaysAuth);
}
2019-08-04 09:49:54 +08:00
const matchersPath = path.join(__dirname, '..', '.github');
console.log(`##[add-matcher]${path.join(matchersPath, 'tsc.json')}`);
console.log(
`##[add-matcher]${path.join(matchersPath, 'eslint-stylish.json')}`
);
console.log(
`##[add-matcher]${path.join(matchersPath, 'eslint-compact.json')}`
);
} catch (error) {
core.setFailed(error.message);
}
}
run();