From 990de42500daa82ff2a1a8da65bda7d1dee161a8 Mon Sep 17 00:00:00 2001 From: Aiden Fujiwara Date: Thu, 2 Nov 2023 11:08:26 -0700 Subject: [PATCH 1/5] filter out non semver compatible tags --- __tests__/configFile.test.ts | 48 ++++++++++++++++++++++++++++++++++-- src/configFile.ts | 8 +++--- src/foreman.ts | 15 +++++++++-- src/main.ts | 11 ++++----- 4 files changed, 69 insertions(+), 13 deletions(-) diff --git a/__tests__/configFile.test.ts b/__tests__/configFile.test.ts index 3b772eb..81db43b 100644 --- a/__tests__/configFile.test.ts +++ b/__tests__/configFile.test.ts @@ -1,6 +1,8 @@ import configFile from "../src/configFile"; -import {parse} from "toml"; - +import foreman from "../src/foreman"; +import type { GitHubRelease } from "../src/foreman"; +import { parse } from "toml"; +import semver from "semver"; test("get off my back, Jest", () => { expect(5).toEqual(5); }); @@ -30,3 +32,45 @@ test("checkSameOrgToolSpec different org", () => { false ); }); + +test("filter valid releases", () => { + const releases: GitHubRelease[] = [ + { + tag_name: "v1.0.0", + assets: [] + }, + { + tag_name: "v2.1.0", + assets: [] + }, + { + tag_name: "v3.0.0-rc.1", + assets: [] + }, + { + tag_name: "notvalidsemver", + assets: [] + }, + { + tag_name: "4.3.0", + assets: [] + } + ]; + + const expectedFilteredReleases: GitHubRelease[] = [ + { + tag_name: "v1.0.0", + assets: [] + }, + { + tag_name: "v2.1.0", + assets: [] + }, + { + tag_name: "v3.0.0-rc.1", + assets: [] + } + ]; + const filteredReleases = foreman.filterValidReleases(releases); + expect(filteredReleases).toEqual(expectedFilteredReleases); +}); diff --git a/src/configFile.ts b/src/configFile.ts index 6b7b13d..3da8c6f 100644 --- a/src/configFile.ts +++ b/src/configFile.ts @@ -1,5 +1,5 @@ -import { parse } from "toml"; -import { readFile } from "fs"; +import {parse} from "toml"; +import {readFile} from "fs"; import findUp from "find-up"; interface foremanConfig { tools: { @@ -58,7 +58,9 @@ async function checkSameOrgInConfig(org: string): Promise { await readFile(manifestPath, "utf8", (err, data) => { if (err) { - throw new Error(`setup-foreman Could not read Foreman config file. err: ${err}`); + throw new Error( + `setup-foreman Could not read Foreman config file. err: ${err}` + ); } const manifestContent = parse(data); const sameGithubOrgSource = checkSameOrgToolSpecs(manifestContent, org); diff --git a/src/foreman.ts b/src/foreman.ts index 718a5c9..9adc87b 100644 --- a/src/foreman.ts +++ b/src/foreman.ts @@ -20,12 +20,20 @@ async function getReleases(octokit: GitHub): Promise { repo: "foreman" }); - const releases = response.data as GitHubRelease[]; + let releases = response.data as GitHubRelease[]; + releases = filterValidReleases(releases); releases.sort((a, b) => -semver.compare(a.tag_name, b.tag_name)); return releases; } +function filterValidReleases(releases: GitHubRelease[]): GitHubRelease[] { + return releases.filter(release => { + const tag = release.tag_name; + return tag.startsWith("v") && semver.valid(tag); + }); +} + function chooseRelease( versionReq: string, releases: GitHubRelease[] @@ -97,5 +105,8 @@ export default { chooseAsset, authenticate, addBinDirToPath, - installTools + installTools, + filterValidReleases }; + +export type {GitHubRelease}; diff --git a/src/main.ts b/src/main.ts index 453abc9..5796522 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,8 +1,8 @@ -import { getInput, debug, addPath, setFailed } from "@actions/core"; -import { downloadTool, extractZip } from "@actions/tool-cache"; -import { GitHub } from "@actions/github"; -import { resolve } from "path"; -import { exec } from "@actions/exec"; +import {getInput, debug, addPath, setFailed} from "@actions/core"; +import {downloadTool, extractZip} from "@actions/tool-cache"; +import {GitHub} from "@actions/github"; +import {resolve} from "path"; +import {exec} from "@actions/exec"; import configFile from "./configFile"; import foreman from "./foreman"; @@ -15,7 +15,6 @@ async function run(): Promise { "allow-external-github-orgs" ).toLowerCase(); - const octokit = new GitHub(githubToken); const releases = await foreman.getReleases(octokit); debug("Choosing release from GitHub API"); From fa71755706f0da33117baf3c73a906cbeabaa291 Mon Sep 17 00:00:00 2001 From: Aiden Fujiwara Date: Thu, 2 Nov 2023 11:09:31 -0700 Subject: [PATCH 2/5] remove unused import --- __tests__/configFile.test.ts | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/__tests__/configFile.test.ts b/__tests__/configFile.test.ts index 81db43b..235ecb4 100644 --- a/__tests__/configFile.test.ts +++ b/__tests__/configFile.test.ts @@ -1,8 +1,7 @@ import configFile from "../src/configFile"; import foreman from "../src/foreman"; -import type { GitHubRelease } from "../src/foreman"; -import { parse } from "toml"; -import semver from "semver"; +import type {GitHubRelease} from "../src/foreman"; +import {parse} from "toml"; test("get off my back, Jest", () => { expect(5).toEqual(5); }); From 75f1636d91f3ee9df16fa38feaee369660b93db4 Mon Sep 17 00:00:00 2001 From: Aiden Fujiwara Date: Thu, 2 Nov 2023 11:12:12 -0700 Subject: [PATCH 3/5] code structure --- src/foreman.ts | 9 ++++----- src/main.ts | 13 +++++++------ 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/foreman.ts b/src/foreman.ts index 9adc87b..d669c6b 100644 --- a/src/foreman.ts +++ b/src/foreman.ts @@ -1,6 +1,6 @@ -import {addPath} from "@actions/core"; -import {exec} from "@actions/exec"; -import {GitHub} from "@actions/github"; +import { addPath } from "@actions/core"; +import { exec } from "@actions/exec"; +import { GitHub } from "@actions/github"; import semver from "semver"; import os from "os"; @@ -21,7 +21,6 @@ async function getReleases(octokit: GitHub): Promise { }); let releases = response.data as GitHubRelease[]; - releases = filterValidReleases(releases); releases.sort((a, b) => -semver.compare(a.tag_name, b.tag_name)); return releases; @@ -109,4 +108,4 @@ export default { filterValidReleases }; -export type {GitHubRelease}; +export type { GitHubRelease }; diff --git a/src/main.ts b/src/main.ts index 5796522..d4de7a7 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,8 +1,8 @@ -import {getInput, debug, addPath, setFailed} from "@actions/core"; -import {downloadTool, extractZip} from "@actions/tool-cache"; -import {GitHub} from "@actions/github"; -import {resolve} from "path"; -import {exec} from "@actions/exec"; +import { getInput, debug, addPath, setFailed } from "@actions/core"; +import { downloadTool, extractZip } from "@actions/tool-cache"; +import { GitHub } from "@actions/github"; +import { resolve } from "path"; +import { exec } from "@actions/exec"; import configFile from "./configFile"; import foreman from "./foreman"; @@ -17,9 +17,10 @@ async function run(): Promise { const octokit = new GitHub(githubToken); const releases = await foreman.getReleases(octokit); + const validReleases = foreman.filterValidReleases(releases) debug("Choosing release from GitHub API"); - const release = foreman.chooseRelease(versionReq, releases); + const release = foreman.chooseRelease(versionReq, validReleases); if (release == null) { throw new Error( `Could not find Foreman release for version ${versionReq}` From 1cd08d32293c344a1b939e988df53982477164b8 Mon Sep 17 00:00:00 2001 From: Aiden Fujiwara Date: Thu, 2 Nov 2023 11:16:17 -0700 Subject: [PATCH 4/5] lint --- src/foreman.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/foreman.ts b/src/foreman.ts index d669c6b..b1604d5 100644 --- a/src/foreman.ts +++ b/src/foreman.ts @@ -20,7 +20,7 @@ async function getReleases(octokit: GitHub): Promise { repo: "foreman" }); - let releases = response.data as GitHubRelease[]; + const releases = response.data as GitHubRelease[]; releases.sort((a, b) => -semver.compare(a.tag_name, b.tag_name)); return releases; From 0025671d66941c5b756d1778fbb784b5c0b3f43d Mon Sep 17 00:00:00 2001 From: Aiden Fujiwara Date: Thu, 2 Nov 2023 11:39:53 -0700 Subject: [PATCH 5/5] added invalid tag starting with v test --- __tests__/configFile.test.ts | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/__tests__/configFile.test.ts b/__tests__/configFile.test.ts index 235ecb4..52c6210 100644 --- a/__tests__/configFile.test.ts +++ b/__tests__/configFile.test.ts @@ -1,7 +1,7 @@ import configFile from "../src/configFile"; import foreman from "../src/foreman"; -import type {GitHubRelease} from "../src/foreman"; -import {parse} from "toml"; +import type { GitHubRelease } from "../src/foreman"; +import { parse } from "toml"; test("get off my back, Jest", () => { expect(5).toEqual(5); }); @@ -53,6 +53,10 @@ test("filter valid releases", () => { { tag_name: "4.3.0", assets: [] + }, + { + tag_name: "verybadtag", + assets: [] } ];