t / t5526-fetch-submodules.shon commit fetch/pull: recurse into submodules when necessary (88a2197)
   1#!/bin/sh
   2# Copyright (c) 2010, Jens Lehmann
   3
   4test_description='Recursive "git fetch" for submodules'
   5
   6. ./test-lib.sh
   7
   8pwd=$(pwd)
   9
  10add_upstream_commit() {
  11        (
  12                cd submodule &&
  13                head1=$(git rev-parse --short HEAD) &&
  14                echo new >> subfile &&
  15                test_tick &&
  16                git add subfile &&
  17                git commit -m new subfile &&
  18                head2=$(git rev-parse --short HEAD) &&
  19                echo "From $pwd/submodule" > ../expect.err &&
  20                echo "   $head1..$head2  master     -> origin/master" >> ../expect.err
  21        ) &&
  22        (
  23                cd deepsubmodule &&
  24                head1=$(git rev-parse --short HEAD) &&
  25                echo new >> deepsubfile &&
  26                test_tick &&
  27                git add deepsubfile &&
  28                git commit -m new deepsubfile &&
  29                head2=$(git rev-parse --short HEAD) &&
  30                echo "From $pwd/deepsubmodule" >> ../expect.err &&
  31                echo "   $head1..$head2  master     -> origin/master" >> ../expect.err
  32        )
  33}
  34
  35test_expect_success setup '
  36        mkdir deepsubmodule &&
  37        (
  38                cd deepsubmodule &&
  39                git init &&
  40                echo deepsubcontent > deepsubfile &&
  41                git add deepsubfile &&
  42                git commit -m new deepsubfile
  43        ) &&
  44        mkdir submodule &&
  45        (
  46                cd submodule &&
  47                git init &&
  48                echo subcontent > subfile &&
  49                git add subfile &&
  50                git submodule add "$pwd/deepsubmodule" deepsubmodule &&
  51                git commit -a -m new
  52        ) &&
  53        git submodule add "$pwd/submodule" submodule &&
  54        git commit -am initial &&
  55        git clone . downstream &&
  56        (
  57                cd downstream &&
  58                git submodule update --init --recursive
  59        ) &&
  60        echo "Fetching submodule submodule" > expect.out &&
  61        echo "Fetching submodule submodule/deepsubmodule" >> expect.out
  62'
  63
  64test_expect_success "fetch --recurse-submodules recurses into submodules" '
  65        add_upstream_commit &&
  66        (
  67                cd downstream &&
  68                git fetch --recurse-submodules >../actual.out 2>../actual.err
  69        ) &&
  70        test_cmp expect.out actual.out &&
  71        test_cmp expect.err actual.err
  72'
  73
  74test_expect_success "fetch alone only fetches superproject" '
  75        add_upstream_commit &&
  76        (
  77                cd downstream &&
  78                git fetch >../actual.out 2>../actual.err
  79        ) &&
  80        ! test -s actual.out &&
  81        ! test -s actual.err
  82'
  83
  84test_expect_success "fetch --no-recurse-submodules only fetches superproject" '
  85        (
  86                cd downstream &&
  87                git fetch --no-recurse-submodules >../actual.out 2>../actual.err
  88        ) &&
  89        ! test -s actual.out &&
  90        ! test -s actual.err
  91'
  92
  93test_expect_success "using fetchRecurseSubmodules=true in .gitmodules recurses into submodules" '
  94        (
  95                cd downstream &&
  96                git config -f .gitmodules submodule.submodule.fetchRecurseSubmodules true &&
  97                git fetch >../actual.out 2>../actual.err
  98        ) &&
  99        test_cmp expect.out actual.out &&
 100        test_cmp expect.err actual.err
 101'
 102
 103test_expect_success "--no-recurse-submodules overrides .gitmodules config" '
 104        add_upstream_commit &&
 105        (
 106                cd downstream &&
 107                git fetch --no-recurse-submodules >../actual.out 2>../actual.err
 108        ) &&
 109        ! test -s actual.out &&
 110        ! test -s actual.err
 111'
 112
 113test_expect_success "using fetchRecurseSubmodules=false in .git/config overrides setting in .gitmodules" '
 114        (
 115                cd downstream &&
 116                git config submodule.submodule.fetchRecurseSubmodules false &&
 117                git fetch >../actual.out 2>../actual.err
 118        ) &&
 119        ! test -s actual.out &&
 120        ! test -s actual.err
 121'
 122
 123test_expect_success "--recurse-submodules overrides fetchRecurseSubmodules setting from .git/config" '
 124        (
 125                cd downstream &&
 126                git fetch --recurse-submodules >../actual.out 2>../actual.err &&
 127                git config --unset -f .gitmodules submodule.submodule.fetchRecurseSubmodules &&
 128                git config --unset submodule.submodule.fetchRecurseSubmodules
 129        ) &&
 130        test_cmp expect.out actual.out &&
 131        test_cmp expect.err actual.err
 132'
 133
 134test_expect_success "--quiet propagates to submodules" '
 135        (
 136                cd downstream &&
 137                git fetch --recurse-submodules --quiet >../actual.out 2>../actual.err
 138        ) &&
 139        ! test -s actual.out &&
 140        ! test -s actual.err
 141'
 142
 143test_expect_success "--dry-run propagates to submodules" '
 144        add_upstream_commit &&
 145        (
 146                cd downstream &&
 147                git fetch --recurse-submodules --dry-run >../actual.out 2>../actual.err
 148        ) &&
 149        test_cmp expect.out actual.out &&
 150        test_cmp expect.err actual.err &&
 151        (
 152                cd downstream &&
 153                git fetch --recurse-submodules >../actual.out 2>../actual.err
 154        ) &&
 155        test_cmp expect.out actual.out &&
 156        test_cmp expect.err actual.err
 157'
 158
 159test_expect_success "recurseSubmodules=true propagates into submodules" '
 160        add_upstream_commit &&
 161        (
 162                cd downstream &&
 163                git config fetch.recurseSubmodules true
 164                git fetch >../actual.out 2>../actual.err
 165        ) &&
 166        test_cmp expect.out actual.out &&
 167        test_cmp expect.err actual.err
 168'
 169
 170test_expect_success "--recurse-submodules overrides config in submodule" '
 171        add_upstream_commit &&
 172        (
 173                cd downstream &&
 174                (
 175                        cd submodule &&
 176                        git config fetch.recurseSubmodules false
 177                ) &&
 178                git fetch --recurse-submodules >../actual.out 2>../actual.err
 179        ) &&
 180        test_cmp expect.out actual.out &&
 181        test_cmp expect.err actual.err
 182'
 183
 184test_expect_success "--no-recurse-submodules overrides config setting" '
 185        add_upstream_commit &&
 186        (
 187                cd downstream &&
 188                git config fetch.recurseSubmodules true
 189                git fetch --no-recurse-submodules >../actual.out 2>../actual.err
 190        ) &&
 191        ! test -s actual.out &&
 192        ! test -s actual.err
 193'
 194
 195test_expect_success "Recursion doesn't happen when no new commits are fetched in the superproject" '
 196        (
 197                cd downstream &&
 198                (
 199                        cd submodule &&
 200                        git config --unset fetch.recurseSubmodules
 201                ) &&
 202                git config --unset fetch.recurseSubmodules
 203                git fetch >../actual.out 2>../actual.err
 204        ) &&
 205        ! test -s actual.out &&
 206        ! test -s actual.err
 207'
 208
 209test_expect_success "Recursion stops when no new submodule commits are fetched" '
 210        head1=$(git rev-parse --short HEAD) &&
 211        git add submodule &&
 212        git commit -m "new submodule" &&
 213        head2=$(git rev-parse --short HEAD) &&
 214        echo "Fetching submodule submodule" > expect.out.sub &&
 215        echo "From $pwd/." > expect.err.sub &&
 216        echo "   $head1..$head2  master     -> origin/master" >> expect.err.sub
 217        head -2 expect.err >> expect.err.sub &&
 218        (
 219                cd downstream &&
 220                git fetch >../actual.out 2>../actual.err
 221        ) &&
 222        test_cmp expect.err.sub actual.err &&
 223        test_cmp expect.out.sub actual.out
 224'
 225
 226test_expect_success "Recursion doesn't happen when new superproject commits don't change any submodules" '
 227        add_upstream_commit &&
 228        head1=$(git rev-parse --short HEAD) &&
 229        echo a > file &&
 230        git add file &&
 231        git commit -m "new file" &&
 232        head2=$(git rev-parse --short HEAD) &&
 233        echo "From $pwd/." > expect.err.file &&
 234        echo "   $head1..$head2  master     -> origin/master" >> expect.err.file &&
 235        (
 236                cd downstream &&
 237                git fetch >../actual.out 2>../actual.err
 238        ) &&
 239        ! test -s actual.out &&
 240        test_cmp expect.err.file actual.err
 241'
 242
 243test_expect_success "Recursion picks up config in submodule" '
 244        (
 245                cd downstream &&
 246                git fetch --recurse-submodules &&
 247                (
 248                        cd submodule &&
 249                        git config fetch.recurseSubmodules true
 250                )
 251        ) &&
 252        add_upstream_commit &&
 253        head1=$(git rev-parse --short HEAD) &&
 254        git add submodule &&
 255        git commit -m "new submodule" &&
 256        head2=$(git rev-parse --short HEAD) &&
 257        echo "From $pwd/." > expect.err.sub &&
 258        echo "   $head1..$head2  master     -> origin/master" >> expect.err.sub &&
 259        cat expect.err >> expect.err.sub &&
 260        (
 261                cd downstream &&
 262                git fetch >../actual.out 2>../actual.err &&
 263                (
 264                        cd submodule &&
 265                        git config --unset fetch.recurseSubmodules
 266                )
 267        ) &&
 268        test_cmp expect.err.sub actual.err &&
 269        test_cmp expect.out actual.out
 270'
 271
 272test_expect_success "Recursion picks up all submodules when necessary" '
 273        add_upstream_commit &&
 274        (
 275                cd submodule &&
 276                (
 277                        cd deepsubmodule &&
 278                        git fetch &&
 279                        git checkout -q FETCH_HEAD
 280                ) &&
 281                head1=$(git rev-parse --short HEAD^) &&
 282                git add deepsubmodule &&
 283                git commit -m "new deepsubmodule"
 284                head2=$(git rev-parse --short HEAD) &&
 285                echo "From $pwd/submodule" > ../expect.err.sub &&
 286                echo "   $head1..$head2  master     -> origin/master" >> ../expect.err.sub
 287        ) &&
 288        head1=$(git rev-parse --short HEAD) &&
 289        git add submodule &&
 290        git commit -m "new submodule" &&
 291        head2=$(git rev-parse --short HEAD) &&
 292        echo "From $pwd/." > expect.err.2 &&
 293        echo "   $head1..$head2  master     -> origin/master" >> expect.err.2 &&
 294        cat expect.err.sub >> expect.err.2 &&
 295        tail -2 expect.err >> expect.err.2 &&
 296        (
 297                cd downstream &&
 298                git fetch >../actual.out 2>../actual.err
 299        ) &&
 300        test_cmp expect.err.2 actual.err &&
 301        test_cmp expect.out actual.out
 302'
 303
 304test_done