Merge pull request #12 from yusefren/fix/when-open-ai-error

Fix OpenAI API error handling when generating commit message
This commit is contained in:
Hassan El Mghari
2023-02-14 12:09:25 -05:00
committed by GitHub

View File

@@ -55,30 +55,36 @@ export async function main() {
console.log( console.log(
chalk.white("▲ ") + chalk.gray("Generating your AI commit message...\n") chalk.white("▲ ") + chalk.gray("Generating your AI commit message...\n")
); );
const aiCommitMessage = await generateCommitMessage(prompt);
console.log( try {
chalk.white("▲ ") + chalk.bold("Commit message: ") + aiCommitMessage + "\n" const aiCommitMessage = await generateCommitMessage(prompt);
); console.log(
chalk.white("▲ ") + chalk.bold("Commit message: ") + aiCommitMessage +
"\n",
);
const confirmationMessage = await inquirer.prompt([ const confirmationMessage = await inquirer.prompt([
{ {
name: "useCommitMessage", name: "useCommitMessage",
message: "Would you like to use this commit message? (Y / n)", message: "Would you like to use this commit message? (Y / n)",
choices: ["Y", "y", "n"], choices: ["Y", "y", "n"],
default: "y", default: "y",
}, },
]); ]);
if (confirmationMessage.useCommitMessage === "n") { if (confirmationMessage.useCommitMessage === "n") {
console.log(chalk.white("▲ ") + "Commit message has not been commited."); console.log(chalk.white("▲ ") + "Commit message has not been commited.");
process.exit(1);
}
execSync(`git commit -m "${aiCommitMessage}"`, {
stdio: "inherit",
encoding: "utf8",
});
} catch (e) {
console.error(chalk.white("▲ ") + chalk.red(e.message));
process.exit(1); process.exit(1);
} }
execSync(`git commit -m "${aiCommitMessage}"`, {
stdio: "inherit",
encoding: "utf8",
});
} }
async function generateCommitMessage(prompt: string) { async function generateCommitMessage(prompt: string) {
@@ -101,6 +107,12 @@ async function generateCommitMessage(prompt: string) {
method: "POST", method: "POST",
body: JSON.stringify(payload), body: JSON.stringify(payload),
}); });
if (response.status !== 200) {
const errorJson: any = await response.json();
throw new Error(
`OpenAI API failed while processing the request '${errorJson?.error?.message}'`,
);
}
const json: any = await response.json(); const json: any = await response.json();
const aiCommit = json.choices[0].text; const aiCommit = json.choices[0].text;