t / t7411-submodule-config.shon commit notes: allow merging from arbitrary references (b3715b7)
   1#!/bin/sh
   2#
   3# Copyright (c) 2014 Heiko Voigt
   4#
   5
   6test_description='Test submodules config cache infrastructure
   7
   8This test verifies that parsing .gitmodules configurations directly
   9from the database and from the worktree works.
  10'
  11
  12TEST_NO_CREATE_REPO=1
  13. ./test-lib.sh
  14
  15test_expect_success 'submodule config cache setup' '
  16        mkdir submodule &&
  17        (cd submodule &&
  18                git init &&
  19                echo a >a &&
  20                git add . &&
  21                git commit -ma
  22        ) &&
  23        mkdir super &&
  24        (cd super &&
  25                git init &&
  26                git submodule add ../submodule &&
  27                git submodule add ../submodule a &&
  28                git commit -m "add as submodule and as a" &&
  29                git mv a b &&
  30                git commit -m "move a to b"
  31        )
  32'
  33
  34cat >super/expect <<EOF
  35Submodule name: 'a' for path 'a'
  36Submodule name: 'a' for path 'b'
  37Submodule name: 'submodule' for path 'submodule'
  38Submodule name: 'submodule' for path 'submodule'
  39EOF
  40
  41test_expect_success 'test parsing and lookup of submodule config by path' '
  42        (cd super &&
  43                test-submodule-config \
  44                        HEAD^ a \
  45                        HEAD b \
  46                        HEAD^ submodule \
  47                        HEAD submodule \
  48                                >actual &&
  49                test_cmp expect actual
  50        )
  51'
  52
  53test_expect_success 'test parsing and lookup of submodule config by name' '
  54        (cd super &&
  55                test-submodule-config --name \
  56                        HEAD^ a \
  57                        HEAD a \
  58                        HEAD^ submodule \
  59                        HEAD submodule \
  60                                >actual &&
  61                test_cmp expect actual
  62        )
  63'
  64
  65cat >super/expect_error <<EOF
  66Submodule name: 'a' for path 'b'
  67Submodule name: 'submodule' for path 'submodule'
  68EOF
  69
  70test_expect_success 'error in one submodule config lets continue' '
  71        (cd super &&
  72                cp .gitmodules .gitmodules.bak &&
  73                echo "  value = \"" >>.gitmodules &&
  74                git add .gitmodules &&
  75                mv .gitmodules.bak .gitmodules &&
  76                git commit -m "add error" &&
  77                test-submodule-config \
  78                        HEAD b \
  79                        HEAD submodule \
  80                                >actual &&
  81                test_cmp expect_error actual
  82        )
  83'
  84
  85cat >super/expect_url <<EOF
  86Submodule url: 'git@somewhere.else.net:a.git' for path 'b'
  87Submodule url: 'git@somewhere.else.net:submodule.git' for path 'submodule'
  88EOF
  89
  90cat >super/expect_local_path <<EOF
  91Submodule name: 'a' for path 'c'
  92Submodule name: 'submodule' for path 'submodule'
  93EOF
  94
  95test_expect_success 'reading of local configuration' '
  96        (cd super &&
  97                old_a=$(git config submodule.a.url) &&
  98                old_submodule=$(git config submodule.submodule.url) &&
  99                git config submodule.a.url git@somewhere.else.net:a.git &&
 100                git config submodule.submodule.url git@somewhere.else.net:submodule.git &&
 101                test-submodule-config --url \
 102                        "" b \
 103                        "" submodule \
 104                                >actual &&
 105                test_cmp expect_url actual &&
 106                git config submodule.a.path c &&
 107                test-submodule-config \
 108                        "" c \
 109                        "" submodule \
 110                                >actual &&
 111                test_cmp expect_local_path actual &&
 112                git config submodule.a.url $old_a &&
 113                git config submodule.submodule.url $old_submodule &&
 114                git config --unset submodule.a.path c
 115        )
 116'
 117
 118cat >super/expect_fetchrecurse_die.err <<EOF
 119fatal: bad submodule.submodule.fetchrecursesubmodules argument: blabla
 120EOF
 121
 122test_expect_success 'local error in fetchrecursesubmodule dies early' '
 123        (cd super &&
 124                git config submodule.submodule.fetchrecursesubmodules blabla &&
 125                test_must_fail test-submodule-config \
 126                        "" b \
 127                        "" submodule \
 128                                >actual.out 2>actual.err &&
 129                touch expect_fetchrecurse_die.out &&
 130                test_cmp expect_fetchrecurse_die.out actual.out  &&
 131                test_cmp expect_fetchrecurse_die.err actual.err  &&
 132                git config --unset submodule.submodule.fetchrecursesubmodules
 133        )
 134'
 135
 136test_expect_success 'error in history in fetchrecursesubmodule lets continue' '
 137        (cd super &&
 138                git config -f .gitmodules \
 139                        submodule.submodule.fetchrecursesubmodules blabla &&
 140                git add .gitmodules &&
 141                git config --unset -f .gitmodules \
 142                        submodule.submodule.fetchrecursesubmodules &&
 143                git commit -m "add error in fetchrecursesubmodules" &&
 144                test-submodule-config \
 145                        HEAD b \
 146                        HEAD submodule \
 147                                >actual &&
 148                test_cmp expect_error actual  &&
 149                git reset --hard HEAD^
 150        )
 151'
 152
 153test_done