t / t7401-submodule-summary.shon commit cherry-pick: add --allow-empty-message option (4bee958)
   1#!/bin/sh
   2#
   3# Copyright (c) 2008 Ping Yin
   4#
   5
   6test_description='Summary support for submodules
   7
   8This test tries to verify the sanity of summary subcommand of git submodule.
   9'
  10
  11. ./test-lib.sh
  12
  13add_file () {
  14        sm=$1
  15        shift
  16        owd=$(pwd)
  17        cd "$sm"
  18        for name; do
  19                echo "$name" > "$name" &&
  20                git add "$name" &&
  21                test_tick &&
  22                git commit -m "Add $name"
  23        done >/dev/null
  24        git rev-parse --verify HEAD | cut -c1-7
  25        cd "$owd"
  26}
  27commit_file () {
  28        test_tick &&
  29        git commit "$@" -m "Commit $*" >/dev/null
  30}
  31
  32test_create_repo sm1 &&
  33add_file . foo >/dev/null
  34
  35head1=$(add_file sm1 foo1 foo2)
  36
  37test_expect_success 'added submodule' "
  38        git add sm1 &&
  39        git submodule summary >actual &&
  40        cat >expected <<-EOF &&
  41* sm1 0000000...$head1 (2):
  42  > Add foo2
  43
  44EOF
  45        test_cmp expected actual
  46"
  47
  48commit_file sm1 &&
  49head2=$(add_file sm1 foo3)
  50
  51test_expect_success 'modified submodule(forward)' "
  52        git submodule summary >actual &&
  53        cat >expected <<-EOF &&
  54* sm1 $head1...$head2 (1):
  55  > Add foo3
  56
  57EOF
  58        test_cmp expected actual
  59"
  60
  61test_expect_success 'modified submodule(forward), --files' "
  62        git submodule summary --files >actual &&
  63        cat >expected <<-EOF &&
  64* sm1 $head1...$head2 (1):
  65  > Add foo3
  66
  67EOF
  68        test_cmp expected actual
  69"
  70
  71commit_file sm1 &&
  72head3=$(
  73        cd sm1 &&
  74        git reset --hard HEAD~2 >/dev/null &&
  75        git rev-parse --verify HEAD | cut -c1-7
  76)
  77
  78test_expect_success 'modified submodule(backward)' "
  79    git submodule summary >actual &&
  80    cat >expected <<-EOF &&
  81* sm1 $head2...$head3 (2):
  82  < Add foo3
  83  < Add foo2
  84
  85EOF
  86        test_cmp expected actual
  87"
  88
  89head4=$(add_file sm1 foo4 foo5) &&
  90head4_full=$(GIT_DIR=sm1/.git git rev-parse --verify HEAD)
  91test_expect_success 'modified submodule(backward and forward)' "
  92    git submodule summary >actual &&
  93    cat >expected <<-EOF &&
  94* sm1 $head2...$head4 (4):
  95  > Add foo5
  96  > Add foo4
  97  < Add foo3
  98  < Add foo2
  99
 100EOF
 101        test_cmp expected actual
 102"
 103
 104test_expect_success '--summary-limit' "
 105    git submodule summary -n 3 >actual &&
 106    cat >expected <<-EOF &&
 107* sm1 $head2...$head4 (4):
 108  > Add foo5
 109  > Add foo4
 110  < Add foo3
 111
 112EOF
 113    test_cmp expected actual
 114"
 115
 116commit_file sm1 &&
 117mv sm1 sm1-bak &&
 118echo sm1 >sm1 &&
 119head5=$(git hash-object sm1 | cut -c1-7) &&
 120git add sm1 &&
 121rm -f sm1 &&
 122mv sm1-bak sm1
 123
 124test_expect_success 'typechanged submodule(submodule->blob), --cached' "
 125    git submodule summary --cached >actual &&
 126    cat >expected <<-EOF &&
 127* sm1 $head4(submodule)->$head5(blob) (3):
 128  < Add foo5
 129
 130EOF
 131        test_i18ncmp actual expected
 132"
 133
 134test_expect_success 'typechanged submodule(submodule->blob), --files' "
 135    git submodule summary --files >actual &&
 136    cat >expected <<-EOF &&
 137* sm1 $head5(blob)->$head4(submodule) (3):
 138  > Add foo5
 139
 140EOF
 141    test_i18ncmp actual expected
 142"
 143
 144rm -rf sm1 &&
 145git checkout-index sm1
 146test_expect_success 'typechanged submodule(submodule->blob)' "
 147    git submodule summary >actual &&
 148    cat >expected <<-EOF &&
 149* sm1 $head4(submodule)->$head5(blob):
 150
 151EOF
 152    test_i18ncmp actual expected
 153"
 154
 155rm -f sm1 &&
 156test_create_repo sm1 &&
 157head6=$(add_file sm1 foo6 foo7)
 158test_expect_success 'nonexistent commit' "
 159    git submodule summary >actual &&
 160    cat >expected <<-EOF &&
 161* sm1 $head4...$head6:
 162  Warn: sm1 doesn't contain commit $head4_full
 163
 164EOF
 165    test_i18ncmp actual expected
 166"
 167
 168commit_file
 169test_expect_success 'typechanged submodule(blob->submodule)' "
 170    git submodule summary >actual &&
 171    cat >expected <<-EOF &&
 172* sm1 $head5(blob)->$head6(submodule) (2):
 173  > Add foo7
 174
 175EOF
 176    test_i18ncmp expected actual
 177"
 178
 179commit_file sm1 &&
 180rm -rf sm1
 181test_expect_success 'deleted submodule' "
 182    git submodule summary >actual &&
 183    cat >expected <<-EOF &&
 184* sm1 $head6...0000000:
 185
 186EOF
 187    test_cmp expected actual
 188"
 189
 190test_create_repo sm2 &&
 191head7=$(add_file sm2 foo8 foo9) &&
 192git add sm2
 193
 194test_expect_success 'multiple submodules' "
 195    git submodule summary >actual &&
 196    cat >expected <<-EOF &&
 197* sm1 $head6...0000000:
 198
 199* sm2 0000000...$head7 (2):
 200  > Add foo9
 201
 202EOF
 203    test_cmp expected actual
 204"
 205
 206test_expect_success 'path filter' "
 207    git submodule summary sm2 >actual &&
 208    cat >expected <<-EOF &&
 209* sm2 0000000...$head7 (2):
 210  > Add foo9
 211
 212EOF
 213    test_cmp expected actual
 214"
 215
 216commit_file sm2
 217test_expect_success 'given commit' "
 218    git submodule summary HEAD^ >actual &&
 219    cat >expected <<-EOF &&
 220* sm1 $head6...0000000:
 221
 222* sm2 0000000...$head7 (2):
 223  > Add foo9
 224
 225EOF
 226    test_cmp expected actual
 227"
 228
 229test_expect_success '--for-status' "
 230    git submodule summary --for-status HEAD^ >actual &&
 231    test_i18ncmp actual - <<EOF
 232# Submodule changes to be committed:
 233#
 234# * sm1 $head6...0000000:
 235#
 236# * sm2 0000000...$head7 (2):
 237#   > Add foo9
 238#
 239EOF
 240"
 241
 242test_expect_success 'fail when using --files together with --cached' "
 243    test_must_fail git submodule summary --files --cached
 244"
 245
 246test_expect_success 'should not fail in an empty repo' "
 247    git init xyzzy &&
 248    cd xyzzy &&
 249    git submodule summary >output 2>&1 &&
 250    test_cmp output /dev/null
 251"
 252
 253test_done