t / t4202-log.shon commit blame,cat-file --textconv: Don't assume mode is ``S_IFREF | 0664'' (9006471)
   1#!/bin/sh
   2
   3test_description='git log'
   4
   5. ./test-lib.sh
   6
   7test_expect_success setup '
   8
   9        echo one >one &&
  10        git add one &&
  11        test_tick &&
  12        git commit -m initial &&
  13
  14        echo ichi >one &&
  15        git add one &&
  16        test_tick &&
  17        git commit -m second &&
  18
  19        git mv one ichi &&
  20        test_tick &&
  21        git commit -m third &&
  22
  23        cp ichi ein &&
  24        git add ein &&
  25        test_tick &&
  26        git commit -m fourth &&
  27
  28        mkdir a &&
  29        echo ni >a/two &&
  30        git add a/two &&
  31        test_tick &&
  32        git commit -m fifth  &&
  33
  34        git rm a/two &&
  35        test_tick &&
  36        git commit -m sixth
  37
  38'
  39
  40printf "sixth\nfifth\nfourth\nthird\nsecond\ninitial" > expect
  41test_expect_success 'pretty' '
  42
  43        git log --pretty="format:%s" > actual &&
  44        test_cmp expect actual
  45'
  46
  47printf "sixth\nfifth\nfourth\nthird\nsecond\ninitial\n" > expect
  48test_expect_success 'pretty (tformat)' '
  49
  50        git log --pretty="tformat:%s" > actual &&
  51        test_cmp expect actual
  52'
  53
  54test_expect_success 'pretty (shortcut)' '
  55
  56        git log --pretty="%s" > actual &&
  57        test_cmp expect actual
  58'
  59
  60test_expect_success 'format' '
  61
  62        git log --format="%s" > actual &&
  63        test_cmp expect actual
  64'
  65
  66cat > expect << EOF
  67 This is
  68  the sixth
  69  commit.
  70 This is
  71  the fifth
  72  commit.
  73EOF
  74
  75test_expect_success 'format %w(12,1,2)' '
  76
  77        git log -2 --format="%w(12,1,2)This is the %s commit." > actual &&
  78        test_cmp expect actual
  79'
  80
  81test_expect_success 'format %w(,1,2)' '
  82
  83        git log -2 --format="%w(,1,2)This is%nthe %s%ncommit." > actual &&
  84        test_cmp expect actual
  85'
  86
  87cat > expect << EOF
  88804a787 sixth
  89394ef78 fifth
  905d31159 fourth
  912fbe8c0 third
  92f7dab8e second
  933a2fdcb initial
  94EOF
  95test_expect_success 'oneline' '
  96
  97        git log --oneline > actual &&
  98        test_cmp expect actual
  99'
 100
 101test_expect_success 'diff-filter=A' '
 102
 103        actual=$(git log --pretty="format:%s" --diff-filter=A HEAD) &&
 104        expect=$(echo fifth ; echo fourth ; echo third ; echo initial) &&
 105        test "$actual" = "$expect" || {
 106                echo Oops
 107                echo "Actual: $actual"
 108                false
 109        }
 110
 111'
 112
 113test_expect_success 'diff-filter=M' '
 114
 115        actual=$(git log --pretty="format:%s" --diff-filter=M HEAD) &&
 116        expect=$(echo second) &&
 117        test "$actual" = "$expect" || {
 118                echo Oops
 119                echo "Actual: $actual"
 120                false
 121        }
 122
 123'
 124
 125test_expect_success 'diff-filter=D' '
 126
 127        actual=$(git log --pretty="format:%s" --diff-filter=D HEAD) &&
 128        expect=$(echo sixth ; echo third) &&
 129        test "$actual" = "$expect" || {
 130                echo Oops
 131                echo "Actual: $actual"
 132                false
 133        }
 134
 135'
 136
 137test_expect_success 'diff-filter=R' '
 138
 139        actual=$(git log -M --pretty="format:%s" --diff-filter=R HEAD) &&
 140        expect=$(echo third) &&
 141        test "$actual" = "$expect" || {
 142                echo Oops
 143                echo "Actual: $actual"
 144                false
 145        }
 146
 147'
 148
 149test_expect_success 'diff-filter=C' '
 150
 151        actual=$(git log -C -C --pretty="format:%s" --diff-filter=C HEAD) &&
 152        expect=$(echo fourth) &&
 153        test "$actual" = "$expect" || {
 154                echo Oops
 155                echo "Actual: $actual"
 156                false
 157        }
 158
 159'
 160
 161test_expect_success 'git log --follow' '
 162
 163        actual=$(git log --follow --pretty="format:%s" ichi) &&
 164        expect=$(echo third ; echo second ; echo initial) &&
 165        test "$actual" = "$expect" || {
 166                echo Oops
 167                echo "Actual: $actual"
 168                false
 169        }
 170
 171'
 172
 173cat > expect << EOF
 174804a787 sixth
 175394ef78 fifth
 1765d31159 fourth
 177EOF
 178test_expect_success 'git log --no-walk <commits> sorts by commit time' '
 179        git log --no-walk --oneline 5d31159 804a787 394ef78 > actual &&
 180        test_cmp expect actual
 181'
 182
 183cat > expect << EOF
 1845d31159 fourth
 185804a787 sixth
 186394ef78 fifth
 187EOF
 188test_expect_success 'git show <commits> leaves list of commits as given' '
 189        git show --oneline -s 5d31159 804a787 394ef78 > actual &&
 190        test_cmp expect actual
 191'
 192
 193test_expect_success 'setup case sensitivity tests' '
 194        echo case >one &&
 195        test_tick &&
 196        git add one
 197        git commit -a -m Second
 198'
 199
 200test_expect_success 'log --grep' '
 201        echo second >expect &&
 202        git log -1 --pretty="tformat:%s" --grep=sec >actual &&
 203        test_cmp expect actual
 204'
 205
 206test_expect_success 'log -i --grep' '
 207        echo Second >expect &&
 208        git log -1 --pretty="tformat:%s" -i --grep=sec >actual &&
 209        test_cmp expect actual
 210'
 211
 212test_expect_success 'log --grep -i' '
 213        echo Second >expect &&
 214        git log -1 --pretty="tformat:%s" --grep=sec -i >actual &&
 215        test_cmp expect actual
 216'
 217
 218cat > expect <<EOF
 219* Second
 220* sixth
 221* fifth
 222* fourth
 223* third
 224* second
 225* initial
 226EOF
 227
 228test_expect_success 'simple log --graph' '
 229        git log --graph --pretty=tformat:%s >actual &&
 230        test_cmp expect actual
 231'
 232
 233test_expect_success 'set up merge history' '
 234        git checkout -b side HEAD~4 &&
 235        test_commit side-1 1 1 &&
 236        test_commit side-2 2 2 &&
 237        git checkout master &&
 238        git merge side
 239'
 240
 241cat > expect <<\EOF
 242*   Merge branch 'side'
 243|\
 244| * side-2
 245| * side-1
 246* | Second
 247* | sixth
 248* | fifth
 249* | fourth
 250|/
 251* third
 252* second
 253* initial
 254EOF
 255
 256test_expect_success 'log --graph with merge' '
 257        git log --graph --date-order --pretty=tformat:%s |
 258                sed "s/ *\$//" >actual &&
 259        test_cmp expect actual
 260'
 261
 262cat > expect <<\EOF
 263*   commit master
 264|\  Merge: A B
 265| | Author: A U Thor <author@example.com>
 266| |
 267| |     Merge branch 'side'
 268| |
 269| * commit side
 270| | Author: A U Thor <author@example.com>
 271| |
 272| |     side-2
 273| |
 274| * commit tags/side-1
 275| | Author: A U Thor <author@example.com>
 276| |
 277| |     side-1
 278| |
 279* | commit master~1
 280| | Author: A U Thor <author@example.com>
 281| |
 282| |     Second
 283| |
 284* | commit master~2
 285| | Author: A U Thor <author@example.com>
 286| |
 287| |     sixth
 288| |
 289* | commit master~3
 290| | Author: A U Thor <author@example.com>
 291| |
 292| |     fifth
 293| |
 294* | commit master~4
 295|/  Author: A U Thor <author@example.com>
 296|
 297|       fourth
 298|
 299* commit tags/side-1~1
 300| Author: A U Thor <author@example.com>
 301|
 302|     third
 303|
 304* commit tags/side-1~2
 305| Author: A U Thor <author@example.com>
 306|
 307|     second
 308|
 309* commit tags/side-1~3
 310  Author: A U Thor <author@example.com>
 311
 312      initial
 313EOF
 314
 315test_expect_success 'log --graph with full output' '
 316        git log --graph --date-order --pretty=short |
 317                git name-rev --name-only --stdin |
 318                sed "s/Merge:.*/Merge: A B/;s/ *\$//" >actual &&
 319        test_cmp expect actual
 320'
 321
 322test_expect_success 'set up more tangled history' '
 323        git checkout -b tangle HEAD~6 &&
 324        test_commit tangle-a tangle-a a &&
 325        git merge master~3 &&
 326        git merge side~1 &&
 327        git checkout master &&
 328        git merge tangle &&
 329        git checkout -b reach &&
 330        test_commit reach &&
 331        git checkout master &&
 332        git checkout -b octopus-a &&
 333        test_commit octopus-a &&
 334        git checkout master &&
 335        git checkout -b octopus-b &&
 336        test_commit octopus-b &&
 337        git checkout master &&
 338        test_commit seventh &&
 339        git merge octopus-a octopus-b
 340        git merge reach
 341'
 342
 343cat > expect <<\EOF
 344*   Merge commit 'reach'
 345|\
 346| \
 347|  \
 348*-. \   Merge commit 'octopus-a'; commit 'octopus-b'
 349|\ \ \
 350* | | | seventh
 351| | * | octopus-b
 352| |/ /
 353|/| |
 354| * | octopus-a
 355|/ /
 356| * reach
 357|/
 358*   Merge branch 'tangle'
 359|\
 360| *   Merge branch 'side' (early part) into tangle
 361| |\
 362| * \   Merge branch 'master' (early part) into tangle
 363| |\ \
 364| * | | tangle-a
 365* | | |   Merge branch 'side'
 366|\ \ \ \
 367| * | | | side-2
 368| | |_|/
 369| |/| |
 370| * | | side-1
 371* | | | Second
 372* | | | sixth
 373| |_|/
 374|/| |
 375* | | fifth
 376* | | fourth
 377|/ /
 378* | third
 379|/
 380* second
 381* initial
 382EOF
 383
 384test_expect_success 'log --graph with merge' '
 385        git log --graph --date-order --pretty=tformat:%s |
 386                sed "s/ *\$//" >actual &&
 387        test_cmp expect actual
 388'
 389
 390test_expect_success 'log.decorate configuration' '
 391        git config --unset-all log.decorate || :
 392
 393        git log --oneline >expect.none &&
 394        git log --oneline --decorate >expect.short &&
 395        git log --oneline --decorate=full >expect.full &&
 396
 397        echo "[log] decorate" >>.git/config &&
 398        git log --oneline >actual &&
 399        test_cmp expect.short actual &&
 400
 401        git config --unset-all log.decorate &&
 402        git config log.decorate true &&
 403        git log --oneline >actual &&
 404        test_cmp expect.short actual &&
 405        git log --oneline --decorate=full >actual &&
 406        test_cmp expect.full actual &&
 407        git log --oneline --decorate=no >actual &&
 408        test_cmp expect.none actual &&
 409
 410        git config --unset-all log.decorate &&
 411        git config log.decorate no &&
 412        git log --oneline >actual &&
 413        test_cmp expect.none actual &&
 414        git log --oneline --decorate >actual &&
 415        test_cmp expect.short actual &&
 416        git log --oneline --decorate=full >actual &&
 417        test_cmp expect.full actual &&
 418
 419        git config --unset-all log.decorate &&
 420        git config log.decorate short &&
 421        git log --oneline >actual &&
 422        test_cmp expect.short actual &&
 423        git log --oneline --no-decorate >actual &&
 424        test_cmp expect.none actual &&
 425        git log --oneline --decorate=full >actual &&
 426        test_cmp expect.full actual &&
 427
 428        git config --unset-all log.decorate &&
 429        git config log.decorate full &&
 430        git log --oneline >actual &&
 431        test_cmp expect.full actual &&
 432        git log --oneline --no-decorate >actual &&
 433        test_cmp expect.none actual &&
 434        git log --oneline --decorate >actual &&
 435        test_cmp expect.short actual
 436
 437'
 438
 439test_expect_success 'show added path under "--follow -M"' '
 440        # This tests for a regression introduced in v1.7.2-rc0~103^2~2
 441        test_create_repo regression &&
 442        (
 443                cd regression &&
 444                test_commit needs-another-commit &&
 445                test_commit foo.bar &&
 446                git log -M --follow -p foo.bar.t &&
 447                git log -M --follow --stat foo.bar.t &&
 448                git log -M --follow --name-only foo.bar.t
 449        )
 450'
 451
 452test_done