PR Feedback - simplifying action

This commit is contained in:
Derrick Marcey
2019-06-27 13:53:08 -04:00
parent 762d5da203
commit 4fdd5911a6
5 changed files with 17 additions and 70 deletions

View File

@@ -5,9 +5,6 @@ inputs:
version:
description: 'Version range or exact version of a Ruby version to use.'
default: '>= 2.4'
add-to-path:
description: 'Prepend the retrieved Ruby version to the PATH environment variable to make it available in subsequent actions or scripts without using the output variable.'
default: 'true'
runs:
using: 'node'

View File

@@ -15,47 +15,24 @@ var __importStar = (this && this.__importStar) || function (mod) {
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
const core = __importStar(require("@actions/core"));
const exec = __importStar(require("@actions/exec"));
const tc = __importStar(require("@actions/tool-cache"));
const os = __importStar(require("os"));
const path = __importStar(require("path"));
var Platform;
(function (Platform) {
Platform[Platform["Windows"] = 0] = "Windows";
Platform[Platform["MacOS"] = 1] = "MacOS";
Platform[Platform["Linux"] = 2] = "Linux";
})(Platform = exports.Platform || (exports.Platform = {}));
function getPlatform() {
switch (os.platform()) {
case 'win32':
return Platform.Windows;
case 'darwin':
return Platform.MacOS;
case 'linux':
return Platform.Linux;
default:
throw Error('Platform not recognized');
}
}
exports.getPlatform = getPlatform;
function default_1(inputs, platform) {
const IS_WINDOWS = process.platform === 'win32';
function default_1(version) {
return __awaiter(this, void 0, void 0, function* () {
const installDir = tc.find('Ruby', inputs.version);
const installDir = tc.find('Ruby', version);
if (!installDir) {
throw new Error(`Version ${inputs.version} not found`);
throw new Error(`Version ${version} not found`);
}
const toolPath = path.join(installDir, 'bin');
if (platform !== Platform.Windows) {
if (!IS_WINDOWS) {
// Ruby / Gem heavily use the '#!/usr/bin/ruby' to find ruby, so this task needs to
// replace that version of ruby so all the correct version of ruby gets selected
// replace the default
const dest = '/usr/bin/ruby';
exec.exec('sudo ln', ['-sf', path.join(toolPath, 'ruby'), dest]); // replace any existing
}
if (inputs.addToPath === 'true') {
core.addPath(toolPath);
}
});
}
exports.default = default_1;

View File

@@ -14,15 +14,17 @@ var __importStar = (this && this.__importStar) || function (mod) {
result["default"] = mod;
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const core = __importStar(require("@actions/core"));
const find_ruby_1 = __importStar(require("./find-ruby"));
const find_ruby_1 = __importDefault(require("./find-ruby"));
function run() {
return __awaiter(this, void 0, void 0, function* () {
try {
const version = core.getInput('version');
const addToPath = core.getInput('add-to-path');
yield find_ruby_1.default({ version, addToPath }, find_ruby_1.getPlatform());
yield find_ruby_1.default(version);
}
catch (error) {
core.setFailed(error.message);

View File

@@ -1,51 +1,23 @@
import * as core from '@actions/core';
import * as exec from '@actions/exec';
import * as tc from '@actions/tool-cache';
import * as os from 'os';
import * as path from 'path';
export enum Platform {
Windows,
MacOS,
Linux
}
const IS_WINDOWS = process.platform === 'win32';
export function getPlatform(): Platform {
switch (os.platform()) {
case 'win32':
return Platform.Windows;
case 'darwin':
return Platform.MacOS;
case 'linux':
return Platform.Linux;
default:
throw Error('Platform not recognized');
}
}
interface ActionInputs {
version: string;
addToPath: string;
}
export default async function(inputs: ActionInputs, platform: Platform) {
const installDir: string | null = tc.find('Ruby', inputs.version);
export default async function(version: string) {
const installDir: string | null = tc.find('Ruby', version);
if (!installDir) {
throw new Error(`Version ${inputs.version} not found`);
throw new Error(`Version ${version} not found`);
}
const toolPath: string = path.join(installDir, 'bin');
if (platform !== Platform.Windows) {
if (!IS_WINDOWS) {
// Ruby / Gem heavily use the '#!/usr/bin/ruby' to find ruby, so this task needs to
// replace that version of ruby so all the correct version of ruby gets selected
// replace the default
const dest: string = '/usr/bin/ruby';
exec.exec('sudo ln', ['-sf', path.join(toolPath, 'ruby'), dest]); // replace any existing
}
if (inputs.addToPath === 'true') {
core.addPath(toolPath);
}
}

View File

@@ -1,11 +1,10 @@
import * as core from '@actions/core';
import findRubyVersion, {getPlatform} from './find-ruby';
import findRubyVersion from './find-ruby';
async function run() {
try {
const version = core.getInput('version');
const addToPath = core.getInput('add-to-path');
await findRubyVersion({version, addToPath}, getPlatform());
await findRubyVersion(version);
} catch (error) {
core.setFailed(error.message);
}