Signed-off-by: Guillaume Pagès <[email protected]>
---
t/t7512-status-help.sh | 227 ++++++++++++++++++++++++++++++++++++++++++++++---
1 file changed, 213 insertions(+), 14 deletions(-)
diff --git a/t/t7512-status-help.sh b/t/t7512-status-help.sh
index 68ad2d7..242124f 100755
--- a/t/t7512-status-help.sh
+++ b/t/t7512-status-help.sh
@@ -134,9 +134,13 @@ test_expect_success 'prepare for rebase_i_conflicts' '
test_expect_success 'status during rebase -i when conflicts unresolved' '
test_when_finished "git rebase --abort" &&
ONTO=$(git rev-parse --short rebase_i_conflicts) &&
+ LAST_COMMIT=$(git rev-parse rebase_i_conflicts_second) &&
test_must_fail git rebase -i rebase_i_conflicts &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (1 command(s) done):
+ pick $LAST_COMMIT one_second
+No command remaining.
You are currently rebasing branch '\''rebase_i_conflicts_second'\'' on
'\''$ONTO'\''.
(fix conflicts and then run "git rebase --continue")
(use "git rebase --skip" to skip this patch)
@@ -159,10 +163,14 @@ test_expect_success 'status during rebase -i after
resolving conflicts' '
git reset --hard rebase_i_conflicts_second &&
test_when_finished "git rebase --abort" &&
ONTO=$(git rev-parse --short rebase_i_conflicts) &&
+ LAST_COMMIT=$(git rev-parse rebase_i_conflicts_second) &&
test_must_fail git rebase -i rebase_i_conflicts &&
git add main.txt &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (1 command(s) done):
+ pick $LAST_COMMIT one_second
+No command remaining.
You are currently rebasing branch '\''rebase_i_conflicts_second'\'' on
'\''$ONTO'\''.
(all conflicts fixed: run "git rebase --continue")
@@ -183,14 +191,20 @@ test_expect_success 'status when rebasing -i in edit
mode' '
git checkout -b rebase_i_edit &&
test_commit one_rebase_i main.txt one &&
test_commit two_rebase_i main.txt two &&
+ COMMIT2=$(git rev-parse rebase_i_edit) &&
test_commit three_rebase_i main.txt three &&
+ COMMIT3=$(git rev-parse rebase_i_edit) &&
FAKE_LINES="1 edit 2" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
ONTO=$(git rev-parse --short HEAD~2) &&
git rebase -i HEAD~2 &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ pick $COMMIT2 two_rebase_i
+ edit $COMMIT3 three_rebase_i
+No command remaining.
You are currently editing a commit while rebasing branch '\''rebase_i_edit'\''
on '\''$ONTO'\''.
(use "git commit --amend" to amend the current commit)
(use "git rebase --continue" once you are satisfied with your changes)
@@ -207,8 +221,11 @@ test_expect_success 'status when splitting a commit' '
git checkout -b split_commit &&
test_commit one_split main.txt one &&
test_commit two_split main.txt two &&
+ COMMIT2=$(git rev-parse split_commit) &&
test_commit three_split main.txt three &&
+ COMMIT3=$(git rev-parse split_commit) &&
test_commit four_split main.txt four &&
+ COMMIT4=$(git rev-parse split_commit) &&
FAKE_LINES="1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
@@ -216,7 +233,13 @@ test_expect_success 'status when splitting a commit' '
git rebase -i HEAD~3 &&
git reset HEAD^ &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ pick $COMMIT2 two_split
+ edit $COMMIT3 three_split
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_split
+ (use git rebase --edit-todo to view and edit)
You are currently splitting a commit while rebasing branch
'\''split_commit'\'' on '\''$ONTO'\''.
(Once your working directory is clean, run "git rebase --continue")
@@ -239,7 +262,9 @@ test_expect_success 'status after editing the last commit
with --amend during a
test_commit one_amend main.txt one &&
test_commit two_amend main.txt two &&
test_commit three_amend main.txt three &&
+ COMMIT3=$(git rev-parse amend_last) &&
test_commit four_amend main.txt four &&
+ COMMIT4=$(git rev-parse amend_last) &&
FAKE_LINES="1 2 edit 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
@@ -247,7 +272,12 @@ test_expect_success 'status after editing the last commit
with --amend during a
git rebase -i HEAD~3 &&
git commit --amend -m "foo" &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (3 command(s) done):
+ pick $COMMIT3 three_amend
+ edit $COMMIT4 four_amend
+ (see more at .git/rebase-merge/done)
+No command remaining.
You are currently editing a commit while rebasing branch '\''amend_last'\'' on
'\''$ONTO'\''.
(use "git commit --amend" to amend the current commit)
(use "git rebase --continue" once you are satisfied with your changes)
@@ -273,11 +303,20 @@ test_expect_success 'status: (continue first edit) second
edit' '
FAKE_LINES="edit 1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
ONTO=$(git rev-parse --short HEAD~3) &&
git rebase -i HEAD~3 &&
git rebase --continue &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently editing a commit while rebasing branch '\''several_edits'\''
on '\''$ONTO'\''.
(use "git commit --amend" to amend the current commit)
(use "git rebase --continue" once you are satisfied with your changes)
@@ -294,12 +333,21 @@ test_expect_success 'status: (continue first edit) second
edit and split' '
FAKE_LINES="edit 1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
ONTO=$(git rev-parse --short HEAD~3) &&
git rebase -i HEAD~3 &&
git rebase --continue &&
git reset HEAD^ &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently splitting a commit while rebasing branch
'\''several_edits'\'' on '\''$ONTO'\''.
(Once your working directory is clean, run "git rebase --continue")
@@ -321,12 +369,21 @@ test_expect_success 'status: (continue first edit) second
edit and amend' '
FAKE_LINES="edit 1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
ONTO=$(git rev-parse --short HEAD~3) &&
git rebase -i HEAD~3 &&
git rebase --continue &&
git commit --amend -m "foo" &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently editing a commit while rebasing branch '\''several_edits'\''
on '\''$ONTO'\''.
(use "git commit --amend" to amend the current commit)
(use "git rebase --continue" once you are satisfied with your changes)
@@ -343,12 +400,21 @@ test_expect_success 'status: (amend first edit) second
edit' '
FAKE_LINES="edit 1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
ONTO=$(git rev-parse --short HEAD~3) &&
git rebase -i HEAD~3 &&
git commit --amend -m "a" &&
git rebase --continue &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently editing a commit while rebasing branch '\''several_edits'\''
on '\''$ONTO'\''.
(use "git commit --amend" to amend the current commit)
(use "git rebase --continue" once you are satisfied with your changes)
@@ -366,12 +432,21 @@ test_expect_success 'status: (amend first edit) second
edit and split' '
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
ONTO=$(git rev-parse --short HEAD~3) &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
git rebase -i HEAD~3 &&
git commit --amend -m "b" &&
git rebase --continue &&
git reset HEAD^ &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently splitting a commit while rebasing branch
'\''several_edits'\'' on '\''$ONTO'\''.
(Once your working directory is clean, run "git rebase --continue")
@@ -393,13 +468,22 @@ test_expect_success 'status: (amend first edit) second
edit and amend' '
FAKE_LINES="edit 1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
ONTO=$(git rev-parse --short HEAD~3) &&
git rebase -i HEAD~3 &&
git commit --amend -m "c" &&
git rebase --continue &&
git commit --amend -m "d" &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently editing a commit while rebasing branch '\''several_edits'\''
on '\''$ONTO'\''.
(use "git commit --amend" to amend the current commit)
(use "git rebase --continue" once you are satisfied with your changes)
@@ -416,6 +500,9 @@ test_expect_success 'status: (split first edit) second
edit' '
FAKE_LINES="edit 1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
ONTO=$(git rev-parse --short HEAD~3) &&
git rebase -i HEAD~3 &&
git reset HEAD^ &&
@@ -423,7 +510,13 @@ test_expect_success 'status: (split first edit) second
edit' '
git commit -m "e" &&
git rebase --continue &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently editing a commit while rebasing branch '\''several_edits'\''
on '\''$ONTO'\''.
(use "git commit --amend" to amend the current commit)
(use "git rebase --continue" once you are satisfied with your changes)
@@ -440,6 +533,9 @@ test_expect_success 'status: (split first edit) second edit
and split' '
FAKE_LINES="edit 1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
ONTO=$(git rev-parse --short HEAD~3) &&
git rebase -i HEAD~3 &&
git reset HEAD^ &&
@@ -448,7 +544,13 @@ test_expect_success 'status: (split first edit) second
edit and split' '
git rebase --continue &&
git reset HEAD^ &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently splitting a commit while rebasing branch
'\''several_edits'\'' on '\''$ONTO'\''.
(Once your working directory is clean, run "git rebase --continue")
@@ -470,6 +572,9 @@ test_expect_success 'status: (split first edit) second edit
and amend' '
FAKE_LINES="edit 1 edit 2 3" &&
export FAKE_LINES &&
test_when_finished "git rebase --abort" &&
+ COMMIT2=$(git rev-parse several_edits^^) &&
+ COMMIT3=$(git rev-parse several_edits^) &&
+ COMMIT4=$(git rev-parse several_edits) &&
ONTO=$(git rev-parse --short HEAD~3) &&
git rebase -i HEAD~3 &&
git reset HEAD^ &&
@@ -478,7 +583,13 @@ test_expect_success 'status: (split first edit) second
edit and amend' '
git rebase --continue &&
git commit --amend -m "h" &&
cat >expected <<EOF &&
-rebase in progress; onto $ONTO
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ edit $COMMIT2 two_edits
+ edit $COMMIT3 three_edits
+Next command(s) to do (1 remaining command(s)):
+ pick $COMMIT4 four_edits
+ (use git rebase --edit-todo to view and edit)
You are currently editing a commit while rebasing branch '\''several_edits'\''
on '\''$ONTO'\''.
(use "git commit --amend" to amend the current commit)
(use "git rebase --continue" once you are satisfied with your changes)
@@ -745,4 +856,92 @@ EOF
test_i18ncmp expected actual
'
+test_expect_success 'prepare for different number of commits rebased' '
+ git reset --hard master &&
+ git checkout -b several_commits &&
+ test_commit one_commit main.txt one &&
+ test_commit two_commit main.txt two &&
+ test_commit three_commit main.txt three &&
+ test_commit four_commit main.txt four
+'
+
+
+test_expect_success 'status: one command done nothing remaining' '
+ FAKE_LINES=" exec_exit_15" &&
+ export FAKE_LINES &&
+ test_when_finished "git rebase --abort" &&
+ ONTO=$(git rev-parse --short HEAD~3) &&
+ (git rebase -i HEAD~3 || true)&&
+ cat >expected <<EOF &&
+interactive rebase in progress; onto $ONTO
+Last command(s) done (1 command(s) done):
+ exec exit 15
+No command remaining.
+You are currently editing a commit while rebasing branch
'\''several_commits'\'' on '\''$ONTO'\''.
+ (use "git commit --amend" to amend the current commit)
+ (use "git rebase --continue" once you are satisfied with your changes)
+
+nothing to commit (use -u to show untracked files)
+EOF
+ git status --untracked-files=no >actual &&
+ test_i18ncmp expected actual
+'
+
+test_expect_success 'status: two commands done, two remainings' '
+ FAKE_LINES="1 exec_exit_15 2 3" &&
+ export FAKE_LINES &&
+ test_when_finished "git rebase --abort" &&
+ ONTO=$(git rev-parse --short HEAD~3) &&
+ COMMIT4=$(git rev-parse HEAD) &&
+ COMMIT3=$(git rev-parse HEAD^) &&
+ COMMIT2=$(git rev-parse HEAD^^) &&
+ (git rebase -i HEAD~3 || true)&&
+ cat >expected <<EOF &&
+interactive rebase in progress; onto $ONTO
+Last command(s) done (2 command(s) done):
+ pick $COMMIT2 two_commit
+ exec exit 15
+Next command(s) to do (2 remaining command(s)):
+ pick $COMMIT3 three_commit
+ pick $COMMIT4 four_commit
+ (use git rebase --edit-todo to view and edit)
+You are currently editing a commit while rebasing branch
'\''several_commits'\'' on '\''$ONTO'\''.
+ (use "git commit --amend" to amend the current commit)
+ (use "git rebase --continue" once you are satisfied with your changes)
+
+nothing to commit (use -u to show untracked files)
+EOF
+ git status --untracked-files=no >actual &&
+ test_i18ncmp expected actual
+'
+
+test_expect_success 'status: more than two commands done, two remainings' '
+ FAKE_LINES="1 2 exec_exit_15 3 4" &&
+ export FAKE_LINES &&
+ test_when_finished "git rebase --abort" &&
+ ONTO=$(git rev-parse --short HEAD~4) &&
+ COMMIT4=$(git rev-parse HEAD) &&
+ COMMIT3=$(git rev-parse HEAD^) &&
+ COMMIT2=$(git rev-parse HEAD^^) &&
+ (git rebase -i HEAD~4 || true)&&
+ cat >expected <<EOF &&
+interactive rebase in progress; onto $ONTO
+Last command(s) done (3 command(s) done):
+ pick $COMMIT2 two_commit
+ exec exit 15
+ (see more at .git/rebase-merge/done)
+Next command(s) to do (2 remaining command(s)):
+ pick $COMMIT3 three_commit
+ pick $COMMIT4 four_commit
+ (use git rebase --edit-todo to view and edit)
+You are currently editing a commit while rebasing branch
'\''several_commits'\'' on '\''$ONTO'\''.
+ (use "git commit --amend" to amend the current commit)
+ (use "git rebase --continue" once you are satisfied with your changes)
+
+nothing to commit (use -u to show untracked files)
+EOF
+ git status --untracked-files=no >actual &&
+ test_i18ncmp expected actual
+'
+
test_done
--
2.4.2.340.g37f3f38
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html