You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
246 lines
3.7 KiB
246 lines
3.7 KiB
#!/bin/sh |
|
|
|
# There's more than one "correct" way to represent the history graphically. |
|
# These tests depend on the current behavior of the graphing code. If the |
|
# graphing code is ever changed to draw the output differently, these tests |
|
# cases will need to be updated to know about the new layout. |
|
|
|
test_description='--graph and simplified history' |
|
|
|
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main |
|
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME |
|
|
|
. ./test-lib.sh |
|
. "$TEST_DIRECTORY"/lib-log-graph.sh |
|
|
|
check_graph () { |
|
cat >expect && |
|
lib_test_cmp_graph --format=%s "$@" |
|
} |
|
|
|
test_expect_success 'set up rev-list --graph test' ' |
|
# 3 commits on branch A |
|
test_commit A1 foo.txt && |
|
test_commit A2 bar.txt && |
|
test_commit A3 bar.txt && |
|
git branch -m main A && |
|
|
|
# 2 commits on branch B, started from A1 |
|
git checkout -b B A1 && |
|
test_commit B1 foo.txt && |
|
test_commit B2 abc.txt && |
|
|
|
# 2 commits on branch C, started from A2 |
|
git checkout -b C A2 && |
|
test_commit C1 xyz.txt && |
|
test_commit C2 xyz.txt && |
|
|
|
# Octopus merge B and C into branch A |
|
git checkout A && |
|
git merge B C -m A4 && |
|
git tag A4 && |
|
|
|
test_commit A5 bar.txt && |
|
|
|
# More commits on C, then merge C into A |
|
git checkout C && |
|
test_commit C3 foo.txt && |
|
test_commit C4 bar.txt && |
|
git checkout A && |
|
git merge -s ours C -m A6 && |
|
git tag A6 && |
|
|
|
test_commit A7 bar.txt |
|
' |
|
|
|
test_expect_success '--graph --all' ' |
|
check_graph --all <<-\EOF |
|
* A7 |
|
* A6 |
|
|\ |
|
| * C4 |
|
| * C3 |
|
* | A5 |
|
| | |
|
| \ |
|
*-. | A4 |
|
|\ \| |
|
| | * C2 |
|
| | * C1 |
|
| * | B2 |
|
| * | B1 |
|
* | | A3 |
|
| |/ |
|
|/| |
|
* | A2 |
|
|/ |
|
* A1 |
|
EOF |
|
' |
|
|
|
# Make sure the graph_is_interesting() code still realizes |
|
# that undecorated merges are interesting, even with --simplify-by-decoration |
|
test_expect_success '--graph --simplify-by-decoration' ' |
|
git tag -d A4 && |
|
check_graph --all --simplify-by-decoration <<-\EOF |
|
* A7 |
|
* A6 |
|
|\ |
|
| * C4 |
|
| * C3 |
|
* | A5 |
|
| | |
|
| \ |
|
*-. | A4 |
|
|\ \| |
|
| | * C2 |
|
| | * C1 |
|
| * | B2 |
|
| * | B1 |
|
* | | A3 |
|
| |/ |
|
|/| |
|
* | A2 |
|
|/ |
|
* A1 |
|
EOF |
|
' |
|
|
|
test_expect_success 'setup: get rid of decorations on B' ' |
|
git tag -d B2 && |
|
git tag -d B1 && |
|
git branch -d B |
|
' |
|
|
|
# Graph with branch B simplified away |
|
test_expect_success '--graph --simplify-by-decoration prune branch B' ' |
|
check_graph --simplify-by-decoration --all <<-\EOF |
|
* A7 |
|
* A6 |
|
|\ |
|
| * C4 |
|
| * C3 |
|
* | A5 |
|
* | A4 |
|
|\| |
|
| * C2 |
|
| * C1 |
|
* | A3 |
|
|/ |
|
* A2 |
|
* A1 |
|
EOF |
|
' |
|
|
|
test_expect_success '--graph --full-history -- bar.txt' ' |
|
check_graph --full-history --all -- bar.txt <<-\EOF |
|
* A7 |
|
* A6 |
|
|\ |
|
| * C4 |
|
* | A5 |
|
* | A4 |
|
|\| |
|
* | A3 |
|
|/ |
|
* A2 |
|
EOF |
|
' |
|
|
|
test_expect_success '--graph --full-history --simplify-merges -- bar.txt' ' |
|
check_graph --full-history --simplify-merges --all -- bar.txt <<-\EOF |
|
* A7 |
|
* A6 |
|
|\ |
|
| * C4 |
|
* | A5 |
|
* | A3 |
|
|/ |
|
* A2 |
|
EOF |
|
' |
|
|
|
test_expect_success '--graph -- bar.txt' ' |
|
check_graph --all -- bar.txt <<-\EOF |
|
* A7 |
|
* A5 |
|
* A3 |
|
| * C4 |
|
|/ |
|
* A2 |
|
EOF |
|
' |
|
|
|
test_expect_success '--graph --sparse -- bar.txt' ' |
|
check_graph --sparse --all -- bar.txt <<-\EOF |
|
* A7 |
|
* A6 |
|
* A5 |
|
* A4 |
|
* A3 |
|
| * C4 |
|
| * C3 |
|
| * C2 |
|
| * C1 |
|
|/ |
|
* A2 |
|
* A1 |
|
EOF |
|
' |
|
|
|
test_expect_success '--graph ^C4' ' |
|
check_graph --all ^C4 <<-\EOF |
|
* A7 |
|
* A6 |
|
* A5 |
|
* A4 |
|
|\ |
|
| * B2 |
|
| * B1 |
|
* A3 |
|
EOF |
|
' |
|
|
|
test_expect_success '--graph ^C3' ' |
|
check_graph --all ^C3 <<-\EOF |
|
* A7 |
|
* A6 |
|
|\ |
|
| * C4 |
|
* A5 |
|
* A4 |
|
|\ |
|
| * B2 |
|
| * B1 |
|
* A3 |
|
EOF |
|
' |
|
|
|
# I don't think the ordering of the boundary commits is really |
|
# that important, but this test depends on it. If the ordering ever changes |
|
# in the code, we'll need to update this test. |
|
test_expect_success '--graph --boundary ^C3' ' |
|
check_graph --boundary --all ^C3 <<-\EOF |
|
* A7 |
|
* A6 |
|
|\ |
|
| * C4 |
|
* | A5 |
|
| | |
|
| \ |
|
*-. \ A4 |
|
|\ \ \ |
|
| * | | B2 |
|
| * | | B1 |
|
* | | | A3 |
|
o | | | A2 |
|
|/ / / |
|
o / / A1 |
|
/ / |
|
| o C3 |
|
|/ |
|
o C2 |
|
EOF |
|
' |
|
|
|
test_done
|
|
|