Message ID | bcfde9bc7651266deaa0e5036cebd058dffc12a7.1630359290.git.gitgitgadget@gmail.com (mailing list archive) |
---|---|
State | Superseded |
Headers | show |
Series | Upstreaming the Scalar command | expand |
On Mon, Aug 30 2021, Johannes Schindelin via GitGitGadget wrote: > To test the Scalar command, create a test script in contrib/scalar/t > that is executed as `make -C contrib/scalar test`. Since Scalar has no > meaningful capabilities yet, the only test is rather simple. We will add > more tests in subsequent commits that introduce corresponding, new > functionality. As a comment on 01..03/15: I'd really prefer if we stop using this pattern of sub-Makefile, the dependencies are a pain to manage, and we end up copy/pasting large sets of functionality. That would mean just adding the build of this command to the top-level Makefile behind some "CONTRIB_SCALAR" flag or whatever, but I find that much cleaner than.... > @@ -21,7 +22,7 @@ include ../../config.mak.uname > TARGETS = scalar$(X) scalar.o > GITLIBS = ../../common-main.o ../../libgit.a ../../xdiff/lib.a > > -all: scalar$X > +all: scalar$X ../../bin-wrappers/scalar > > [...] > +../../bin-wrappers/scalar: ../../wrap-for-bin.sh Makefile > [...] > scalar.html: | scalar.1 # prevent them from trying to build `doc.dep` in parallel ...things like this, which refer to assets built by other Makefiles, and need to plaster over the dependency issues... > +++ b/contrib/scalar/t/Makefile > @@ -0,0 +1,78 @@ > +# Run scalar tests > +# > +# Copyright (c) 2005,2021 Junio C Hamano, Johannes Schindelin > +# > + > +-include ../../../config.mak.autogen > +-include ../../../config.mak > + > +SHELL_PATH ?= $(SHELL) > +PERL_PATH ?= /usr/bin/perl > +RM ?= rm -f > +PROVE ?= prove > +DEFAULT_TEST_TARGET ?= test > +TEST_LINT ?= test-lint > + > +ifdef TEST_OUTPUT_DIRECTORY > +TEST_RESULTS_DIRECTORY = $(TEST_OUTPUT_DIRECTORY)/test-results > +else > +TEST_RESULTS_DIRECTORY = ../../../t/test-results > +endif > + > +# Shell quote; > +SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH)) > +PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH)) > +TEST_RESULTS_DIRECTORY_SQ = $(subst ','\'',$(TEST_RESULTS_DIRECTORY)) > + > +T = $(sort $(wildcard t[0-9][0-9][0-9][0-9]-*.sh)) > + > +all: $(DEFAULT_TEST_TARGET) > + > +test: $(TEST_LINT) > + $(MAKE) aggregate-results-and-cleanup > + > +prove: $(TEST_LINT) > + @echo "*** prove ***"; GIT_CONFIG=.git/config $(PROVE) --exec '$(SHELL_PATH_SQ)' $(GIT_PROVE_OPTS) $(T) :: $(GIT_TEST_OPTS) > + $(MAKE) clean-except-prove-cache > + > +$(T): > + @echo "*** $@ ***"; GIT_CONFIG=.git/config '$(SHELL_PATH_SQ)' $@ $(GIT_TEST_OPTS) > + > +clean-except-prove-cache: > + $(RM) -r 'trash directory'.* '$(TEST_RESULTS_DIRECTORY_SQ)' > + $(RM) -r valgrind/bin > + > +clean: clean-except-prove-cache > + $(RM) .prove > + > +test-lint: test-lint-duplicates test-lint-executable test-lint-shell-syntax > + > +test-lint-duplicates: > + @dups=`echo $(T) | tr ' ' '\n' | sed 's/-.*//' | sort | uniq -d` && \ > + test -z "$$dups" || { \ > + echo >&2 "duplicate test numbers:" $$dups; exit 1; } > + > +test-lint-executable: > + @bad=`for i in $(T); do test -x "$$i" || echo $$i; done` && \ > + test -z "$$bad" || { \ > + echo >&2 "non-executable tests:" $$bad; exit 1; } > + > +test-lint-shell-syntax: > + @'$(PERL_PATH_SQ)' ../../../t/check-non-portable-shell.pl $(T) > + > +aggregate-results-and-cleanup: $(T) > + $(MAKE) aggregate-results > + $(MAKE) clean > + > +aggregate-results: > + for f in '$(TEST_RESULTS_DIRECTORY_SQ)'/t*-*.counts; do \ > + echo "$$f"; \ > + done | '$(SHELL_PATH_SQ)' ../../../t/aggregate-results.sh > + > +valgrind: > + $(MAKE) GIT_TEST_OPTS="$(GIT_TEST_OPTS) --valgrind" > + > +test-results: > + mkdir -p test-results > + > +.PHONY: $(T) aggregate-results clean valgrind ...and this entire copy/pasting & adjusting of t/Makefile.
diff --git a/contrib/scalar/Makefile b/contrib/scalar/Makefile index 85c186634e9..8620042f281 100644 --- a/contrib/scalar/Makefile +++ b/contrib/scalar/Makefile @@ -3,6 +3,7 @@ QUIET_SUBDIR1 = ifneq ($(findstring s,$(MAKEFLAGS)),s) ifndef V + QUIET_GEN = @echo ' ' GEN $@; QUIET_SUBDIR0 = +@subdir= QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \ $(MAKE) $(PRINT_DIR) -C $$subdir @@ -21,7 +22,7 @@ include ../../config.mak.uname TARGETS = scalar$(X) scalar.o GITLIBS = ../../common-main.o ../../libgit.a ../../xdiff/lib.a -all: scalar$X +all: scalar$X ../../bin-wrappers/scalar $(GITLIBS): $(QUIET_SUBDIR0)../.. $(QUIET_SUBDIR1) $(subst ../../,,$@) @@ -30,9 +31,19 @@ $(TARGETS): $(GITLIBS) scalar.c $(QUIET_SUBDIR0)../.. $(QUIET_SUBDIR1) $(patsubst %,contrib/scalar/%,$@) clean: - $(RM) $(TARGETS) + $(RM) $(TARGETS) ../../bin-wrappers/scalar $(RM) scalar.1 scalar.html scalar.xml +../../bin-wrappers/scalar: ../../wrap-for-bin.sh Makefile + @mkdir -p ../../bin-wrappers + $(QUIET_GEN)sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \ + -e 's|@@BUILD_DIR@@|$(shell cd ../.. && pwd)|' \ + -e 's|@@PROG@@|contrib/scalar/scalar$(X)|' < $< > $@ && \ + chmod +x $@ + +test: all + $(MAKE) -C t + docs: scalar.html scalar.1 scalar.html: | scalar.1 # prevent them from trying to build `doc.dep` in parallel @@ -43,4 +54,4 @@ scalar.html scalar.1: scalar.txt ../contrib/scalar/$@ $(QUIET)test scalar.1 != "$@" || mv ../../Documentation/$@ . -.PHONY: all clean docs FORCE +.PHONY: all clean docs test FORCE diff --git a/contrib/scalar/t/Makefile b/contrib/scalar/t/Makefile new file mode 100644 index 00000000000..6170672bb37 --- /dev/null +++ b/contrib/scalar/t/Makefile @@ -0,0 +1,78 @@ +# Run scalar tests +# +# Copyright (c) 2005,2021 Junio C Hamano, Johannes Schindelin +# + +-include ../../../config.mak.autogen +-include ../../../config.mak + +SHELL_PATH ?= $(SHELL) +PERL_PATH ?= /usr/bin/perl +RM ?= rm -f +PROVE ?= prove +DEFAULT_TEST_TARGET ?= test +TEST_LINT ?= test-lint + +ifdef TEST_OUTPUT_DIRECTORY +TEST_RESULTS_DIRECTORY = $(TEST_OUTPUT_DIRECTORY)/test-results +else +TEST_RESULTS_DIRECTORY = ../../../t/test-results +endif + +# Shell quote; +SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH)) +PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH)) +TEST_RESULTS_DIRECTORY_SQ = $(subst ','\'',$(TEST_RESULTS_DIRECTORY)) + +T = $(sort $(wildcard t[0-9][0-9][0-9][0-9]-*.sh)) + +all: $(DEFAULT_TEST_TARGET) + +test: $(TEST_LINT) + $(MAKE) aggregate-results-and-cleanup + +prove: $(TEST_LINT) + @echo "*** prove ***"; GIT_CONFIG=.git/config $(PROVE) --exec '$(SHELL_PATH_SQ)' $(GIT_PROVE_OPTS) $(T) :: $(GIT_TEST_OPTS) + $(MAKE) clean-except-prove-cache + +$(T): + @echo "*** $@ ***"; GIT_CONFIG=.git/config '$(SHELL_PATH_SQ)' $@ $(GIT_TEST_OPTS) + +clean-except-prove-cache: + $(RM) -r 'trash directory'.* '$(TEST_RESULTS_DIRECTORY_SQ)' + $(RM) -r valgrind/bin + +clean: clean-except-prove-cache + $(RM) .prove + +test-lint: test-lint-duplicates test-lint-executable test-lint-shell-syntax + +test-lint-duplicates: + @dups=`echo $(T) | tr ' ' '\n' | sed 's/-.*//' | sort | uniq -d` && \ + test -z "$$dups" || { \ + echo >&2 "duplicate test numbers:" $$dups; exit 1; } + +test-lint-executable: + @bad=`for i in $(T); do test -x "$$i" || echo $$i; done` && \ + test -z "$$bad" || { \ + echo >&2 "non-executable tests:" $$bad; exit 1; } + +test-lint-shell-syntax: + @'$(PERL_PATH_SQ)' ../../../t/check-non-portable-shell.pl $(T) + +aggregate-results-and-cleanup: $(T) + $(MAKE) aggregate-results + $(MAKE) clean + +aggregate-results: + for f in '$(TEST_RESULTS_DIRECTORY_SQ)'/t*-*.counts; do \ + echo "$$f"; \ + done | '$(SHELL_PATH_SQ)' ../../../t/aggregate-results.sh + +valgrind: + $(MAKE) GIT_TEST_OPTS="$(GIT_TEST_OPTS) --valgrind" + +test-results: + mkdir -p test-results + +.PHONY: $(T) aggregate-results clean valgrind diff --git a/contrib/scalar/t/t9099-scalar.sh b/contrib/scalar/t/t9099-scalar.sh new file mode 100755 index 00000000000..16f2b72b126 --- /dev/null +++ b/contrib/scalar/t/t9099-scalar.sh @@ -0,0 +1,17 @@ +#!/bin/sh + +test_description='test the `scalar` command' + +TEST_DIRECTORY=$PWD/../../../t +export TEST_DIRECTORY + +# Make it work with --no-bin-wrappers +PATH=$PWD/..:$PATH + +. ../../../t/test-lib.sh + +test_expect_success 'scalar shows a usage' ' + test_expect_code 129 scalar -h +' + +test_done