On Sat, Jul 7, 2018 at 1:44 PM Elijah Newren <[email protected]> wrote:
>
> In the case of a file/submodule conflict, although both cannot exist at
> the same path, we expect both to be present somewhere for the user to be
> able to resolve the conflict with. Add a testcase for this.
>
> Signed-off-by: Elijah Newren <[email protected]>
> ---
> t/t7405-submodule-merge.sh | 56 ++++++++++++++++++++++++++++++++++++++
> 1 file changed, 56 insertions(+)
>
> diff --git a/t/t7405-submodule-merge.sh b/t/t7405-submodule-merge.sh
> index 7bfb2f498..95fd05d83 100755
> --- a/t/t7405-submodule-merge.sh
> +++ b/t/t7405-submodule-merge.sh
> @@ -279,4 +279,60 @@ test_expect_success 'recursive merge with submodule' '
> grep "$(cat expect3)" actual > /dev/null)
> '
>
> +# File/submodule conflict
> +# Commit O: <empty>
> +# Commit A: path (submodule)
> +# Commit B: path
> +# Expected: path/ is submodule and file contents for B's path are somewhere
> +
> +test_expect_success 'setup file/submodule conflict' '
> + test_create_repo file-submodule &&
> + (
> + cd file-submodule &&
> +
> + git commit --allow-empty -m O &&
> +
> + git branch A &&
> + git branch B &&
> +
> + git checkout B &&
> + echo contents >path &&
> + git add path &&
> + git commit -m B &&
> +
> + git checkout A &&
> + test_create_repo path &&
> + (
> + cd path &&
> +
> + echo hello >world &&
test_commit -C path &&
or do we need a dirty submodule specifically?
If so what is important, the untracked file or
would changes in the index be sufficient?
> + git add world &&
when observing this one in verbose mode , you may be
asked to use 'git submodule add' instead
https://github.com/git/git/blob/master/builtin/add.c#L323
> + git commit -m "submodule"
Not sure if we'd need the shell it is only test_commit,
the [submodule] add and commit, so maybe we can get away with
3 times -C ?
> +test_expect_failure 'file/submodule conflict' '
Which part fails here?
> + test_when_finished "git -C file-submodule reset --hard" &&
> + (
> + cd file-submodule &&
> +
> + git checkout A^0 &&
> + test_must_fail git merge B^0 >out 2>err &&
> +
> + git ls-files -s >out &&
> + test_line_count = 2 out &&
> + git ls-files -u >out &&
> + test_line_count = 2 out &&
> +
> + # path/ is still a submodule
> + test_path_is_dir path/.git &&
> +
> + echo Checking if contents from B:path showed up anywhere &&
This could be a comment instead?
> + grep -q content * 2>/dev/null
Ah that is why we needed the specific echo above.
Sorry for being dense here, I am not quite following the last part of the test,
as it is unclear what ought to fail in this test.
Thanks,
Stefan