On Fri, Dec 26, 2014 at 6:11 PM, Doug Kelly <[email protected]> wrote:
> git am will break when using diff.submodule=log; add some test cases
> to illustrate this breakage as simply as possible. There are
> currently two ways this can fail:
>
> * With errors ("unrecognized input"), if only change
> * Silently (no submodule change), if other files change
>
> Test for both conditions and ensure without diff.submodule this works.
>
> Signed-off-by: Doug Kelly <[email protected]>
> ---
> diff --git a/t/t4255-am-submodule.sh b/t/t4255-am-submodule.sh
> index 8bde7db..d9a1d79 100755
> --- a/t/t4255-am-submodule.sh
> +++ b/t/t4255-am-submodule.sh
> @@ -18,4 +18,87 @@ am_3way () {
> KNOWN_FAILURE_NOFF_MERGE_ATTEMPTS_TO_MERGE_REMOVED_SUBMODULE_FILES=1
> test_submodule_switch "am_3way"
>
> +test_expect_success 'setup diff.submodule' '
Since the tests are actually expected to fail at this point (before
you've fixed the problem), use test_expect_failure. The follow-up
patch, which fixes the problem, should flip them to
test_expect_success.
> + echo one >one &&
> + git add one &&
> + test_tick &&
> + git commit -m initial &&
Rather than performing these steps manually (here and below), perhaps
test_commit would be suitable and more succinct.
> + git rev-parse HEAD >initial &&
Other scripts in the test suite don't bother with this indirection.
Instead, they assign the variable here, then reference it in
subsequent tests (and no need to redirect to a file).
INITIAL=$(git rev-parse HEAD) &&
> +
> + git init submodule &&
> + (cd submodule &&
> + echo two >two &&
> + git add two &&
> + test_tick &&
> + git commit -m "initial submodule" &&
> + git rev-parse HEAD >../initial-submodule) &&
Style: Format the subshell like this:
(
...commands...
) &&
> + git submodule add ./submodule &&
> + test_tick &&
> + git commit -m first &&
> + git rev-parse HEAD >first &&
Is file 'first' ever used anywhere?
> + (cd submodule &&
> + echo three >three &&
> + git add three &&
> + test_tick &&
> + git commit -m "first submodule" &&
> + git rev-parse HEAD >../first-submodule) &&
> + git add submodule &&
> + test_tick &&
> + git commit -m second &&
> + git rev-parse HEAD >second &&
> +
> + (cd submodule &&
> + git mv two four &&
> + test_tick &&
> + git commit -m "second submodule" &&
> + git rev-parse HEAD >../second-submodule) &&
> + git add submodule &&
> + echo four >four &&
> + git add four &&
> + test_tick &&
> + git commit -m third &&
> + git rev-parse HEAD >third &&
> + git submodule update --init
> +'
> +
> +INITIAL=$(cat initial)
> +SECOND=$(cat second)
> +THIRD=$(cat third)
No need for this extra level of indirection. See above.
> +run_test() {
> + START_COMMIT=$1
> + EXPECT=$2
Although it's not specifically wrong here, someone adding code above
these two lines later on may not notice the broken &&-chain, so it
would be a good idea to keep the &&-chain intact.
> + (git am --abort || true) &&
> + git reset --hard $START_COMMIT &&
> + rm -f *.patch &&
> + git format-patch -1 &&
> + git reset --hard $START_COMMIT^ &&
> + git submodule update &&
> + git am *.patch &&
> + git submodule update &&
> + (cd submodule && git rev-parse HEAD >../actual) &&
> + test_cmp $EXPECT actual
> +}
> +
> +test_expect_success 'diff.submodule unset' '
> + (git config --unset diff.submodule || true) &&
> + run_test $SECOND 'first-submodule'
Note that you're already inside a single-quoted string here, so
'first-submodule' is not quite doing what you expect. Double quotes
would be more appropriate. Or, better, drop the quoting of
first-submodule altogether since it's unnecessary.
> +'
> +
> +test_expect_success 'diff.submodule unset with extra file' '
> + (git config --unset diff.submodule || true) &&
> + run_test $THIRD 'second-submodule'
> +'
> +
> +test_expect_success 'diff.submodule=log' '
> + git config diff.submodule log &&
> + run_test $SECOND 'first-submodule'
> +'
> +
> +test_expect_success 'diff.submodule=log with extra file' '
> + git config diff.submodule log &&
> + run_test $THIRD 'second-submodule'
> +'
> +
> test_done
> --
> 2.0.5
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html