| #!/bin/sh |
| |
| test_description='Test with test-tool submodule is-active |
| |
| This test verifies that `test-tool submodule is-active` correctly identifies |
| submodules which are "active" and interesting to the user. |
| |
| This is a unit test of the submodule.c is_submodule_active() function, |
| which is also indirectly tested elsewhere. |
| ' |
| |
| TEST_PASSES_SANITIZE_LEAK=true |
| . ./test-lib.sh |
| |
| test_expect_success 'setup' ' |
| git config --global protocol.file.allow always && |
| git init sub && |
| test_commit -C sub initial && |
| git init super && |
| test_commit -C super initial && |
| git -C super submodule add ../sub sub1 && |
| git -C super submodule add ../sub sub2 && |
| |
| # Remove submodule.<name>.active entries in order to test in an |
| # environment where only URLs are present in the conifg |
| git -C super config --unset submodule.sub1.active && |
| git -C super config --unset submodule.sub2.active && |
| |
| git -C super commit -a -m "add 2 submodules at sub{1,2}" |
| ' |
| |
| test_expect_success 'is-active works with urls' ' |
| test-tool -C super submodule is-active sub1 && |
| test-tool -C super submodule is-active sub2 && |
| |
| git -C super config --unset submodule.sub1.URL && |
| test_must_fail test-tool -C super submodule is-active sub1 && |
| git -C super config submodule.sub1.URL ../sub && |
| test-tool -C super submodule is-active sub1 |
| ' |
| |
| test_expect_success 'is-active works with submodule.<name>.active config' ' |
| test_when_finished "git -C super config --unset submodule.sub1.active" && |
| test_when_finished "git -C super config submodule.sub1.URL ../sub" && |
| |
| git -C super config --bool submodule.sub1.active "false" && |
| test_must_fail test-tool -C super submodule is-active sub1 && |
| |
| git -C super config --bool submodule.sub1.active "true" && |
| git -C super config --unset submodule.sub1.URL && |
| test-tool -C super submodule is-active sub1 |
| ' |
| |
| test_expect_success 'is-active handles submodule.active config missing a value' ' |
| cp super/.git/config super/.git/config.orig && |
| test_when_finished mv super/.git/config.orig super/.git/config && |
| |
| cat >>super/.git/config <<-\EOF && |
| [submodule] |
| active |
| EOF |
| |
| cat >expect <<-\EOF && |
| error: missing value for '\''submodule.active'\'' |
| EOF |
| test-tool -C super submodule is-active sub1 2>actual && |
| test_cmp expect actual |
| ' |
| |
| test_expect_success 'is-active works with basic submodule.active config' ' |
| test_when_finished "git -C super config submodule.sub1.URL ../sub" && |
| test_when_finished "git -C super config --unset-all submodule.active" && |
| |
| git -C super config --add submodule.active "." && |
| git -C super config --unset submodule.sub1.URL && |
| |
| test-tool -C super submodule is-active sub1 && |
| test-tool -C super submodule is-active sub2 |
| ' |
| |
| test_expect_success 'is-active correctly works with paths that are not submodules' ' |
| test_when_finished "git -C super config --unset-all submodule.active" && |
| |
| test_must_fail test-tool -C super submodule is-active not-a-submodule && |
| |
| git -C super config --add submodule.active "." && |
| test_must_fail test-tool -C super submodule is-active not-a-submodule |
| ' |
| |
| test_expect_success 'is-active works with exclusions in submodule.active config' ' |
| test_when_finished "git -C super config --unset-all submodule.active" && |
| |
| git -C super config --add submodule.active "." && |
| git -C super config --add submodule.active ":(exclude)sub1" && |
| |
| test_must_fail test-tool -C super submodule is-active sub1 && |
| test-tool -C super submodule is-active sub2 |
| ' |
| |
| test_expect_success 'is-active with submodule.active and submodule.<name>.active' ' |
| test_when_finished "git -C super config --unset-all submodule.active" && |
| test_when_finished "git -C super config --unset submodule.sub1.active" && |
| test_when_finished "git -C super config --unset submodule.sub2.active" && |
| |
| git -C super config --add submodule.active "sub1" && |
| git -C super config --bool submodule.sub1.active "false" && |
| git -C super config --bool submodule.sub2.active "true" && |
| |
| test_must_fail test-tool -C super submodule is-active sub1 && |
| test-tool -C super submodule is-active sub2 |
| ' |
| |
| test_expect_success 'is-active, submodule.active and submodule add' ' |
| test_when_finished "rm -rf super2" && |
| git init super2 && |
| test_commit -C super2 initial && |
| git -C super2 config --add submodule.active "sub*" && |
| |
| # submodule add should only add submodule.<name>.active |
| # to the config if not matched by the pathspec |
| git -C super2 submodule add ../sub sub1 && |
| test_must_fail git -C super2 config --get submodule.sub1.active && |
| |
| git -C super2 submodule add ../sub mod && |
| git -C super2 config --get submodule.mod.active |
| ' |
| |
| test_done |