setup-node/src/setup-node.ts

54 lines
1.6 KiB
TypeScript
Raw Normal View History

2019-08-04 01:49:54 +00:00
import * as core from '@actions/core';
2020-04-16 14:45:55 +00:00
import * as io from '@actions/io';
2019-08-04 01:49:54 +00:00
import * as installer from './installer';
import * as auth from './authutil';
2019-08-04 01:49:54 +00:00
import * as path from 'path';
2020-04-16 14:45:55 +00:00
import cp from 'child_process';
2019-08-04 01:49:54 +00:00
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 01:49:54 +00:00
if (version) {
await installer.getNode(version);
}
2020-04-16 14:45:55 +00:00
// Output version of node and npm that are being used
const nodePath = await io.which('node');
2020-04-21 15:40:45 +00:00
const nodeVersion = cp.execSync(`"${nodePath}" --version`);
2020-04-16 14:45:55 +00:00
console.log(`Node Version: ${nodeVersion}`);
const npmPath = await io.which('npm');
2020-04-21 15:21:23 +00:00
// Older versions of Node don't include npm
if (npmPath) {
2020-04-21 15:40:45 +00:00
const npmVersion = cp.execSync(`"${npmPath}" --version`);
2020-04-21 15:21:23 +00:00
console.log(`npm Version: ${npmVersion}`);
}
2020-04-16 14:45:55 +00:00
const registryUrl: string = core.getInput('registry-url');
const alwaysAuth: string = core.getInput('always-auth');
if (registryUrl) {
auth.configAuthentication(registryUrl, alwaysAuth);
}
2019-08-04 01:49:54 +00: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();