| #!/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 |