On Mon, Dec 11, 2017 at 12:37:42PM -0800, Junio C Hamano wrote: > > Interestingly, many of those do something like this in the Makefile: > > > > ifdef GIT_TEST_CMP > > @echo GIT_TEST_OPTS=... >>$@+ > > endif > > > > which seems utterly confusing to me. Because it means that if you build > > with those options set, then they will override anything in the > > environment. But if you don't, then you _may_ override them in the > > environment. In other words: > > > > make > > cd t > > GIT_TEST_CMP=foo ./t0000-* > > > > will respect that variable. But: > > > > make GIT_TEST_CMP=foo > > cd t > > GIT_TEST_CMP=bar ./t0000-* > > > > will not. Which seems weird. But I guess we could follow that pattern > > with TEST_SHELL_PATH. > > Or perhaps we can start setting a better example with the new > variable, and migrate those weird existing ones over to the new way > of not forbidding run-time overriding? This turns out to be quite tricky, because GIT-BUILD-OPTIONS must be parsed as both a Makefile and shell-script. So we can do: 1. Omit them from GIT-BUILD-OPTIONS, which means they don't work for cases where the tests aren't started from the Makefile (which would have put them in the environment). I think this is a non-starter. 2. Add a Makefile-level ifdef when generating GIT-BUILD-OPTIONS, so that unused options can be overridden by the environment That's the "weird" thing above that we do now for some variables. 3. Add something like: test -z "$FOO" && FOO=... when building GIT-BUILD-OPTIONS (instead of just FOO=...). But that doesn't work because it must parse as Makefile. 4. In test-lib.sh, save and restore each such variable so that the existing environment takes precedence. Like: FOO_save=$FOO BAR_save=$BAR ...etc for each... . GIT-BUILD-OPTIONS test -n "$FOO_save" && FOO=$FOO_save test -n "$BAR_save" && BAR=$BAR_save ...etc... We have to do the save/restore dance rather than just reordering the assignments, because the existing environment is being passed into us (so we can't just "assign" it to overwrite what's in the build options file). This could be made slightly less tedious with a loop and an eval. It could possibly be made very succinct but very magical with something like: saved=$(export) . GIT-BUILD-OPTIONS eval "$saved" 5. Give up on the dual nature of GIT-BUILD-OPTIONS, and generate two such files (with identical values but different syntax). I think (4) and (5) are the only things that actually change the behavior in a meaningful way. But they're a bit more hacky and repetitive than I'd like. Especially given that I'm not really sure we're solving an interesting problem. I'm happy enough with the patch as shown, and I do not recall anybody complaining about the current behavior of these options. > There is a long outstanding NEEDSWORK comment in help.c that wonders > if we want to embed contents from GIT-BUILD-OPTIONS in the resulting > binary, and the distinction Dscho brought up between "build" and > "test" phases would start to matter even more once we go in that > direction. I guess you're implying having a GIT-BUILD-OPTIONS and a GIT-TEST-OPTIONS here. But that doesn't save us from the Makefile/shell duality, unfortunately. Some of the test options need to be read by t/Makefile, and some need to be read by test-lib.sh (and I suspect there are some needed in both places). -Peff