0
0
Fork 0
mirror of https://github.com/denoland/rusty_v8.git synced 2025-01-13 17:40:23 -05:00

refactor: use Deno.Command instead of Deno.run (#1225)

This commit is contained in:
Leo Kettmeir 2023-05-03 23:05:07 +02:00 committed by GitHub
parent 5b1417799e
commit bf9f7cbcdc
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -21,25 +21,25 @@ function extractVersion() {
return `${major}.${minor}.${build}.${patch}`; return `${major}.${minor}.${build}.${patch}`;
} }
await run(["git", "checkout", "origin/main"]); await run("git", ["checkout", "origin/main"]);
await run(["git", "submodule", "update", "--init", "--recursive", "v8"]); await run("git", ["submodule", "update", "--init", "--recursive", "v8"]);
const currentVersion = extractVersion(); const currentVersion = extractVersion();
console.log(`Starting auto update. Currently on ${currentVersion}`); console.log(`Starting auto update. Currently on ${currentVersion}`);
async function run(cmd: string[], cwd?: string) { async function run(cmd: string, args: string[], cwd?: string) {
console.log("$", ...cmd); console.log("$", cmd, ...args);
const proc = Deno.run({ cmd, cwd }); const proc = new Deno.Command(cmd, { args, cwd });
const status = await proc.status(); const status = await proc.output();
if (!status.success) { if (!status.success) {
console.error(`Failed to run ${cmd.join(" ")}`); console.error(`Failed to run ${cmd} ${args.join(" ")}`);
Deno.exit(1); Deno.exit(1);
} }
} }
// Update v8 submodule // Update v8 submodule
await run(["git", "fetch", `origin`, V8_TRACKING_BRANCH], "./v8"); await run("git", ["fetch", `origin`, V8_TRACKING_BRANCH], "./v8");
await run(["git", "checkout", `origin/${V8_TRACKING_BRANCH}`], "./v8"); await run("git", ["checkout", `origin/${V8_TRACKING_BRANCH}`], "./v8");
const newVersion = extractVersion(); const newVersion = extractVersion();
if (currentVersion == newVersion) { if (currentVersion == newVersion) {
@ -58,30 +58,29 @@ readme = readme.replace(
Deno.writeTextFileSync("README.md", readme); Deno.writeTextFileSync("README.md", readme);
// Stage the changes // Stage the changes
await run(["git", "add", "v8", "README.md"]); await run("git", ["add", "v8", "README.md"]);
// Commit the changes // Commit the changes
await run(["git", "commit", "-m", `Rolling to V8 ${newVersion}`]); await run("git", ["commit", "-m", `Rolling to V8 ${newVersion}`]);
// Push to the `denoland/rusty_v8#autoroll` // Push to the `denoland/rusty_v8#autoroll`
await run(["git", "push", "origin", `+HEAD:refs/heads/${AUTOROLL_BRANCH}`]); await run("git", ["push", "origin", `+HEAD:refs/heads/${AUTOROLL_BRANCH}`]);
// Fetch the remote branch so `gh` cli can find it // Fetch the remote branch so `gh` cli can find it
await run(["git", "fetch", "origin", AUTOROLL_BRANCH]); await run("git", ["fetch", "origin", AUTOROLL_BRANCH]);
const proc = Deno.run({ const proc = new Deno.Command("gh", {
cmd: ["gh", "pr", "view", AUTOROLL_BRANCH, "--json", "state"], args: ["pr", "view", AUTOROLL_BRANCH, "--json", "state"],
stdout: "piped", stdout: "piped",
}); });
const status = await proc.status(); const output = await proc.output();
const isPrOpen = status.success const isPrOpen = output.success
? JSON.parse(new TextDecoder().decode(await proc.output())).state === "OPEN" ? JSON.parse(new TextDecoder().decode(output.stdout)).state === "OPEN"
: false; : false;
if (isPrOpen) { if (isPrOpen) {
console.log("Already open PR. Editing existing PR."); console.log("Already open PR. Editing existing PR.");
await run([ await run("gh", [
"gh",
"pr", "pr",
"edit", "edit",
AUTOROLL_BRANCH, AUTOROLL_BRANCH,
@ -90,8 +89,7 @@ if (isPrOpen) {
]); ]);
} else { } else {
console.log("No PR open. Creating a new PR."); console.log("No PR open. Creating a new PR.");
await run([ await run("gh", [
"gh",
"pr", "pr",
"create", "create",
"--title", "--title",