mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-18 10:07:28 +00:00
cli: on push, indicate which branches we're going to force-push
This commit is contained in:
parent
2d2ed53a34
commit
d1565fb6eb
2 changed files with 32 additions and 21 deletions
|
@ -4339,6 +4339,7 @@ fn cmd_git_push(
|
|||
|
||||
let mut ref_updates = vec![];
|
||||
let mut new_heads = vec![];
|
||||
let mut force_pushed_branches = hashset! {};
|
||||
for (branch_name, update) in &branch_updates {
|
||||
let qualified_name = format!("refs/heads/{}", branch_name);
|
||||
if let Some(new_target) = &update.new_target {
|
||||
|
@ -4347,6 +4348,9 @@ fn cmd_git_push(
|
|||
None => false,
|
||||
Some(old_target) => !repo.index().is_ancestor(old_target, new_target),
|
||||
};
|
||||
if force {
|
||||
force_pushed_branches.insert(branch_name.to_string());
|
||||
}
|
||||
ref_updates.push(GitRefUpdate {
|
||||
qualified_name,
|
||||
force,
|
||||
|
@ -4401,12 +4405,21 @@ fn cmd_git_push(
|
|||
for (branch_name, update) in &branch_updates {
|
||||
match (&update.old_target, &update.new_target) {
|
||||
(Some(old_target), Some(new_target)) => {
|
||||
writeln!(
|
||||
ui,
|
||||
" Move branch {branch_name} from {} to {}",
|
||||
short_commit_hash(old_target),
|
||||
short_commit_hash(new_target)
|
||||
)?;
|
||||
if force_pushed_branches.contains(branch_name) {
|
||||
writeln!(
|
||||
ui,
|
||||
" Force branch {branch_name} from {} to {}",
|
||||
short_commit_hash(old_target),
|
||||
short_commit_hash(new_target)
|
||||
)?;
|
||||
} else {
|
||||
writeln!(
|
||||
ui,
|
||||
" Move branch {branch_name} from {} to {}",
|
||||
short_commit_hash(old_target),
|
||||
short_commit_hash(new_target)
|
||||
)?;
|
||||
}
|
||||
}
|
||||
(Some(old_target), None) => {
|
||||
writeln!(
|
||||
|
|
|
@ -79,10 +79,8 @@ fn test_git_push_current_branch() {
|
|||
&workspace_root,
|
||||
&["describe", "branch1", "-m", "modified branch1 commit"],
|
||||
);
|
||||
test_env.jj_cmd_success(
|
||||
&workspace_root,
|
||||
&["branch", "set", "--allow-backwards", "branch2"],
|
||||
);
|
||||
test_env.jj_cmd_success(&workspace_root, &["co", "branch2"]);
|
||||
test_env.jj_cmd_success(&workspace_root, &["branch", "set", "branch2"]);
|
||||
test_env.jj_cmd_success(&workspace_root, &["branch", "create", "my-branch"]);
|
||||
test_env.jj_cmd_success(&workspace_root, &["describe", "-m", "foo"]);
|
||||
// Check the setup
|
||||
|
@ -90,30 +88,30 @@ fn test_git_push_current_branch() {
|
|||
insta::assert_snapshot!(stdout, @r###"
|
||||
branch1: 5d0d85ed3da7 modified branch1 commit
|
||||
@origin (ahead by 1 commits, behind by 1 commits): a3ccc578ea7b description 1
|
||||
branch2: 7840c9885676 foo
|
||||
@origin (ahead by 1 commits, behind by 1 commits): 7fd4b07286b3 description 2
|
||||
my-branch: 7840c9885676 foo
|
||||
branch2: 60db6d808983 foo
|
||||
@origin (behind by 1 commits): 7fd4b07286b3 description 2
|
||||
my-branch: 60db6d808983 foo
|
||||
"###);
|
||||
// First dry-run. `branch1` should not get pushed.
|
||||
let stdout = test_env.jj_cmd_success(&workspace_root, &["git", "push", "--dry-run"]);
|
||||
insta::assert_snapshot!(stdout, @r###"
|
||||
Branch changes to push to origin:
|
||||
Move branch branch2 from 7fd4b07286b3 to 7840c9885676
|
||||
Add branch my-branch to 7840c9885676
|
||||
Move branch branch2 from 7fd4b07286b3 to 60db6d808983
|
||||
Add branch my-branch to 60db6d808983
|
||||
Dry-run requested, not pushing.
|
||||
"###);
|
||||
let stdout = test_env.jj_cmd_success(&workspace_root, &["git", "push"]);
|
||||
insta::assert_snapshot!(stdout, @r###"
|
||||
Branch changes to push to origin:
|
||||
Move branch branch2 from 7fd4b07286b3 to 7840c9885676
|
||||
Add branch my-branch to 7840c9885676
|
||||
Move branch branch2 from 7fd4b07286b3 to 60db6d808983
|
||||
Add branch my-branch to 60db6d808983
|
||||
"###);
|
||||
let stdout = test_env.jj_cmd_success(&workspace_root, &["branch", "list"]);
|
||||
insta::assert_snapshot!(stdout, @r###"
|
||||
branch1: 5d0d85ed3da7 modified branch1 commit
|
||||
@origin (ahead by 1 commits, behind by 1 commits): a3ccc578ea7b description 1
|
||||
branch2: 7840c9885676 foo
|
||||
my-branch: 7840c9885676 foo
|
||||
branch2: 60db6d808983 foo
|
||||
my-branch: 60db6d808983 foo
|
||||
"###);
|
||||
}
|
||||
|
||||
|
@ -151,7 +149,7 @@ fn test_git_push_all() {
|
|||
insta::assert_snapshot!(stdout, @r###"
|
||||
Branch changes to push to origin:
|
||||
Delete branch branch1 from a3ccc578ea7b
|
||||
Move branch branch2 from 7fd4b07286b3 to 7840c9885676
|
||||
Force branch branch2 from 7fd4b07286b3 to 7840c9885676
|
||||
Add branch my-branch to 7840c9885676
|
||||
Dry-run requested, not pushing.
|
||||
"###);
|
||||
|
@ -159,7 +157,7 @@ fn test_git_push_all() {
|
|||
insta::assert_snapshot!(stdout, @r###"
|
||||
Branch changes to push to origin:
|
||||
Delete branch branch1 from a3ccc578ea7b
|
||||
Move branch branch2 from 7fd4b07286b3 to 7840c9885676
|
||||
Force branch branch2 from 7fd4b07286b3 to 7840c9885676
|
||||
Add branch my-branch to 7840c9885676
|
||||
"###);
|
||||
let stdout = test_env.jj_cmd_success(&workspace_root, &["branch", "list"]);
|
||||
|
|
Loading…
Reference in a new issue