diff options
author | Johannes Schindelin <johannes.schindelin@gmx.de> | 2024-04-24 18:14:58 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2024-04-24 19:46:03 +0200 |
commit | 12c2ee5fbd1ab0f0fcf7ca37c613d438db52821d (patch) | |
tree | ddd4b4151cd79658849e1a0bc5ebbf3caf984d79 /t/t0068-for-each-repo.sh | |
parent | Git 2.44 (diff) | |
download | git-12c2ee5fbd1ab0f0fcf7ca37c613d438db52821d.tar.xz git-12c2ee5fbd1ab0f0fcf7ca37c613d438db52821d.zip |
for-each-repo: optionally keep going on an error
In https://github.com/microsoft/git/issues/623, it was reported that
the regularly scheduled maintenance stops if one repo in the middle of
the list was found to be missing.
This is undesirable, and points out a gap in the design of `git
for-each-repo`: We need a mode where that command does not stop on an
error, but continues to try running the specified command with the other
repositories.
Imitating the `--keep-going` option of GNU make, this commit teaches
`for-each-repo` the same trick: to continue with the operation on all
the remaining repositories in case there was a problem with one
repository, still setting the exit code to indicate an error occurred.
Helped-by: Eric Sunshine <sunshine@sunshineco.com>
Helped-by: Patrick Steinhardt <ps@pks.im>
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rwxr-xr-x | t/t0068-for-each-repo.sh | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/t/t0068-for-each-repo.sh b/t/t0068-for-each-repo.sh index 4b90b74d5d..95019e01ed 100755 --- a/t/t0068-for-each-repo.sh +++ b/t/t0068-for-each-repo.sh @@ -59,4 +59,20 @@ test_expect_success 'error on NULL value for config keys' ' test_cmp expect actual ' +test_expect_success '--keep-going' ' + git config keep.going non-existing && + git config --add keep.going . && + + test_must_fail git for-each-repo --config=keep.going \ + -- branch >out 2>err && + test_grep "cannot change to .*non-existing" err && + test_must_be_empty out && + + test_must_fail git for-each-repo --config=keep.going --keep-going \ + -- branch >out 2>err && + test_grep "cannot change to .*non-existing" err && + git branch >expect && + test_cmp expect out +' + test_done |