mirror of
https://github.com/oven-sh/setup-bun.git
synced 2025-04-04 02:30:10 +08:00
chore: update Prettier settings and add settings for vscode
This commit is contained in:
parent
6fb6603cc1
commit
f6221cd95f
4
.prettierrc
Normal file
4
.prettierrc
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
"semi": false,
|
||||||
|
"quoteProps": "preserve"
|
||||||
|
}
|
3
.vscode/extensions.json
vendored
Normal file
3
.vscode/extensions.json
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"recommendations": ["esbenp.prettier-vscode", "github.vscode-github-actions"]
|
||||||
|
}
|
3
.vscode/settings.json
vendored
Normal file
3
.vscode/settings.json
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
||||||
|
}
|
6
bun.lock
Executable file → Normal file
6
bun.lock
Executable file → Normal file
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"lockfileVersion": 0,
|
"lockfileVersion": 1,
|
||||||
"workspaces": {
|
"workspaces": {
|
||||||
"": {
|
"": {
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
@ -13,7 +13,7 @@
|
|||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/node": "^20.8.2",
|
"@types/node": "^20.8.2",
|
||||||
"esbuild": "^0.19.2",
|
"esbuild": "^0.19.2",
|
||||||
"prettier": "^2.8.4",
|
"prettier": "^3.4.2",
|
||||||
"typescript": "^4.9.5",
|
"typescript": "^4.9.5",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -139,7 +139,7 @@
|
|||||||
|
|
||||||
"node-fetch": ["node-fetch@2.7.0", "", { "dependencies": { "whatwg-url": "^5.0.0" }, "peerDependencies": { "encoding": "^0.1.0" }, "optionalPeers": ["encoding"] }, "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A=="],
|
"node-fetch": ["node-fetch@2.7.0", "", { "dependencies": { "whatwg-url": "^5.0.0" }, "peerDependencies": { "encoding": "^0.1.0" }, "optionalPeers": ["encoding"] }, "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A=="],
|
||||||
|
|
||||||
"prettier": ["prettier@2.8.8", "", { "bin": { "prettier": "bin-prettier.js" } }, "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q=="],
|
"prettier": ["prettier@3.4.2", "", { "bin": { "prettier": "bin/prettier.cjs" } }, "sha512-e9MewbtFo+Fevyuxn/4rrcDAaq0IYxPGLvObpQjiZBMAzB9IGmzlnG9RZy3FFas+eBMu2vA0CszMeduow5dIuQ=="],
|
||||||
|
|
||||||
"process": ["process@0.11.10", "", {}, "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A=="],
|
"process": ["process@0.11.10", "", {}, "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A=="],
|
||||||
|
|
||||||
|
10
package-lock.json
generated
10
package-lock.json
generated
@ -19,7 +19,7 @@
|
|||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/node": "^20.8.2",
|
"@types/node": "^20.8.2",
|
||||||
"esbuild": "^0.19.2",
|
"esbuild": "^0.19.2",
|
||||||
"prettier": "^2.8.4",
|
"prettier": "^3.4.2",
|
||||||
"typescript": "^4.9.5"
|
"typescript": "^4.9.5"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -473,14 +473,16 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/prettier": {
|
"node_modules/prettier": {
|
||||||
"version": "2.8.8",
|
"version": "3.4.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/prettier/-/prettier-3.4.2.tgz",
|
||||||
|
"integrity": "sha512-e9MewbtFo+Fevyuxn/4rrcDAaq0IYxPGLvObpQjiZBMAzB9IGmzlnG9RZy3FFas+eBMu2vA0CszMeduow5dIuQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"bin": {
|
"bin": {
|
||||||
"prettier": "bin-prettier.js"
|
"prettier": "bin/prettier.cjs"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=10.13.0"
|
"node": ">=14"
|
||||||
},
|
},
|
||||||
"funding": {
|
"funding": {
|
||||||
"url": "https://github.com/prettier/prettier?sponsor=1"
|
"url": "https://github.com/prettier/prettier?sponsor=1"
|
||||||
|
@ -32,10 +32,7 @@
|
|||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/node": "^20.8.2",
|
"@types/node": "^20.8.2",
|
||||||
"esbuild": "^0.19.2",
|
"esbuild": "^0.19.2",
|
||||||
"prettier": "^2.8.4",
|
"prettier": "^3.4.2",
|
||||||
"typescript": "^4.9.5"
|
"typescript": "^4.9.5"
|
||||||
},
|
|
||||||
"prettier": {
|
|
||||||
"quoteProps": "preserve"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
194
src/action.ts
194
src/action.ts
@ -1,117 +1,117 @@
|
|||||||
import { createHash } from "node:crypto";
|
import { createHash } from "node:crypto"
|
||||||
import { homedir } from "node:os";
|
import { homedir } from "node:os"
|
||||||
import { join } from "node:path";
|
import { join } from "node:path"
|
||||||
import {
|
import {
|
||||||
mkdirSync,
|
mkdirSync,
|
||||||
readdirSync,
|
readdirSync,
|
||||||
symlinkSync,
|
symlinkSync,
|
||||||
renameSync,
|
renameSync,
|
||||||
copyFileSync,
|
copyFileSync,
|
||||||
} from "node:fs";
|
} from "node:fs"
|
||||||
import { addPath, info, warning } from "@actions/core";
|
import { addPath, info, warning } from "@actions/core"
|
||||||
import { isFeatureAvailable, restoreCache } from "@actions/cache";
|
import { isFeatureAvailable, restoreCache } from "@actions/cache"
|
||||||
import { downloadTool, extractZip } from "@actions/tool-cache";
|
import { downloadTool, extractZip } from "@actions/tool-cache"
|
||||||
import { getExecOutput } from "@actions/exec";
|
import { getExecOutput } from "@actions/exec"
|
||||||
import { writeBunfig } from "./bunfig";
|
import { writeBunfig } from "./bunfig"
|
||||||
import { saveState } from "@actions/core";
|
import { saveState } from "@actions/core"
|
||||||
import { addExtension, retry } from "./utils";
|
import { addExtension, retry } from "./utils"
|
||||||
|
|
||||||
export type Input = {
|
export type Input = {
|
||||||
customUrl?: string;
|
customUrl?: string
|
||||||
version?: string;
|
version?: string
|
||||||
os?: string;
|
os?: string
|
||||||
arch?: string;
|
arch?: string
|
||||||
avx2?: boolean;
|
avx2?: boolean
|
||||||
profile?: boolean;
|
profile?: boolean
|
||||||
scope?: string;
|
scope?: string
|
||||||
registryUrl?: string;
|
registryUrl?: string
|
||||||
noCache?: boolean;
|
noCache?: boolean
|
||||||
};
|
}
|
||||||
|
|
||||||
export type Output = {
|
export type Output = {
|
||||||
version: string;
|
version: string
|
||||||
revision: string;
|
revision: string
|
||||||
bunPath: string;
|
bunPath: string
|
||||||
url: string;
|
url: string
|
||||||
cacheHit: boolean;
|
cacheHit: boolean
|
||||||
};
|
}
|
||||||
|
|
||||||
export type CacheState = {
|
export type CacheState = {
|
||||||
cacheEnabled: boolean;
|
cacheEnabled: boolean
|
||||||
cacheHit: boolean;
|
cacheHit: boolean
|
||||||
bunPath: string;
|
bunPath: string
|
||||||
url: string;
|
url: string
|
||||||
};
|
}
|
||||||
|
|
||||||
export default async (options: Input): Promise<Output> => {
|
export default async (options: Input): Promise<Output> => {
|
||||||
const bunfigPath = join(process.cwd(), "bunfig.toml");
|
const bunfigPath = join(process.cwd(), "bunfig.toml")
|
||||||
writeBunfig(bunfigPath, options);
|
writeBunfig(bunfigPath, options)
|
||||||
|
|
||||||
const url = getDownloadUrl(options);
|
const url = getDownloadUrl(options)
|
||||||
const cacheEnabled = isCacheEnabled(options);
|
const cacheEnabled = isCacheEnabled(options)
|
||||||
|
|
||||||
const binPath = join(homedir(), ".bun", "bin");
|
const binPath = join(homedir(), ".bun", "bin")
|
||||||
try {
|
try {
|
||||||
mkdirSync(binPath, { recursive: true });
|
mkdirSync(binPath, { recursive: true })
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (error.code !== "EEXIST") {
|
if (error.code !== "EEXIST") {
|
||||||
throw error;
|
throw error
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
addPath(binPath);
|
addPath(binPath)
|
||||||
|
|
||||||
const exe = (name: string) =>
|
const exe = (name: string) =>
|
||||||
process.platform === "win32" ? `${name}.exe` : name;
|
process.platform === "win32" ? `${name}.exe` : name
|
||||||
const bunPath = join(binPath, exe("bun"));
|
const bunPath = join(binPath, exe("bun"))
|
||||||
try {
|
try {
|
||||||
symlinkSync(bunPath, join(binPath, exe("bunx")));
|
symlinkSync(bunPath, join(binPath, exe("bunx")))
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (error.code !== "EEXIST") {
|
if (error.code !== "EEXIST") {
|
||||||
throw error;
|
throw error
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let revision: string | undefined;
|
let revision: string | undefined
|
||||||
let cacheHit = false;
|
let cacheHit = false
|
||||||
if (cacheEnabled) {
|
if (cacheEnabled) {
|
||||||
const cacheKey = createHash("sha1").update(url).digest("base64");
|
const cacheKey = createHash("sha1").update(url).digest("base64")
|
||||||
|
|
||||||
const cacheRestored = await restoreCache([bunPath], cacheKey);
|
const cacheRestored = await restoreCache([bunPath], cacheKey)
|
||||||
if (cacheRestored) {
|
if (cacheRestored) {
|
||||||
revision = await getRevision(bunPath);
|
revision = await getRevision(bunPath)
|
||||||
if (revision) {
|
if (revision) {
|
||||||
cacheHit = true;
|
cacheHit = true
|
||||||
info(`Using a cached version of Bun: ${revision}`);
|
info(`Using a cached version of Bun: ${revision}`)
|
||||||
} else {
|
} else {
|
||||||
warning(
|
warning(
|
||||||
`Found a cached version of Bun: ${revision} (but it appears to be corrupted?)`
|
`Found a cached version of Bun: ${revision} (but it appears to be corrupted?)`,
|
||||||
);
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!cacheHit) {
|
if (!cacheHit) {
|
||||||
info(`Downloading a new version of Bun: ${url}`);
|
info(`Downloading a new version of Bun: ${url}`)
|
||||||
// TODO: remove this, temporary fix for https://github.com/oven-sh/setup-bun/issues/73
|
// TODO: remove this, temporary fix for https://github.com/oven-sh/setup-bun/issues/73
|
||||||
revision = await retry(async () => await downloadBun(url, bunPath), 3);
|
revision = await retry(async () => await downloadBun(url, bunPath), 3)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!revision) {
|
if (!revision) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
"Downloaded a new version of Bun, but failed to check its version? Try again."
|
"Downloaded a new version of Bun, but failed to check its version? Try again.",
|
||||||
);
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
const [version] = revision.split("+");
|
const [version] = revision.split("+")
|
||||||
|
|
||||||
const cacheState: CacheState = {
|
const cacheState: CacheState = {
|
||||||
cacheEnabled,
|
cacheEnabled,
|
||||||
cacheHit,
|
cacheHit,
|
||||||
bunPath,
|
bunPath,
|
||||||
url,
|
url,
|
||||||
};
|
}
|
||||||
|
|
||||||
saveState("cache", JSON.stringify(cacheState));
|
saveState("cache", JSON.stringify(cacheState))
|
||||||
|
|
||||||
return {
|
return {
|
||||||
version,
|
version,
|
||||||
@ -119,92 +119,92 @@ export default async (options: Input): Promise<Output> => {
|
|||||||
bunPath,
|
bunPath,
|
||||||
url,
|
url,
|
||||||
cacheHit,
|
cacheHit,
|
||||||
};
|
}
|
||||||
};
|
}
|
||||||
|
|
||||||
async function downloadBun(
|
async function downloadBun(
|
||||||
url: string,
|
url: string,
|
||||||
bunPath: string
|
bunPath: string,
|
||||||
): Promise<string | undefined> {
|
): Promise<string | undefined> {
|
||||||
// Workaround for https://github.com/oven-sh/setup-bun/issues/79 and https://github.com/actions/toolkit/issues/1179
|
// Workaround for https://github.com/oven-sh/setup-bun/issues/79 and https://github.com/actions/toolkit/issues/1179
|
||||||
const zipPath = addExtension(await downloadTool(url), ".zip");
|
const zipPath = addExtension(await downloadTool(url), ".zip")
|
||||||
const extractedZipPath = await extractZip(zipPath);
|
const extractedZipPath = await extractZip(zipPath)
|
||||||
const extractedBunPath = await extractBun(extractedZipPath);
|
const extractedBunPath = await extractBun(extractedZipPath)
|
||||||
try {
|
try {
|
||||||
renameSync(extractedBunPath, bunPath);
|
renameSync(extractedBunPath, bunPath)
|
||||||
} catch {
|
} catch {
|
||||||
// If mv does not work, try to copy the file instead.
|
// If mv does not work, try to copy the file instead.
|
||||||
// For example: EXDEV: cross-device link not permitted
|
// For example: EXDEV: cross-device link not permitted
|
||||||
copyFileSync(extractedBunPath, bunPath);
|
copyFileSync(extractedBunPath, bunPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
return await getRevision(bunPath);
|
return await getRevision(bunPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
function isCacheEnabled(options: Input): boolean {
|
function isCacheEnabled(options: Input): boolean {
|
||||||
const { customUrl, version, noCache } = options;
|
const { customUrl, version, noCache } = options
|
||||||
if (noCache) {
|
if (noCache) {
|
||||||
return false;
|
return false
|
||||||
}
|
}
|
||||||
if (customUrl) {
|
if (customUrl) {
|
||||||
return false;
|
return false
|
||||||
}
|
}
|
||||||
if (!version || /latest|canary|action/i.test(version)) {
|
if (!version || /latest|canary|action/i.test(version)) {
|
||||||
return false;
|
return false
|
||||||
}
|
}
|
||||||
return isFeatureAvailable();
|
return isFeatureAvailable()
|
||||||
}
|
}
|
||||||
|
|
||||||
function getDownloadUrl(options: Input): string {
|
function getDownloadUrl(options: Input): string {
|
||||||
const { customUrl } = options;
|
const { customUrl } = options
|
||||||
if (customUrl) {
|
if (customUrl) {
|
||||||
return customUrl;
|
return customUrl
|
||||||
}
|
}
|
||||||
const { version, os, arch, avx2, profile } = options;
|
const { version, os, arch, avx2, profile } = options
|
||||||
const eversion = encodeURIComponent(version ?? "latest");
|
const eversion = encodeURIComponent(version ?? "latest")
|
||||||
const eos = encodeURIComponent(os ?? process.platform);
|
const eos = encodeURIComponent(os ?? process.platform)
|
||||||
const earch = encodeURIComponent(arch ?? process.arch);
|
const earch = encodeURIComponent(arch ?? process.arch)
|
||||||
const eavx2 = encodeURIComponent(avx2 ?? true);
|
const eavx2 = encodeURIComponent(avx2 ?? true)
|
||||||
const eprofile = encodeURIComponent(profile ?? false);
|
const eprofile = encodeURIComponent(profile ?? false)
|
||||||
const { href } = new URL(
|
const { href } = new URL(
|
||||||
`${eversion}/${eos}/${earch}?avx2=${eavx2}&profile=${eprofile}`,
|
`${eversion}/${eos}/${earch}?avx2=${eavx2}&profile=${eprofile}`,
|
||||||
"https://bun.sh/download/"
|
"https://bun.sh/download/",
|
||||||
);
|
)
|
||||||
return href;
|
return href
|
||||||
}
|
}
|
||||||
|
|
||||||
async function extractBun(path: string): Promise<string> {
|
async function extractBun(path: string): Promise<string> {
|
||||||
for (const entry of readdirSync(path, { withFileTypes: true })) {
|
for (const entry of readdirSync(path, { withFileTypes: true })) {
|
||||||
const { name } = entry;
|
const { name } = entry
|
||||||
const entryPath = join(path, name);
|
const entryPath = join(path, name)
|
||||||
if (entry.isFile()) {
|
if (entry.isFile()) {
|
||||||
if (name === "bun" || name === "bun.exe") {
|
if (name === "bun" || name === "bun.exe") {
|
||||||
return entryPath;
|
return entryPath
|
||||||
}
|
}
|
||||||
if (/^bun.*\.zip/.test(name)) {
|
if (/^bun.*\.zip/.test(name)) {
|
||||||
const extractedPath = await extractZip(entryPath);
|
const extractedPath = await extractZip(entryPath)
|
||||||
return extractBun(extractedPath);
|
return extractBun(extractedPath)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (/^bun/.test(name) && entry.isDirectory()) {
|
if (/^bun/.test(name) && entry.isDirectory()) {
|
||||||
return extractBun(entryPath);
|
return extractBun(entryPath)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
throw new Error("Could not find executable: bun");
|
throw new Error("Could not find executable: bun")
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getRevision(exe: string): Promise<string | undefined> {
|
async function getRevision(exe: string): Promise<string | undefined> {
|
||||||
const revision = await getExecOutput(exe, ["--revision"], {
|
const revision = await getExecOutput(exe, ["--revision"], {
|
||||||
ignoreReturnCode: true,
|
ignoreReturnCode: true,
|
||||||
});
|
})
|
||||||
if (revision.exitCode === 0 && /^\d+\.\d+\.\d+/.test(revision.stdout)) {
|
if (revision.exitCode === 0 && /^\d+\.\d+\.\d+/.test(revision.stdout)) {
|
||||||
return revision.stdout.trim();
|
return revision.stdout.trim()
|
||||||
}
|
}
|
||||||
const version = await getExecOutput(exe, ["--version"], {
|
const version = await getExecOutput(exe, ["--version"], {
|
||||||
ignoreReturnCode: true,
|
ignoreReturnCode: true,
|
||||||
});
|
})
|
||||||
if (version.exitCode === 0 && /^\d+\.\d+\.\d+/.test(version.stdout)) {
|
if (version.exitCode === 0 && /^\d+\.\d+\.\d+/.test(version.stdout)) {
|
||||||
return version.stdout.trim();
|
return version.stdout.trim()
|
||||||
}
|
}
|
||||||
return undefined;
|
return undefined
|
||||||
}
|
}
|
||||||
|
@ -1,50 +1,50 @@
|
|||||||
import { EOL } from "node:os";
|
import { EOL } from "node:os"
|
||||||
import { appendFileSync } from "node:fs";
|
import { appendFileSync } from "node:fs"
|
||||||
import { info } from "@actions/core";
|
import { info } from "@actions/core"
|
||||||
|
|
||||||
type BunfigOptions = {
|
type BunfigOptions = {
|
||||||
registryUrl?: string;
|
registryUrl?: string
|
||||||
scope?: string;
|
scope?: string
|
||||||
};
|
}
|
||||||
|
|
||||||
export function createBunfig(options: BunfigOptions): string | null {
|
export function createBunfig(options: BunfigOptions): string | null {
|
||||||
const { registryUrl, scope } = options;
|
const { registryUrl, scope } = options
|
||||||
|
|
||||||
let url: URL | undefined;
|
let url: URL | undefined
|
||||||
if (registryUrl) {
|
if (registryUrl) {
|
||||||
try {
|
try {
|
||||||
url = new URL(registryUrl);
|
url = new URL(registryUrl)
|
||||||
} catch {
|
} catch {
|
||||||
throw new Error(`Invalid registry-url: ${registryUrl}`);
|
throw new Error(`Invalid registry-url: ${registryUrl}`)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let owner: string | undefined;
|
let owner: string | undefined
|
||||||
if (scope) {
|
if (scope) {
|
||||||
owner = scope.startsWith("@")
|
owner = scope.startsWith("@")
|
||||||
? scope.toLocaleLowerCase()
|
? scope.toLocaleLowerCase()
|
||||||
: `@${scope.toLocaleLowerCase()}`;
|
: `@${scope.toLocaleLowerCase()}`
|
||||||
}
|
}
|
||||||
|
|
||||||
if (url && owner) {
|
if (url && owner) {
|
||||||
return `[install.scopes]${EOL}'${owner}' = { token = "$BUN_AUTH_TOKEN", url = "${url}"}${EOL}`;
|
return `[install.scopes]${EOL}'${owner}' = { token = "$BUN_AUTH_TOKEN", url = "${url}"}${EOL}`
|
||||||
}
|
}
|
||||||
|
|
||||||
if (url && !owner) {
|
if (url && !owner) {
|
||||||
return `[install]${EOL}registry = "${url}"${EOL}`;
|
return `[install]${EOL}registry = "${url}"${EOL}`
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
export function writeBunfig(path: string, options: BunfigOptions): void {
|
export function writeBunfig(path: string, options: BunfigOptions): void {
|
||||||
const bunfig = createBunfig(options);
|
const bunfig = createBunfig(options)
|
||||||
if (!bunfig) {
|
if (!bunfig) {
|
||||||
return;
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
info(`Writing bunfig.toml to '${path}'.`);
|
info(`Writing bunfig.toml to '${path}'.`)
|
||||||
appendFileSync(path, bunfig, {
|
appendFileSync(path, bunfig, {
|
||||||
encoding: "utf8",
|
encoding: "utf8",
|
||||||
});
|
})
|
||||||
}
|
}
|
||||||
|
@ -1,18 +1,17 @@
|
|||||||
import { saveCache } from "@actions/cache";
|
import { saveCache } from "@actions/cache"
|
||||||
import { getState, warning } from "@actions/core";
|
import { getState, warning } from "@actions/core"
|
||||||
import { CacheState } from "./action";
|
import { CacheState } from "./action"
|
||||||
import { createHash } from "node:crypto";
|
import { createHash } from "node:crypto"
|
||||||
|
;(async () => {
|
||||||
(async () => {
|
const state: CacheState = JSON.parse(getState("cache"))
|
||||||
const state: CacheState = JSON.parse(getState("cache"));
|
|
||||||
if (state.cacheEnabled && !state.cacheHit) {
|
if (state.cacheEnabled && !state.cacheHit) {
|
||||||
const cacheKey = createHash("sha1").update(state.url).digest("base64");
|
const cacheKey = createHash("sha1").update(state.url).digest("base64")
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await saveCache([state.bunPath], cacheKey);
|
await saveCache([state.bunPath], cacheKey)
|
||||||
process.exit(0);
|
process.exit(0)
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
warning("Failed to save Bun to cache.");
|
warning("Failed to save Bun to cache.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})();
|
})()
|
||||||
|
28
src/index.ts
28
src/index.ts
@ -1,10 +1,10 @@
|
|||||||
import { tmpdir } from "node:os";
|
import { tmpdir } from "node:os"
|
||||||
import { getInput, setOutput, setFailed, getBooleanInput } from "@actions/core";
|
import { getInput, setOutput, setFailed, getBooleanInput } from "@actions/core"
|
||||||
import runAction from "./action.js";
|
import runAction from "./action.js"
|
||||||
import { readVersionFromFile } from "./utils.js";
|
import { readVersionFromFile } from "./utils.js"
|
||||||
|
|
||||||
if (!process.env.RUNNER_TEMP) {
|
if (!process.env.RUNNER_TEMP) {
|
||||||
process.env.RUNNER_TEMP = tmpdir();
|
process.env.RUNNER_TEMP = tmpdir()
|
||||||
}
|
}
|
||||||
|
|
||||||
runAction({
|
runAction({
|
||||||
@ -18,14 +18,14 @@ runAction({
|
|||||||
noCache: getBooleanInput("no-cache") || false,
|
noCache: getBooleanInput("no-cache") || false,
|
||||||
})
|
})
|
||||||
.then(({ version, revision, bunPath, url, cacheHit }) => {
|
.then(({ version, revision, bunPath, url, cacheHit }) => {
|
||||||
setOutput("bun-version", version);
|
setOutput("bun-version", version)
|
||||||
setOutput("bun-revision", revision);
|
setOutput("bun-revision", revision)
|
||||||
setOutput("bun-path", bunPath);
|
setOutput("bun-path", bunPath)
|
||||||
setOutput("bun-download-url", url);
|
setOutput("bun-download-url", url)
|
||||||
setOutput("cache-hit", cacheHit);
|
setOutput("cache-hit", cacheHit)
|
||||||
process.exit(0);
|
process.exit(0)
|
||||||
})
|
})
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
setFailed(error);
|
setFailed(error)
|
||||||
process.exit(1);
|
process.exit(1)
|
||||||
});
|
})
|
||||||
|
60
src/utils.ts
60
src/utils.ts
@ -1,30 +1,30 @@
|
|||||||
import { debug, warning } from "@actions/core";
|
import { debug, warning } from "@actions/core"
|
||||||
import { info } from "node:console";
|
import { info } from "node:console"
|
||||||
import { existsSync, readFileSync, renameSync } from "node:fs";
|
import { existsSync, readFileSync, renameSync } from "node:fs"
|
||||||
import { resolve, basename } from "node:path";
|
import { resolve, basename } from "node:path"
|
||||||
|
|
||||||
export function retry<T>(
|
export function retry<T>(
|
||||||
fn: () => Promise<T>,
|
fn: () => Promise<T>,
|
||||||
retries: number,
|
retries: number,
|
||||||
timeout = 10000
|
timeout = 10000,
|
||||||
): Promise<T> {
|
): Promise<T> {
|
||||||
return fn().catch((err) => {
|
return fn().catch((err) => {
|
||||||
if (retries <= 0) {
|
if (retries <= 0) {
|
||||||
throw err;
|
throw err
|
||||||
}
|
}
|
||||||
return new Promise((resolve) => setTimeout(resolve, timeout)).then(() =>
|
return new Promise((resolve) => setTimeout(resolve, timeout)).then(() =>
|
||||||
retry(fn, retries - 1, timeout)
|
retry(fn, retries - 1, timeout),
|
||||||
);
|
)
|
||||||
});
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
export function addExtension(path: string, ext: string): string {
|
export function addExtension(path: string, ext: string): string {
|
||||||
if (!path.endsWith(ext)) {
|
if (!path.endsWith(ext)) {
|
||||||
renameSync(path, path + ext);
|
renameSync(path, path + ext)
|
||||||
return path + ext;
|
return path + ext
|
||||||
}
|
}
|
||||||
|
|
||||||
return path;
|
return path
|
||||||
}
|
}
|
||||||
|
|
||||||
const FILE_VERSION_READERS = {
|
const FILE_VERSION_READERS = {
|
||||||
@ -34,45 +34,45 @@ const FILE_VERSION_READERS = {
|
|||||||
content.match(/^bun\s*(?<version>.*?)$/m)?.groups?.version,
|
content.match(/^bun\s*(?<version>.*?)$/m)?.groups?.version,
|
||||||
".bumrc": (content: string) => content, // https://github.com/owenizedd/bum
|
".bumrc": (content: string) => content, // https://github.com/owenizedd/bum
|
||||||
".bun-version": (content: string) => content,
|
".bun-version": (content: string) => content,
|
||||||
};
|
}
|
||||||
|
|
||||||
export function readVersionFromFile(file: string): string | undefined {
|
export function readVersionFromFile(file: string): string | undefined {
|
||||||
const cwd = process.env.GITHUB_WORKSPACE;
|
const cwd = process.env.GITHUB_WORKSPACE
|
||||||
if (!cwd) {
|
if (!cwd) {
|
||||||
return;
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!file) {
|
if (!file) {
|
||||||
return;
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
debug(`Reading version from ${file}`);
|
debug(`Reading version from ${file}`)
|
||||||
|
|
||||||
const path = resolve(cwd, file);
|
const path = resolve(cwd, file)
|
||||||
const base = basename(file);
|
const base = basename(file)
|
||||||
|
|
||||||
if (!existsSync(path)) {
|
if (!existsSync(path)) {
|
||||||
warning(`File ${path} not found`);
|
warning(`File ${path} not found`)
|
||||||
return;
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
const reader = FILE_VERSION_READERS[base] ?? (() => undefined);
|
const reader = FILE_VERSION_READERS[base] ?? (() => undefined)
|
||||||
|
|
||||||
let output: string | undefined;
|
let output: string | undefined
|
||||||
try {
|
try {
|
||||||
output = reader(readFileSync(path, "utf8"))?.trim();
|
output = reader(readFileSync(path, "utf8"))?.trim()
|
||||||
|
|
||||||
if (!output) {
|
if (!output) {
|
||||||
warning(`Failed to read version from ${file}`);
|
warning(`Failed to read version from ${file}`)
|
||||||
return;
|
return
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
const { message } = error as Error;
|
const { message } = error as Error
|
||||||
warning(`Failed to read ${file}: ${message}`);
|
warning(`Failed to read ${file}: ${message}`)
|
||||||
} finally {
|
} finally {
|
||||||
if (output) {
|
if (output) {
|
||||||
info(`Obtained version ${output} from ${file}`);
|
info(`Obtained version ${output} from ${file}`)
|
||||||
return output;
|
return output
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user