clone: treat "checking connectivity" like other progress
authorJeff King <peff@peff.net>
Wed, 18 Sep 2013 20:06:50 +0000 (16:06 -0400)
committerJunio C Hamano <gitster@pobox.com>
Wed, 18 Sep 2013 20:34:46 +0000 (13:34 -0700)
When stderr does not point to a tty, we typically suppress
"we are now in this phase" progress reporting (e.g., we ask
the server not to send us "counting objects" and the like).

The new "checking connectivity" message is in the same vein,
and should be suppressed. Since clone relies on the
transport code to make the decision, we can simply sneak a
peek at the "progress" field of the transport struct. That
properly takes into account both the verbosity and progress
options we were given, as well as the result of isatty().

Note that we do not set up that progress flag for a local
clone, as we do not fetch using the transport at all. That's
acceptable here, though, because we also do not perform a
connectivity check in that case.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/clone.c
t/t5702-clone-options.sh
index 42c40f2bfdef5f8c322e550eac81c3ac4dcc0384..72cc40a1cc51816b6e10536e2f5e5ecdd5351f16 100644 (file)
@@ -551,12 +551,12 @@ static void update_remote_refs(const struct ref *refs,
        const struct ref *rm = mapped_refs;
 
        if (check_connectivity) {
-               if (0 <= option_verbosity)
+               if (transport->progress)
                        fprintf(stderr, _("Checking connectivity... "));
                if (check_everything_connected_with_transport(iterate_ref_map,
                                                              0, &rm, transport))
                        die(_("remote did not send all necessary objects"));
-               if (0 <= option_verbosity)
+               if (transport->progress)
                        fprintf(stderr, _("done\n"));
        }
 
index d3dbdfe0699c4ad590263d157ad22d7bfed6b8f5..9e24ec88e67f0db8be401f2a60f69c408f39fc02 100755 (executable)
@@ -22,7 +22,8 @@ test_expect_success 'clone -o' '
 test_expect_success 'redirected clone does not show progress' '
 
        git clone "file://$(pwd)/parent" clone-redirected >out 2>err &&
-       ! grep % err
+       ! grep % err &&
+       test_i18ngrep ! "Checking connectivity" err
 
 '