diff options
author | Jeff King <peff@peff.net> | 2018-05-02 17:20:35 -0400 |
---|---|---|
committer | Jeff King <peff@peff.net> | 2018-05-21 23:55:12 -0400 |
commit | 1995b5e03e1cc97116be58cdc0502d4a23547856 (patch) | |
tree | 1d482dcd90f29be2e5758dc3aa1c5dc4eec479d3 | |
parent | fsck: check .gitmodules content (diff) | |
download | tgif-1995b5e03e1cc97116be58cdc0502d4a23547856.tar.xz |
fsck: call fsck_finish() after fscking objects
Now that the internal fsck code is capable of checking
.gitmodules files, we just need to teach its callers to use
the "finish" function to check any queued objects.
With this, we can now catch the malicious case in t7415 with
git-fsck.
Signed-off-by: Jeff King <peff@peff.net>
-rw-r--r-- | builtin/fsck.c | 3 | ||||
-rwxr-xr-x | t/t7415-submodule-names.sh | 4 |
2 files changed, 7 insertions, 0 deletions
diff --git a/builtin/fsck.c b/builtin/fsck.c index f91d5f360d..028aba52eb 100644 --- a/builtin/fsck.c +++ b/builtin/fsck.c @@ -748,6 +748,9 @@ int cmd_fsck(int argc, const char **argv, const char *prefix) } stop_progress(&progress); } + + if (fsck_finish(&fsck_obj_options)) + errors_found |= ERROR_OBJECT; } for (i = 0; i < argc; i++) { diff --git a/t/t7415-submodule-names.sh b/t/t7415-submodule-names.sh index 75fa071c6d..c8ce2f4717 100755 --- a/t/t7415-submodule-names.sh +++ b/t/t7415-submodule-names.sh @@ -73,4 +73,8 @@ test_expect_success 'clone evil superproject' ' ! grep "RUNNING POST CHECKOUT" output ' +test_expect_success 'fsck detects evil superproject' ' + test_must_fail git fsck +' + test_done |