Add prototype action using exec and curl

* Downloads a fixed version Julia binary using curl
* Adds it to PATH
* Runs `julia --version` to test the installation
This commit is contained in:
Sascha Mann
2019-08-13 01:13:12 +02:00
parent d3bf4c48c9
commit 7961e4e3f2
8 changed files with 102 additions and 30 deletions

View File

@@ -1,3 +1,3 @@
describe('TODO - Add a test suite', () => { describe("TODO - Add a test suite", () => {
it('TODO - Add a test', async () => {}); it("TODO - Add a test", async () => {});
}); });

View File

@@ -1,10 +1,10 @@
name: 'Node 12 Template Action' name: 'Setup Julia environment'
description: 'Get started with Node actions' description: 'Setup a Julia environment and add it to the PATH'
author: 'GitHub' author: 'Sascha Mann <git@mail.saschamann.eu>'
inputs: inputs:
myInput: version:
description: 'Input to use' description: 'The Julia version to download (if necessary) and use. Example: 1.0'
default: 'world' default: '1.0'
runs: runs:
using: 'node12' using: 'node12'
main: 'lib/main.js' main: 'lib/setup-julia.js'

3
lib/file.js Normal file
View File

@@ -0,0 +1,3 @@
"use strict";
// Apparently this satisfies the typescript compiler
// https://stackoverflow.com/questions/41211566/tsconfig-json-buildno-inputs-were-found-in-config-file/45790421#45790421

46
lib/setup-julia.js Normal file
View File

@@ -0,0 +1,46 @@
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
result["default"] = mod;
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
const core = __importStar(require("@actions/core"));
const exec = __importStar(require("@actions/exec"));
const os = __importStar(require("os"));
function run() {
return __awaiter(this, void 0, void 0, function* () {
try {
const version = core.getInput("version");
core.debug(`selected Julia version: ${version}`);
// Store information about the environment
const osPlat = os.platform();
const osArch = os.arch();
// For now, just download Linux x64 binaries
yield exec.exec("curl", [
"-O",
"https://julialang-s3.julialang.org/bin/linux/x64/1.0/julia-1.0.1-linux-x86_64.tar.gz"
]);
yield exec.exec("tar xf julia-1.0.1-linux-x86_64.tar.gz");
// Add the downloaded binary to path
core.addPath("julia-1.0.1/bin");
// Test if it worked
yield exec.exec("julia", ["--version"]);
yield exec.exec("julia", ["-e", "'using InteractiveUtils; versioninfo()'"]);
}
catch (error) {
core.setFailed(error.message);
}
});
}
run();

4
package-lock.json generated
View File

@@ -1,6 +1,6 @@
{ {
"name": "node12-template-action", "name": "setup-julia",
"version": "0.0.0", "version": "1.0.0",
"lockfileVersion": 1, "lockfileVersion": 1,
"requires": true, "requires": true,
"dependencies": { "dependencies": {

View File

@@ -1,23 +1,25 @@
{ {
"name": "node12-template-action", "name": "setup-julia",
"version": "0.0.0", "version": "1.0.0",
"private": true, "private": true,
"description": "Node 12 template action", "description": "setup Julia action",
"main": "lib/main.js", "main": "lib/setup-julia.js",
"scripts": { "scripts": {
"build": "tsc", "build": "tsc",
"format": "prettier --write **/*.ts",
"format-check": "prettier --check **/*.ts",
"test": "jest" "test": "jest"
}, },
"repository": { "repository": {
"type": "git", "type": "git",
"url": "git+https://github.com/actions/node12-template.git" "url": "git+https://github.com/julia-actions/setup-julia.git"
}, },
"keywords": [ "keywords": [
"actions", "actions",
"node", "julia",
"setup" "setup"
], ],
"author": "GitHub", "author": "Sascha Mann",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@actions/core": "^1.0.0", "@actions/core": "^1.0.0",
@@ -33,6 +35,7 @@
"@types/semver": "^6.0.0", "@types/semver": "^6.0.0",
"jest": "^24.8.0", "jest": "^24.8.0",
"jest-circus": "^24.7.1", "jest-circus": "^24.7.1",
"prettier": "^1.17.1",
"ts-jest": "^24.0.2", "ts-jest": "^24.0.2",
"typescript": "^3.5.1" "typescript": "^3.5.1"
} }

View File

@@ -1,12 +0,0 @@
import * as core from '@actions/core';
async function run() {
try {
const myInput = core.getInput('myInput');
core.debug(`Hello ${myInput}`);
} catch (error) {
core.setFailed(error.message);
}
}
run();

32
src/setup-julia.ts Normal file
View File

@@ -0,0 +1,32 @@
import * as core from "@actions/core";
import * as exec from "@actions/exec";
import * as os from "os";
async function run() {
try {
const version = core.getInput("version");
core.debug(`selected Julia version: ${version}`);
// Store information about the environment
const osPlat = os.platform();
const osArch = os.arch();
// For now, just download Linux x64 binaries
await exec.exec("curl", [
"-O",
"https://julialang-s3.julialang.org/bin/linux/x64/1.0/julia-1.0.1-linux-x86_64.tar.gz"
]);
await exec.exec("tar xf julia-1.0.1-linux-x86_64.tar.gz");
// Add the downloaded binary to path
core.addPath("julia-1.0.1/bin");
// Test if it worked
await exec.exec("julia", ["--version"]);
} catch (error) {
core.setFailed(error.message);
}
}
run();