git-p4.py: fix --prepare-p4-only error with multiple commits
authorBen Keene <seraphire@gmail.com>
Tue, 12 May 2020 13:15:59 +0000 (13:15 +0000)
committerJunio C Hamano <gitster@pobox.com>
Tue, 12 May 2020 19:42:32 +0000 (12:42 -0700)
commit2dfdd705ffd8c6dd1ef75abdfb64e1a08ad35a26
treeade6763b51b34fbe730ab9b1a1e11f135bf14abd
parentd61d20c9b413225793f8a0b491bbbec61c184e26
git-p4.py: fix --prepare-p4-only error with multiple commits

When using git p4 submit with the --prepare-p4-only option, the program
should prepare a single p4 changelist and notify the user that more
commits are pending and then stop processing.

A bug has been introduced by the p4-changelist hook feature that
causes the program to continue to try and process all pending
changelists at the same time.

The function applyCommit returns True when applying the commit
was successful and the program should continue. However, when the
optional flag --prepare-p4-only is set, the program should stop
after the first application.

Change the logic in the run method for P4Submit to check for the
flag --prepare-p4-only after successfully completing the applyCommit
method.

Be aware - this change will fix the existing test error in t9807.23
for --prepare-p4-only. However there is insufficent coverage for
this flag.  If more than 1 commit is pending submission to P4, the
method will properly prepare the P4 changelist, however it will
still exit the application with an exitcode of 1.

The current documentation does not define what the exit code should be
in this condition.
(See: https://git-scm.com/docs/git-p4#Documentation/git-p4.txt---prepare-p4-only)

Signed-off-by: Ben Keene <seraphire@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
git-p4.py