t / t6016-rev-list-graph-simplify-history.shon commit Avoid conflicts when merging branches with mixed normalization (f217f0e)
   1#!/bin/sh
   2
   3# There's more than one "correct" way to represent the history graphically.
   4# These tests depend on the current behavior of the graphing code.  If the
   5# graphing code is ever changed to draw the output differently, these tests
   6# cases will need to be updated to know about the new layout.
   7
   8test_description='--graph and simplified history'
   9
  10. ./test-lib.sh
  11
  12test_expect_success 'set up rev-list --graph test' '
  13        # 3 commits on branch A
  14        test_commit A1 foo.txt &&
  15        test_commit A2 bar.txt &&
  16        test_commit A3 bar.txt &&
  17        git branch -m master A &&
  18
  19        # 2 commits on branch B, started from A1
  20        git checkout -b B A1 &&
  21        test_commit B1 foo.txt &&
  22        test_commit B2 abc.txt &&
  23
  24        # 2 commits on branch C, started from A2
  25        git checkout -b C A2 &&
  26        test_commit C1 xyz.txt &&
  27        test_commit C2 xyz.txt &&
  28
  29        # Octopus merge B and C into branch A
  30        git checkout A &&
  31        git merge B C &&
  32        git tag A4
  33
  34        test_commit A5 bar.txt &&
  35
  36        # More commits on C, then merge C into A
  37        git checkout C &&
  38        test_commit C3 foo.txt &&
  39        test_commit C4 bar.txt &&
  40        git checkout A &&
  41        git merge -s ours C &&
  42        git tag A6
  43
  44        test_commit A7 bar.txt &&
  45
  46        # Store commit names in variables for later use
  47        A1=$(git rev-parse --verify A1) &&
  48        A2=$(git rev-parse --verify A2) &&
  49        A3=$(git rev-parse --verify A3) &&
  50        A4=$(git rev-parse --verify A4) &&
  51        A5=$(git rev-parse --verify A5) &&
  52        A6=$(git rev-parse --verify A6) &&
  53        A7=$(git rev-parse --verify A7) &&
  54        B1=$(git rev-parse --verify B1) &&
  55        B2=$(git rev-parse --verify B2) &&
  56        C1=$(git rev-parse --verify C1) &&
  57        C2=$(git rev-parse --verify C2) &&
  58        C3=$(git rev-parse --verify C3) &&
  59        C4=$(git rev-parse --verify C4)
  60        '
  61
  62test_expect_success '--graph --all' '
  63        rm -f expected &&
  64        echo "* $A7" >> expected &&
  65        echo "*   $A6" >> expected &&
  66        echo "|\\  " >> expected &&
  67        echo "| * $C4" >> expected &&
  68        echo "| * $C3" >> expected &&
  69        echo "* | $A5" >> expected &&
  70        echo "| |     " >> expected &&
  71        echo "|  \\    " >> expected &&
  72        echo "*-. \\   $A4" >> expected &&
  73        echo "|\\ \\ \\  " >> expected &&
  74        echo "| | |/  " >> expected &&
  75        echo "| | * $C2" >> expected &&
  76        echo "| | * $C1" >> expected &&
  77        echo "| * | $B2" >> expected &&
  78        echo "| * | $B1" >> expected &&
  79        echo "* | | $A3" >> expected &&
  80        echo "| |/  " >> expected &&
  81        echo "|/|   " >> expected &&
  82        echo "* | $A2" >> expected &&
  83        echo "|/  " >> expected &&
  84        echo "* $A1" >> expected &&
  85        git rev-list --graph --all > actual &&
  86        test_cmp expected actual
  87        '
  88
  89# Make sure the graph_is_interesting() code still realizes
  90# that undecorated merges are interesting, even with --simplify-by-decoration
  91test_expect_success '--graph --simplify-by-decoration' '
  92        rm -f expected &&
  93        git tag -d A4
  94        echo "* $A7" >> expected &&
  95        echo "*   $A6" >> expected &&
  96        echo "|\\  " >> expected &&
  97        echo "| * $C4" >> expected &&
  98        echo "| * $C3" >> expected &&
  99        echo "* | $A5" >> expected &&
 100        echo "| |     " >> expected &&
 101        echo "|  \\    " >> expected &&
 102        echo "*-. \\   $A4" >> expected &&
 103        echo "|\\ \\ \\  " >> expected &&
 104        echo "| | |/  " >> expected &&
 105        echo "| | * $C2" >> expected &&
 106        echo "| | * $C1" >> expected &&
 107        echo "| * | $B2" >> expected &&
 108        echo "| * | $B1" >> expected &&
 109        echo "* | | $A3" >> expected &&
 110        echo "| |/  " >> expected &&
 111        echo "|/|   " >> expected &&
 112        echo "* | $A2" >> expected &&
 113        echo "|/  " >> expected &&
 114        echo "* $A1" >> expected &&
 115        git rev-list --graph --all --simplify-by-decoration > actual &&
 116        test_cmp expected actual
 117        '
 118
 119# Get rid of all decorations on branch B, and graph with it simplified away
 120test_expect_success '--graph --simplify-by-decoration prune branch B' '
 121        rm -f expected &&
 122        git tag -d B2
 123        git tag -d B1
 124        git branch -d B
 125        echo "* $A7" >> expected &&
 126        echo "*   $A6" >> expected &&
 127        echo "|\\  " >> expected &&
 128        echo "| * $C4" >> expected &&
 129        echo "| * $C3" >> expected &&
 130        echo "* | $A5" >> expected &&
 131        echo "* |   $A4" >> expected &&
 132        echo "|\\ \\  " >> expected &&
 133        echo "| |/  " >> expected &&
 134        echo "| * $C2" >> expected &&
 135        echo "| * $C1" >> expected &&
 136        echo "* | $A3" >> expected &&
 137        echo "|/  " >> expected &&
 138        echo "* $A2" >> expected &&
 139        echo "* $A1" >> expected &&
 140        git rev-list --graph --simplify-by-decoration --all > actual &&
 141        test_cmp expected actual
 142        '
 143
 144test_expect_success '--graph --full-history -- bar.txt' '
 145        rm -f expected &&
 146        git tag -d B2
 147        git tag -d B1
 148        git branch -d B
 149        echo "* $A7" >> expected &&
 150        echo "*   $A6" >> expected &&
 151        echo "|\\  " >> expected &&
 152        echo "| * $C4" >> expected &&
 153        echo "* | $A5" >> expected &&
 154        echo "* |   $A4" >> expected &&
 155        echo "|\\ \\  " >> expected &&
 156        echo "| |/  " >> expected &&
 157        echo "* | $A3" >> expected &&
 158        echo "|/  " >> expected &&
 159        echo "* $A2" >> expected &&
 160        git rev-list --graph --full-history --all -- bar.txt > actual &&
 161        test_cmp expected actual
 162        '
 163
 164test_expect_success '--graph --full-history --simplify-merges -- bar.txt' '
 165        rm -f expected &&
 166        git tag -d B2
 167        git tag -d B1
 168        git branch -d B
 169        echo "* $A7" >> expected &&
 170        echo "*   $A6" >> expected &&
 171        echo "|\\  " >> expected &&
 172        echo "| * $C4" >> expected &&
 173        echo "* | $A5" >> expected &&
 174        echo "* | $A3" >> expected &&
 175        echo "|/  " >> expected &&
 176        echo "* $A2" >> expected &&
 177        git rev-list --graph --full-history --simplify-merges --all \
 178                -- bar.txt > actual &&
 179        test_cmp expected actual
 180        '
 181
 182test_expect_success '--graph -- bar.txt' '
 183        rm -f expected &&
 184        git tag -d B2
 185        git tag -d B1
 186        git branch -d B
 187        echo "* $A7" >> expected &&
 188        echo "* $A5" >> expected &&
 189        echo "* $A3" >> expected &&
 190        echo "| * $C4" >> expected &&
 191        echo "|/  " >> expected &&
 192        echo "* $A2" >> expected &&
 193        git rev-list --graph --all -- bar.txt > actual &&
 194        test_cmp expected actual
 195        '
 196
 197test_expect_success '--graph --sparse -- bar.txt' '
 198        rm -f expected &&
 199        git tag -d B2
 200        git tag -d B1
 201        git branch -d B
 202        echo "* $A7" >> expected &&
 203        echo "* $A6" >> expected &&
 204        echo "* $A5" >> expected &&
 205        echo "* $A4" >> expected &&
 206        echo "* $A3" >> expected &&
 207        echo "| * $C4" >> expected &&
 208        echo "| * $C3" >> expected &&
 209        echo "| * $C2" >> expected &&
 210        echo "| * $C1" >> expected &&
 211        echo "|/  " >> expected &&
 212        echo "* $A2" >> expected &&
 213        echo "* $A1" >> expected &&
 214        git rev-list --graph --sparse --all -- bar.txt > actual &&
 215        test_cmp expected actual
 216        '
 217
 218test_expect_success '--graph ^C4' '
 219        rm -f expected &&
 220        echo "* $A7" >> expected &&
 221        echo "* $A6" >> expected &&
 222        echo "* $A5" >> expected &&
 223        echo "*   $A4" >> expected &&
 224        echo "|\\  " >> expected &&
 225        echo "| * $B2" >> expected &&
 226        echo "| * $B1" >> expected &&
 227        echo "* $A3" >> expected &&
 228        git rev-list --graph --all ^C4 > actual &&
 229        test_cmp expected actual
 230        '
 231
 232test_expect_success '--graph ^C3' '
 233        rm -f expected &&
 234        echo "* $A7" >> expected &&
 235        echo "*   $A6" >> expected &&
 236        echo "|\\  " >> expected &&
 237        echo "| * $C4" >> expected &&
 238        echo "* $A5" >> expected &&
 239        echo "*   $A4" >> expected &&
 240        echo "|\\  " >> expected &&
 241        echo "| * $B2" >> expected &&
 242        echo "| * $B1" >> expected &&
 243        echo "* $A3" >> expected &&
 244        git rev-list --graph --all ^C3 > actual &&
 245        test_cmp expected actual
 246        '
 247
 248# I don't think the ordering of the boundary commits is really
 249# that important, but this test depends on it.  If the ordering ever changes
 250# in the code, we'll need to update this test.
 251test_expect_success '--graph --boundary ^C3' '
 252        rm -f expected &&
 253        echo "* $A7" >> expected &&
 254        echo "*   $A6" >> expected &&
 255        echo "|\\  " >> expected &&
 256        echo "| * $C4" >> expected &&
 257        echo "* | $A5" >> expected &&
 258        echo "| |     " >> expected &&
 259        echo "|  \\    " >> expected &&
 260        echo "*-. \\   $A4" >> expected &&
 261        echo "|\\ \\ \\  " >> expected &&
 262        echo "| * | | $B2" >> expected &&
 263        echo "| * | | $B1" >> expected &&
 264        echo "* | | | $A3" >> expected &&
 265        echo "o | | | $A2" >> expected &&
 266        echo "|/ / /  " >> expected &&
 267        echo "o | | $A1" >> expected &&
 268        echo " / /  " >> expected &&
 269        echo "| o $C3" >> expected &&
 270        echo "|/  " >> expected &&
 271        echo "o $C2" >> expected &&
 272        git rev-list --graph --boundary --all ^C3 > actual &&
 273        test_cmp expected actual
 274        '
 275
 276test_done