refactor: Add getURL()
This commit is contained in:
parent
13ddb0fba5
commit
a488e041c8
4 changed files with 37 additions and 9 deletions
15
__tests__/get-url.test.js
Normal file
15
__tests__/get-url.test.js
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
const getURL = require("../lib/get-url");
|
||||||
|
|
||||||
|
describe("getURL()", () => {
|
||||||
|
test("test", () => {
|
||||||
|
const baseURL = "https://github.com/gohugoio/hugo/releases/download/v0.58.2";
|
||||||
|
const urlLinux = `${baseURL}/hugo_0.58.2_Linux-64bit.tar.gz`;
|
||||||
|
const urlLinuxExtended = `${baseURL}/hugo_extended_0.58.2_Linux-64bit.tar.gz`;
|
||||||
|
const urlMacOS = `${baseURL}/hugo_0.58.2_macOS-64bit.tar.gz`;
|
||||||
|
const urlWindows = `${baseURL}/hugo_0.58.2_Windows-64bit.zip`;
|
||||||
|
expect(getURL("Linux", false, "0.58.2")).toBe(urlLinux);
|
||||||
|
expect(getURL("Linux", true, "0.58.2")).toBe(urlLinuxExtended);
|
||||||
|
expect(getURL("macOS", false, "0.58.2")).toBe(urlMacOS);
|
||||||
|
expect(getURL("Windows", false, "0.58.2")).toBe(urlWindows);
|
||||||
|
});
|
||||||
|
});
|
||||||
19
lib/get-url.js
Normal file
19
lib/get-url.js
Normal file
|
|
@ -0,0 +1,19 @@
|
||||||
|
function getURL(os, extended, version) {
|
||||||
|
let extendedStr = "";
|
||||||
|
let ext = "tar.gz";
|
||||||
|
|
||||||
|
if (extended === true) {
|
||||||
|
extendedStr = "extended_";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (os === "Windows") {
|
||||||
|
ext = "zip";
|
||||||
|
}
|
||||||
|
|
||||||
|
const hugoName = `hugo_${extendedStr}${version}_${os}-64bit`;
|
||||||
|
const url = `https://github.com/gohugoio/hugo/releases/download/v${version}/${hugoName}.${ext}`;
|
||||||
|
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = getURL;
|
||||||
10
lib/index.js
10
lib/index.js
|
|
@ -3,6 +3,7 @@ const tc = require("@actions/tool-cache");
|
||||||
const io = require("@actions/io");
|
const io = require("@actions/io");
|
||||||
const exec = require("@actions/exec");
|
const exec = require("@actions/exec");
|
||||||
const getOS = require("./get-os");
|
const getOS = require("./get-os");
|
||||||
|
const getURL = require("./get-url");
|
||||||
const getLatestVersion = require("./get-latest-version");
|
const getLatestVersion = require("./get-latest-version");
|
||||||
|
|
||||||
// most @actions toolkit packages have async methods
|
// most @actions toolkit packages have async methods
|
||||||
|
|
@ -18,18 +19,11 @@ async function run() {
|
||||||
|
|
||||||
const extended = core.getInput("extended");
|
const extended = core.getInput("extended");
|
||||||
console.log(`Hugo extended: ${extended}`);
|
console.log(`Hugo extended: ${extended}`);
|
||||||
let extendedStr = "";
|
|
||||||
if (extended === "true") {
|
|
||||||
extendedStr = "extended_";
|
|
||||||
}
|
|
||||||
|
|
||||||
const osName = getOS(process.platform);
|
const osName = getOS(process.platform);
|
||||||
console.log(`Operating System: ${osName}`);
|
console.log(`Operating System: ${osName}`);
|
||||||
|
|
||||||
const hugoName = `hugo_${extendedStr}${hugoVersion}_${osName}-64bit`;
|
const hugoURL = getURL(osName, extended, hugoVersion);
|
||||||
core.debug(`hugoName: ${hugoName}`);
|
|
||||||
|
|
||||||
const hugoURL = `https://github.com/gohugoio/hugo/releases/download/v${hugoVersion}/${hugoName}.tar.gz`;
|
|
||||||
core.debug(`hugoURL: ${hugoURL}`);
|
core.debug(`hugoURL: ${hugoURL}`);
|
||||||
|
|
||||||
const hugoPath = `${process.env.HOME}/bin`;
|
const hugoPath = `${process.env.HOME}/bin`;
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
"main": "lib/index.js",
|
"main": "lib/index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"lint": "eslint ./lib/**/*",
|
"lint": "eslint ./lib/**/*",
|
||||||
"test": "jest",
|
"test": "jest --coverage --verbose",
|
||||||
"build": "npm prune --production"
|
"build": "npm prune --production"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue