Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

3528 Change branch terminal-run commands into normal commands w/ proper error handling #3597

Open
wants to merge 12 commits into
base: main
Choose a base branch
from

Conversation

sergiolms
Copy link
Contributor

@sergiolms sergiolms commented Sep 20, 2024

Description

Part 2 including changes to branch delete.
Resolves #3528

Example of error:
Captura de pantalla 2024-09-30 a las 16 10 45

Checklist

  • I have followed the guidelines in the Contributing document
  • My changes follow the coding style of this project
  • My changes build without any errors or warnings
  • My changes have been formatted and linted
  • My changes include any required corresponding changes to the documentation (including CHANGELOG.md and README.md)
  • My changes have been rebased and squashed to the minimal number (typically 1) of relevant commits
  • My changes have a descriptive commit message with a short title, including a Fixes $XXX - or Closes #XXX - prefix to auto-close the issue that your PR addresses

@sergiolms sergiolms self-assigned this Sep 20, 2024
@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch 2 times, most recently from d2ada6c to 275d1f4 Compare September 26, 2024 14:56
@eamodio
Copy link
Member

eamodio commented Sep 26, 2024

@sergiolms Please apply similar changes from #3596 to this PR

@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch 7 times, most recently from d3f465e to fb0d9ac Compare September 27, 2024 13:54
@sergiolms sergiolms requested a review from eamodio September 30, 2024 07:34
@sergiolms sergiolms marked this pull request as ready for review September 30, 2024 07:34
@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from fb0d9ac to 31db995 Compare September 30, 2024 07:34
Copy link
Contributor

@axosoft-ramint axosoft-ramint left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since I don't have too much context going into this, could you help me test it by:

  1. Describing how to initiate the commands being changed (all the different ways we can get into the delete branch flow that you are aware of)
  2. Describing what happens before this PR and what happens after the PR changes (essentially, what behavior should I expect to be different when using this PR)
  3. Describing what areas may have regressions as a result of the PR changes that I should spot-check, if any

I did a quick code-scan and it looks good, just had one nitpick below:

src/env/node/git/localGitProvider.ts Show resolved Hide resolved
} catch (ex) {
Logger.error(ex);
// TODO likely need some better error handling here
return showGenericErrorMessage(
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should be handling resumable/retriable errors. For example, if not merged, we should offer to retry with force.

Logger.error(ex);
// TODO likely need some better error handling here
return showGenericErrorMessage(
new BranchError(ex.reason, ex, state.references.map(r => r.name).join(', ')).message,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why are we creating a BranchError here? Isn't the one being thrown a BranchError?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Indeed, I don't really like this solution either. When we return the BranchError at git level we don't know the branch names, we just have an array of args. We could either guess the branch names, or change the number of args of git.branch to be more specific so we can have easier access. In this case we're reusing the BranchError but adding the branch name for context.
Another option is to turn BranchError into a Builder pattern that we can always call like showGenericErrorMessage(ex.WithBranch(branchName)) or something along those lines to provide context on top layers.

@@ -627,7 +637,7 @@ export class BranchGitCommand extends QuickCommand {
} catch (ex) {
Logger.error(ex);
// TODO likely need some better error handling here
return showGenericErrorMessage('Unable to rename branch');
return showGenericErrorMessage(new BranchError(ex.reason, ex, state.name).message);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same here

src/env/node/git/localGitProvider.ts Show resolved Hide resolved
@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from 66762d4 to 58551c8 Compare October 3, 2024 13:43
@sergiolms sergiolms requested a review from eamodio October 3, 2024 14:20
@sergiolms
Copy link
Contributor Author

Now when an error such as unmerged branch happens, we display a prompt to retry it:

Captura de pantalla 2024-10-03 a las 12 59 07

We can turn this prompt into something reusable like a confirmation prompt we can parametrize as we find more cases

@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from 4794ca0 to d093bc3 Compare October 4, 2024 11:02
@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from d093bc3 to e9baa26 Compare October 15, 2024 14:20
@axosoft-ramint axosoft-ramint self-requested a review October 15, 2024 14:58
Copy link
Contributor

@axosoft-ramint axosoft-ramint left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Several build errors here, as well as conflicts with main. Will test once it's rebased and the errors are resolved

src/env/node/git/git.ts Outdated Show resolved Hide resolved
src/env/node/git/localGitProvider.ts Outdated Show resolved Hide resolved
src/env/node/git/localGitProvider.ts Outdated Show resolved Hide resolved
src/env/node/git/localGitProvider.ts Outdated Show resolved Hide resolved
src/env/node/git/localGitProvider.ts Outdated Show resolved Hide resolved
src/env/node/git/localGitProvider.ts Outdated Show resolved Hide resolved
src/env/node/git/localGitProvider.ts Outdated Show resolved Hide resolved
@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch 2 times, most recently from 128b31b to 5ed1cf7 Compare October 23, 2024 10:43
@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from 5ed1cf7 to bed464f Compare October 23, 2024 12:51
Copy link
Contributor

@axosoft-ramint axosoft-ramint left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure what commands are affected, and the only one I noticed was branch delete, so I tried it with a few cases and looks like it works and doesn't open my terminal.

LGTM - let me know if there are other cases I should test

@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from bed464f to 4f145da Compare November 7, 2024 12:37
Copy link
Contributor

@axosoft-ramint axosoft-ramint left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When attempting to delete a remote branch that no longer exists, I do not get the right error message in the notification area. I get a push error that doesn't describe the issue well:

image

It is true that the operation happening under the hood is git push -d origin cool-branch but I expected an error relating to "unable to delete branch because the remote branch was already deleted" or however you have the messaging set up.

The error I get in the logs is more descriptive/accurate:

image

@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from 4f145da to ead29af Compare November 8, 2024 16:29
@sergiolms
Copy link
Contributor Author

When attempting to delete a remote branch that no longer exists, I do not get the right error message in the notification area. I get a push error that doesn't describe the issue well:
[...]
It is true that the operation happening under the hood is git push -d origin cool-branch but I expected an error relating to "unable to delete branch because the remote branch was already deleted" or however you have the messaging set up.

True. Since this action is running under git push it wasn't covered by the git branch errors. I added an additional case to git push to handle that case:

Captura de pantalla 2024-11-11 a las 15 22 58

@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from ead29af to 965edeb Compare November 11, 2024 14:25
@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from 965edeb to ab4f84c Compare November 27, 2024 14:54
@sergiolms sergiolms force-pushed the feature/#3528-part2_change_branch_into_normal_cmd branch from ab4f84c to f502b49 Compare December 12, 2024 12:12
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Change branch terminal-run commands into normal commands w/ proper error handling
3 participants