2014-06-19 22:12:54 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
2019-10-12 17:38:29 +02:00
|
|
|
test_description='stash can handle submodules'
|
2014-06-19 22:12:54 +02:00
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
. "$TEST_DIRECTORY"/lib-submodule-update.sh
|
|
|
|
|
|
|
|
git_stash () {
|
|
|
|
git status -su >expect &&
|
|
|
|
ls -1pR * >>expect &&
|
|
|
|
git read-tree -u -m "$1" &&
|
|
|
|
git stash &&
|
|
|
|
git status -su >actual &&
|
|
|
|
ls -1pR * >>actual &&
|
|
|
|
test_cmp expect actual &&
|
|
|
|
git stash apply
|
|
|
|
}
|
|
|
|
|
|
|
|
KNOWN_FAILURE_STASH_DOES_IGNORE_SUBMODULE_CHANGES=1
|
|
|
|
KNOWN_FAILURE_CHERRY_PICK_SEES_EMPTY_COMMIT=1
|
|
|
|
KNOWN_FAILURE_NOFF_MERGE_DOESNT_CREATE_EMPTY_SUBMODULE_DIR=1
|
|
|
|
test_submodule_switch "git_stash"
|
|
|
|
|
2019-10-12 17:38:29 +02:00
|
|
|
setup_basic () {
|
|
|
|
test_when_finished "rm -rf main sub" &&
|
|
|
|
git init sub &&
|
|
|
|
(
|
|
|
|
cd sub &&
|
|
|
|
test_commit sub_file
|
|
|
|
) &&
|
|
|
|
git init main &&
|
|
|
|
(
|
|
|
|
cd main &&
|
|
|
|
git submodule add ../sub &&
|
|
|
|
test_commit main_file
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
test_expect_success 'stash push with submodule.recurse=true preserves dirty submodule worktree' '
|
|
|
|
setup_basic &&
|
|
|
|
(
|
|
|
|
cd main &&
|
|
|
|
git config submodule.recurse true &&
|
|
|
|
echo "x" >main_file.t &&
|
|
|
|
echo "y" >sub/sub_file.t &&
|
|
|
|
git stash push &&
|
|
|
|
test_must_fail git -C sub diff --quiet
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'stash push and pop with submodule.recurse=true preserves dirty submodule worktree' '
|
|
|
|
setup_basic &&
|
|
|
|
(
|
|
|
|
cd main &&
|
|
|
|
git config submodule.recurse true &&
|
|
|
|
echo "x" >main_file.t &&
|
|
|
|
echo "y" >sub/sub_file.t &&
|
|
|
|
git stash push &&
|
|
|
|
git stash pop &&
|
|
|
|
test_must_fail git -C sub diff --quiet
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
2014-06-19 22:12:54 +02:00
|
|
|
test_done
|