Skip to content

Commit

Permalink
rewrite: fix check for newly-empty commit in optimized path
Browse files Browse the repository at this point in the history
'old_base_tree_id == None' means the rebased tree is unchanged, so the commit
shouldn't be considered newly-empty.
  • Loading branch information
yuja committed Nov 26, 2023
1 parent 2f93de9 commit b7543f8
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 7 deletions.
2 changes: 1 addition & 1 deletion lib/src/rewrite.rs
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,7 @@ pub fn rebase_commit_with_options(
EmptyBehaviour::Keep => false,
EmptyBehaviour::AbandonNewlyEmpty => {
*parent.tree_id() == new_tree_id
&& old_base_tree_id != Some(old_commit.tree_id().clone())
&& old_base_tree_id.map_or(false, |id| id != *old_commit.tree_id())
}
EmptyBehaviour::AbandonAllEmpty => *parent.tree_id() == new_tree_id,
};
Expand Down
22 changes: 16 additions & 6 deletions lib/tests/test_rewrite.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1490,7 +1490,7 @@ fn assert_rebase_skipped(
rebased: Option<RebasedDescendant>,
expected_old_commit: &Commit,
expected_new_commit: &Commit,
) {
) -> Commit {
if let Some(RebasedDescendant {
old_commit,
new_commit,
Expand All @@ -1500,6 +1500,7 @@ fn assert_rebase_skipped(
assert_eq!(new_commit, *expected_new_commit);
// Since it was abandoned, the change ID should be different.
assert_ne!(old_commit.change_id(), new_commit.change_id());
new_commit
} else {
panic!("expected rebased commit: {rebased:?}");
}
Expand All @@ -1517,11 +1518,13 @@ fn test_empty_commit_option(empty: EmptyBehaviour) {
// actual changes.
//
// BD (commit B joined with commit D)
// | H (empty, no parent tree changes)
// | |
// | G
// | |
// | F (clean merge)
// | /|\
// | C D E (empty)
// | C D E (empty, but parent tree changes)
// | \|/
// | B
// A__/
Expand Down Expand Up @@ -1567,6 +1570,7 @@ fn test_empty_commit_option(empty: EmptyBehaviour) {
let commit_e = create_commit(&[&commit_b], &tree_b);
let commit_f = create_commit(&[&commit_c, &commit_d, &commit_e], &tree_f);
let commit_g = create_commit(&[&commit_f], &tree_g);
let commit_h = create_commit(&[&commit_g], &tree_g);
let commit_bd = create_commit(&[&commit_a], &tree_d);

let mut rebaser = DescendantRebaser::new(
Expand Down Expand Up @@ -1595,7 +1599,9 @@ fn test_empty_commit_option(empty: EmptyBehaviour) {
&commit_f,
&[&new_commit_c, &new_commit_d, &new_commit_e],
);
assert_rebased(rebaser.rebase_next().unwrap(), &commit_g, &[&new_commit_f])
let new_commit_g =
assert_rebased(rebaser.rebase_next().unwrap(), &commit_g, &[&new_commit_f]);
assert_rebased(rebaser.rebase_next().unwrap(), &commit_h, &[&new_commit_g])
}
EmptyBehaviour::AbandonAllEmpty => {
// The commit C isn't empty.
Expand All @@ -1606,7 +1612,9 @@ fn test_empty_commit_option(empty: EmptyBehaviour) {
assert_rebase_skipped(rebaser.rebase_next().unwrap(), &commit_d, &commit_bd);
assert_rebase_skipped(rebaser.rebase_next().unwrap(), &commit_e, &commit_bd);
assert_rebase_skipped(rebaser.rebase_next().unwrap(), &commit_f, &new_commit_c);
assert_rebased(rebaser.rebase_next().unwrap(), &commit_g, &[&new_commit_c])
let new_commit_g =
assert_rebased(rebaser.rebase_next().unwrap(), &commit_g, &[&new_commit_c]);
assert_rebase_skipped(rebaser.rebase_next().unwrap(), &commit_h, &new_commit_g)
}
EmptyBehaviour::AbandonNewlyEmpty => {
// The commit C isn't empty.
Expand All @@ -1625,12 +1633,14 @@ fn test_empty_commit_option(empty: EmptyBehaviour) {
&commit_f,
&[&new_commit_c, &new_commit_e],
);
assert_rebased(rebaser.rebase_next().unwrap(), &commit_g, &[&new_commit_f])
let new_commit_g =
assert_rebased(rebaser.rebase_next().unwrap(), &commit_g, &[&new_commit_f]);
assert_rebased(rebaser.rebase_next().unwrap(), &commit_h, &[&new_commit_g])
}
};

assert!(rebaser.rebase_next().unwrap().is_none());
assert_eq!(rebaser.rebased().len(), 5);
assert_eq!(rebaser.rebased().len(), 6);

assert_eq!(
*tx.mut_repo().view().heads(),
Expand Down

0 comments on commit b7543f8

Please sign in to comment.