On Tue, 22 Jan 2019 at 20:07, Junio C Hamano <gitster@xxxxxxxxx> wrote: > > Martin Ågren <martin.agren@xxxxxxxxx> writes: > > >> + echo 11 | git commit-tree --gpg-sign HEAD^{tree} >oid && > >> + test_line_count = 1 oid && > >> + git tag eleventh-signed $(cat oid) && > >> +... > > Let's see if there any opinions from others about this more verbose > > construction, vs placing the oid in a variable and quoting it. We > > obviously went several years without realizing that using $(...) as an > > object id risked falling back to HEAD and that a completely broken `git > > commit-tree -S` would pass the test. So being over-careful and extra > > obvious might very well be the right thing. > > Sorry, but I am not sure what issue you are worried about. If the > "commit-tree" command failed in this construct: > > oid=$(echo 11 | git commit-tree ...) && > git tag eleventh-signed "$oid" > > wouldn't the &&-chain break after the assignment of an empty string > to oid, skip "git tag" and make the whole test fail, with or without > '$oid" fed to "git tag" quoted? Yes. > It is wrong not to quote "$oid" for > the "git tag" command (the test should not rely on the fact that the > object names given by "git commit-tree" have no $IFS in them), but > that is a separate issue. It'd also protect against a failure mode where we get no output and a zero exit code. (Maybe that's ridiculous, but we're testing `git commit-tree -S` here -- plus, I'm lazy, so I'd rather double-quote than think. ;-) ) But you asked me what issue I worried about... To recap, master has a test with a one-liner that doesn't bark if you completely drop the implementation of `git commit-tree -S`. I don't think that's the worrying that you're puzzled about. I posted a three-line replacement that verified the exit code and quotes the output, but which also has a pretty paranoid middle step to verify that there was precisely one line of output. I then followed up with a less paranoid two-liner, which avoids some round-tripping, and which doesn't verify the line count, but which rather assumes that `git tag` will bark on a bad oid. I think that last thing is a fair assumption, and that's why I referred to the three-line test as being over-careful and extra obvious. I'm not worrying about the quoting as such. Martin