From: Johannes Schindelin <Johannes.Schindelin@gmx.de>
To: "Đoàn Trần Công Danh" <congdanhqx@gmail.com>
Cc: git@vger.kernel.org
Subject: Re: [PATCH] t6300: don't run cat-file on non-existent object
Date: Tue, 17 Aug 2021 23:44:35 +0200 (CEST) [thread overview]
Message-ID: <nycvar.QRO.7.76.6.2108172339080.55@tvgsbejvaqbjf.bet> (raw)
In-Reply-To: <bcbde2e7364865ac16702447b863b8a725670428.1629200841.git.congdanhqx@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 3183 bytes --]
Hi Danh,
On Tue, 17 Aug 2021, Đoàn Trần Công Danh wrote:
> In t6300, some tests are guarded behind some prerequisites.
> Thus, objects created by those tests ain't available if those
> prerequisites is unsatistified. Attempting to run "cat-file"
> on those objects will run into failure.
>
> In fact, running t6300 in an environment without gpg(1),
> we'll see those warnings:
>
> fatal: Not a valid object name refs/tags/signed-empty
> fatal: Not a valid object name refs/tags/signed-short
> fatal: Not a valid object name refs/tags/signed-long
>
> Let's put those commands into the real tests, in order to:
>
> * skip their execution if prerequisites aren't satistified.
> * check their exit status code
>
> Signed-off-by: Đoàn Trần Công Danh <congdanhqx@gmail.com>
Makes sense.
> ---
> t/t6300-for-each-ref.sh | 27 ++++++++++++++++-----------
> 1 file changed, 16 insertions(+), 11 deletions(-)
>
> diff --git a/t/t6300-for-each-ref.sh b/t/t6300-for-each-ref.sh
> index 9e0214076b..65fbed2bef 100755
> --- a/t/t6300-for-each-ref.sh
> +++ b/t/t6300-for-each-ref.sh
> @@ -59,18 +59,23 @@ test_atom() {
> # Automatically test "contents:size" atom after testing "contents"
> if test "$2" = "contents"
> then
> - case $(git cat-file -t "$ref") in
> - tag)
> - # We cannot use $3 as it expects sanitize_pgp to run
> - expect=$(git cat-file tag $ref | tail -n +6 | wc -c) ;;
Here, we pipe the output of `cat-file` to `tail` and then `wc`. But below:
> - tree | blob)
> - expect='' ;;
> - commit)
> - expect=$(printf '%s' "$3" | wc -c) ;;
> - esac
> - # Leave $expect unquoted to lose possible leading whitespaces
> - echo $expect >expected
> + expect=$(printf '%s' "$3" | wc -c)
> test_expect_${4:-success} $PREREQ "basic atom: $1 contents:size" '
> + type=$(git cat-file -t "$ref") &&
> + case $type in
> + tag)
> + # We cannot use $3 as it expects sanitize_pgp to run
> + git cat-file tag $ref >out &&
> + expect=$(<out tail -n +6 | wc -c) ;;
... we break the _first_ pipe apart, redirecting into `out` instead. I am
not sure that this patch should change that as it does, I would think that
a regular code move (with re-indentation) would be preferable.
Besides, while it is legal and works, I don't think we ever start with the
redirection. Read: it should probably be `tail -n +6 <out` instead.
> + tree | blob)
> + expect="" ;;
> + commit)
> + : "use the calculated expect" ;;
This necessarily has to be different from the original code (i.e. the code
could not have been moved verbatim) because it uses `$3`, which at this
point has a different value.
My suggestion: mention this in the commit message, other reviewers or
future readers might stumble over this otherwise.
> + *)
> + BUG "unknown object type" ;;
This one is new. Do we need it?
Thanks,
Dscho
> + esac &&
> + # Leave $expect unquoted to lose possible leading whitespaces
> + echo $expect >expected &&
> git for-each-ref --format="%(contents:size)" "$ref" >actual &&
> test_cmp expected actual
> '
> --
> 2.33.0
>
>
next prev parent reply other threads:[~2021-08-17 21:44 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-08-17 11:48 [PATCH] t6300: don't run cat-file on non-existent object Đoàn Trần Công Danh
2021-08-17 21:44 ` Johannes Schindelin [this message]
2021-08-18 5:19 ` [PATCH v2 0/2] t6300: clear warning when running without gpg Đoàn Trần Công Danh
2021-08-18 5:19 ` [PATCH v2 1/2] t6300: don't run cat-file on non-existent object Đoàn Trần Công Danh
2021-08-19 20:16 ` Junio C Hamano
2021-08-18 5:19 ` [PATCH v2 2/2] t6300: check for cat-file exit status code Đoàn Trần Công Danh
2021-08-19 20:19 ` Junio C Hamano
2021-08-18 10:33 ` [PATCH v2 0/2] t6300: clear warning when running without gpg Johannes Schindelin
2021-08-21 1:36 ` [PATCH v3 " Đoàn Trần Công Danh
2021-08-21 1:36 ` [PATCH v3 1/2] t6300: don't run cat-file on non-existent object Đoàn Trần Công Danh
2021-08-21 1:36 ` [PATCH v3 2/2] t6300: check for cat-file exit status code Đoàn Trần Công Danh
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
List information: http://vger.kernel.org/majordomo-info.html
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=nycvar.QRO.7.76.6.2108172339080.55@tvgsbejvaqbjf.bet \
--to=johannes.schindelin@gmx.de \
--cc=congdanhqx@gmail.com \
--cc=git@vger.kernel.org \
/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.
Code repositories for project(s) associated with this public inbox
https://80x24.org/mirrors/git.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).