From 24d7b05c0d4e1eb07b2c6b11dd19c0aba4f9a603 Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Fri, 4 Oct 2024 16:55:00 -0700 Subject: [PATCH] refactor and optimize git operations for commit messages and failure analysis (#7412) --- .gitignore.genai | 3 +++ genaisrc/gai.genai.mts | 17 +++++++++++++++++ genaisrc/gcm.genai.mts | 30 +++++++++--------------------- genaisrc/genaiscript.d.ts | Bin 73251 -> 78662 bytes 4 files changed, 29 insertions(+), 21 deletions(-) create mode 100644 .gitignore.genai create mode 100644 genaisrc/gai.genai.mts diff --git a/.gitignore.genai b/.gitignore.genai new file mode 100644 index 000000000..254ca5bfe --- /dev/null +++ b/.gitignore.genai @@ -0,0 +1,3 @@ +**/genaiscript.d.ts +**/package-lock.json +**/yarn.lock diff --git a/genaisrc/gai.genai.mts b/genaisrc/gai.genai.mts new file mode 100644 index 000000000..9de3cf11a --- /dev/null +++ b/genaisrc/gai.genai.mts @@ -0,0 +1,17 @@ +script({ + tools: ["agent_fs", "agent_git", "agent_github"], +}) + +const { + workflow = "latest failed", + failure_run_id = "latest", + branch = await git.defaultBranch(), +} = env.vars + +$`Investigate the status of the ${workflow} workflow and identify the root cause of the failure of run ${failure_run_id} in branch ${branch}. + +- Correlate the failure with the relevant commits, pull requests or issues. +- Compare the source code between the failed run commit and the last successful run commit before that run. + +In your report, include html links to the relevant runs, commits, pull requests or issues. +` diff --git a/genaisrc/gcm.genai.mts b/genaisrc/gcm.genai.mts index e1ebd1197..d1f97174f 100644 --- a/genaisrc/gcm.genai.mts +++ b/genaisrc/gcm.genai.mts @@ -6,28 +6,16 @@ script({ description: "Generate a commit message for all staged changes", }) -// TODO: update this diff command to match your workspace -const diffCmd = "git diff --cached -- . :!**/genaiscript.d.ts" - // Check for staged changes and stage all changes if none are staged -let diff = await host.exec(diffCmd) -if (!diff.stdout) { - /** - * Ask user to stage all changes if none are staged - */ - const stage = await host.confirm("No staged changes. Stage all changes?", { - default: true, - }) - if (stage) { - // Stage all changes and recompute diff - await host.exec("git add .") - diff = await host.exec(diffCmd) - } - if (!diff.stdout) cancel("no staged changes") -} +const diff = await git.diff({ + staged: true, + excludedPaths: "**/genaiscript.d.ts", + askStageOnEmpty: true, +}) +if (!diff) cancel("no staged changes") // show diff in the console -console.log(diff.stdout) +console.log(diff) let choice let message @@ -79,9 +67,9 @@ Please generate a concise, one-line commit message for these changes. } // Regenerate message if (choice === "commit" && message) { - console.log((await host.exec("git", ["commit", "-m", message])).stdout) + console.log(await git.exec(["commit", "-m", message])) if (await host.confirm("Push changes?", { default: true })) - console.log((await host.exec("git push")).stdout) + console.log(await git.exec("push")) break } } while (choice !== "commit") diff --git a/genaisrc/genaiscript.d.ts b/genaisrc/genaiscript.d.ts index c0a6426d2c5fa168f0c708d8f185820733d3431f..e11a3edd76e417e0aa88b2dc42a15e63ac4c0898 100644 GIT binary patch delta 4013 zcmbVPU2I%O71k!}^>*DP#?7wn#7-s-Asfd@ji~K(o7(v!p~Z3R)P;8 zvLU)qM{UDtk0DYq=HK;P**8rVTuu~X_tZn=Z*-q~ScTn$#zq+GlIHxS5E4)CSL(Xg z27Cs~i~RE{AO4^2&($E*e8I)GR?2I>>p~&w$uy}<%39^ZO^cz4nV0u)u~q1_elrhy zegjCjpr*j~sAIGIQ%)goIz<&^v!jkiMbZ*dn+?mi$J}hN;8!9?M>B~}zQYAd z(aAHFwa#mfWdVkrZx3yn{R;d=V4DaQA92YtB`bFc$--VKPnP+3a=Hgh z$`#cVd@hONdDpkOoxH?ny1P#`+6c^SgSu9|GEFK*OrkaF(WLRnsu%n+`RXvg^7GzX z&&Dqz$3ULrm<;K}pf=GFwUJjMh-oe@dy)gt=>76HSS$+DnH*X}RL>#ixzsL>!BJ%m zeG>^$^}?l~_?h+I_>;%a&hlLgdy+1}y8QV1Wz*#$&bk%qMrIotvyDVK;v zTx{~ghX%NL`nB~}2V!YHwXct7&rH@o0{_gPH+K=+w`TalYuUj5;&9hq5vtFCR74q0 zmauoyvC1Y9SUxVrsp|S%Uu-n^(L72u(0Jj+gM8wN-NB!}GMLyFVH5%$?85&{@zkxp z3l|?Y!MghM(L1%Bfnx! zN<^4;tDBVNe5t1dtbqj8h-L_<$0cQlQO|KJvPE3t`L3sv!6E)Wxnuci-GMOwF>P4o*eRA_)q7zczVLgvq0-@;$N zzVGB|DyD~(iAD{osj4>FqDI_N$D$LJ2;wm$n3~^tDZ}UeEyo1ciGs7n6f)p0l0zew z1KmN1eyD&M8Iel_z)f`dXQbpef44U-4ERDV!w>G-#((obeCjw;(<4Yr3>v&rFlQn+ zHFA)etb}S&m`P%ly~<(UGci1d+0tXe{G9!HAq0#Hz*hv@3R^Kc@KXk|Wi#uq48;0} zrdu>*RWp5^=<^MW*fhsCcJSIOD9U?OHhzP>R09jgGE}|kR{oRWbZ!)V!jw|HcVheE zhvy_9thYlwpAvB9Mrl*-1C87}OHcY#>G$OnByGQW?{ucL$Wlwiw&=-MMU4g zi=jntAsqXHUpOC0Qq@$7+VCP7z^~UiQ~Aq(qcp^1lX&7DhYWy+7j{j+nX|c zXwBRGA*u6ktWEH(YZ?B>wGa3k$9qnk3W;916pIUm|4X3#;B_LNRuX%NdJ2FQCdMNI zQ@e|VgYS8{pLbQC>3v*~iyB<$C~CtyGZfUSbDQ}GwFjqQ^L?b1j&*0nHXW>shfZv& zk2-}}=*0T4$rJqc)uHV`&uzU81bs)()=t5IK&~Y>EEwj+_N8!uMGEG{mFs##+SG{Znc%;EuMZxH;J42`8spDb(={<K4P%I2rx0?3+krO}oG2;P_Z(=69J7k8A=s`T5xaO+xrl;3klWEbDA4iJ zN=*@e|LFE${Oa5$@mAm0Ax8eKYx^%Fv2eraJPrTUc^iUiQErG0qMC=(=hfk?FwVCI z$mgyN0rmeSljh@B`-5*^`*)l#8@(c;hkRQnu33T27oF2QXGy&NCXih8riTqDMcJl8 zV7n4rzw!EhvES{BO$Wzrf9In7d(-q7zq5IeU%s7qvuA7UNOJw}>DZPOY{;-93SwCQ SUphA4l@ld;Gna||qx=8t<}{oD delta 337 zcmX^1jAij2mJOY(lf~KAPkzj1ws{wO5aVPuPP@rZIkhLV^0-c3%gH&pi6>;UGVfg3 z$$$K~Hd|}=2ux1137cGNt+4r|?F+`u7wiq#HuJg(GHy0>Kg2ru6cg{{a^Izs53`6* zKI