All of lore.kernel.org
 help / color / mirror / Atom feed
From: Daniel Hahler <genml+git-2014@thequod.de>
To: David Aguilar <davvid@gmail.com>, Junio C Hamano <gitster@pobox.com>
Cc: git@vger.kernel.org
Subject: git: regression with mergetool and answering "n" (backport fix / add tests)
Date: Tue, 23 Dec 2014 20:08:34 +0100	[thread overview]
Message-ID: <5499BDB2.4070301@thequod.de> (raw)

[-- Attachment #1: Type: text/plain, Size: 3826 bytes --]

Hi,

this is in reply to the commits from David:

    commit 0ddedd4d6b9b3e8eb3557d8ed28e1a0b354a25f8
    Refs: v2.2.0-60-g0ddedd4
    Merge: e886efd 1e86d5b
    Author:     Junio C Hamano <gitster@pobox.com>
    AuthorDate: Fri Dec 12 14:31:39 2014 -0800
    Commit:     Junio C Hamano <gitster@pobox.com>
    CommitDate: Fri Dec 12 14:31:39 2014 -0800

        Merge branch 'da/difftool-mergetool-simplify-reporting-status'

        Code simplification.

        * da/difftool-mergetool-simplify-reporting-status:
          mergetools: stop setting $status in merge_cmd()
          mergetool: simplify conditionals
          difftool--helper: add explicit exit statement
          mergetool--lib: remove use of $status global
          mergetool--lib: remove no-op assignment to $status from setup_user_tool

I've ran into a problem, where "git mergetool" (using vimdiff) would add
the changes to the index, although you'd answered "n" after not changing/saving
the merged file.

This regression has been introduced in:

    commit 99474b6340dbcbe58f6c256fdee231cbadb060f4
    Author: David Aguilar <davvid@gmail.com>
    Date:   Fri Nov 14 13:33:55 2014 -0800

        difftool: honor --trust-exit-code for builtin tools
        
        run_merge_tool() was not setting $status, which prevented the
        exit code for builtin tools from being forwarded to the caller.
        
        Capture the exit status and add a test to guarantee the behavior.
        
        Reported-by: Adria Farres <14farresa@gmail.com>
        Signed-off-by: David Aguilar <davvid@gmail.com>
        Signed-off-by: Junio C Hamano <gitster@pobox.com>

    diff --git a/git-mergetool--lib.sh b/git-mergetool--lib.sh
    index c45a020..cce4f8c 100644
    --- a/git-mergetool--lib.sh
    +++ b/git-mergetool--lib.sh
    @@ -221,6 +221,7 @@ run_merge_tool () {
            else
                    run_diff_cmd "$1"
            fi
    +       status=$?
            return $status
     }


My fix has been the following, but I agree that the changes from David
are much better in general.

    diff --git a/git-mergetool--lib.sh b/git-mergetool--lib.sh
    index cce4f8c..fa9acb1 100644
    --- a/git-mergetool--lib.sh
    +++ b/git-mergetool--lib.sh
    @@ -105,6 +105,7 @@ check_unchanged () {
                            esac
                    done
            fi
    +       return $status
     }
     
     valid_tool () {

I haven't verified if it really fixes the regression, but if it does it
should get backported into the branches where the regression is present.


Also, there should be some tests for this. I've came up with the
following, which is not finished and left in a state of debugging why it
did not trigger the bug.

In t/t7610-mergetool.sh:

  test_expect_success 'return code with untrusted mergetool' '
      # git config merge.tool untrusted &&
      # git config mergetool.untrusted.cmd "true" &&
      # git config mergetool.untrusted.trustExitCode false &&
          test_config mergetool.vimdiff.cmd "cat \"\$REMOTE\"" &&
      git config merge.tool vimdiff &&
      git config --get-regexp mergetool.
      git config --get-regexp merge\.tool.

      git checkout -b test_untrusted branch1 &&
      test_must_fail git merge master >/dev/null 2>&1 &&
      git status -s &&
      test "$(git status --short both)" = "AA both" &&
      ( echo "n" | test_must_fail git mergetool both ) &&
      git status -s &&

      test "$(git status --short both)" = "AA both" &&
      ( echo "y" | git mergetool both ) &&
      git status -s &&
      test "$(git status --short both)" = "M  both" &&
      git reset --hard &&
      git config merge.tool mytool


Cheers,
Daniel.

-- 
http://daniel.hahler.de/



[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 173 bytes --]

             reply	other threads:[~2014-12-23 19:08 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-12-23 19:08 Daniel Hahler [this message]
2014-12-26  1:00 ` git: regression with mergetool and answering "n" (backport fix / add tests) David Aguilar
2014-12-26  1:12   ` Daniel Hahler
2015-01-23 13:19     ` Daniel Hahler

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=5499BDB2.4070301@thequod.de \
    --to=genml+git-2014@thequod.de \
    --cc=davvid@gmail.com \
    --cc=git@vger.kernel.org \
    --cc=gitster@pobox.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.