Merge branch 'dg/subtree-test-cleanup'
Test cleanups for the subtree project. * dg/subtree-test-cleanup: contrib/subtree: Handle '--prefix' argument with a slash appended contrib/subtree: Make each test self-contained contrib/subtree: Add split tests contrib/subtree: Add merge tests contrib/subtree: Add tests for subtree add contrib/subtree: Add test for missing subtree contrib/subtree: Clean and refactor test code
This commit is contained in:
commit
30fe9b2f9a
@ -90,7 +90,7 @@ while [ $# -gt 0 ]; do
|
|||||||
--annotate) annotate="$1"; shift ;;
|
--annotate) annotate="$1"; shift ;;
|
||||||
--no-annotate) annotate= ;;
|
--no-annotate) annotate= ;;
|
||||||
-b) branch="$1"; shift ;;
|
-b) branch="$1"; shift ;;
|
||||||
-P) prefix="$1"; shift ;;
|
-P) prefix="${1%/}"; shift ;;
|
||||||
-m) message="$1"; shift ;;
|
-m) message="$1"; shift ;;
|
||||||
--no-prefix) prefix= ;;
|
--no-prefix) prefix= ;;
|
||||||
--onto) onto="$1"; shift ;;
|
--onto) onto="$1"; shift ;;
|
||||||
|
@ -13,11 +13,23 @@ TAR ?= $(TAR)
|
|||||||
RM ?= rm -f
|
RM ?= rm -f
|
||||||
PROVE ?= prove
|
PROVE ?= prove
|
||||||
DEFAULT_TEST_TARGET ?= test
|
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 quote;
|
||||||
SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
|
SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
|
||||||
|
PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH))
|
||||||
|
TEST_RESULTS_DIRECTORY_SQ = $(subst ','\'',$(TEST_RESULTS_DIRECTORY))
|
||||||
|
|
||||||
T = $(wildcard t[0-9][0-9][0-9][0-9]-*.sh)
|
T = $(sort $(wildcard t[0-9][0-9][0-9][0-9]-*.sh))
|
||||||
|
TSVN = $(sort $(wildcard t91[0-9][0-9]-*.sh))
|
||||||
|
TGITWEB = $(sort $(wildcard t95[0-9][0-9]-*.sh))
|
||||||
|
THELPERS = $(sort $(filter-out $(T),$(wildcard *.sh)))
|
||||||
|
|
||||||
all: $(DEFAULT_TEST_TARGET)
|
all: $(DEFAULT_TEST_TARGET)
|
||||||
|
|
||||||
@ -26,20 +38,22 @@ test: pre-clean $(TEST_LINT)
|
|||||||
|
|
||||||
prove: pre-clean $(TEST_LINT)
|
prove: pre-clean $(TEST_LINT)
|
||||||
@echo "*** prove ***"; GIT_CONFIG=.git/config $(PROVE) --exec '$(SHELL_PATH_SQ)' $(GIT_PROVE_OPTS) $(T) :: $(GIT_TEST_OPTS)
|
@echo "*** prove ***"; GIT_CONFIG=.git/config $(PROVE) --exec '$(SHELL_PATH_SQ)' $(GIT_PROVE_OPTS) $(T) :: $(GIT_TEST_OPTS)
|
||||||
$(MAKE) clean
|
$(MAKE) clean-except-prove-cache
|
||||||
|
|
||||||
$(T):
|
$(T):
|
||||||
@echo "*** $@ ***"; GIT_CONFIG=.git/config '$(SHELL_PATH_SQ)' $@ $(GIT_TEST_OPTS)
|
@echo "*** $@ ***"; GIT_CONFIG=.git/config '$(SHELL_PATH_SQ)' $@ $(GIT_TEST_OPTS)
|
||||||
|
|
||||||
pre-clean:
|
pre-clean:
|
||||||
$(RM) -r test-results
|
$(RM) -r '$(TEST_RESULTS_DIRECTORY_SQ)'
|
||||||
|
|
||||||
clean:
|
clean-except-prove-cache:
|
||||||
$(RM) -r 'trash directory'.* test-results
|
$(RM) -r 'trash directory'.* '$(TEST_RESULTS_DIRECTORY_SQ)'
|
||||||
$(RM) -r valgrind/bin
|
$(RM) -r valgrind/bin
|
||||||
|
|
||||||
|
clean: clean-except-prove-cache
|
||||||
$(RM) .prove
|
$(RM) .prove
|
||||||
|
|
||||||
test-lint: test-lint-duplicates test-lint-executable
|
test-lint: test-lint-duplicates test-lint-executable test-lint-shell-syntax
|
||||||
|
|
||||||
test-lint-duplicates:
|
test-lint-duplicates:
|
||||||
@dups=`echo $(T) | tr ' ' '\n' | sed 's/-.*//' | sort | uniq -d` && \
|
@dups=`echo $(T) | tr ' ' '\n' | sed 's/-.*//' | sort | uniq -d` && \
|
||||||
@ -51,12 +65,15 @@ test-lint-executable:
|
|||||||
test -z "$$bad" || { \
|
test -z "$$bad" || { \
|
||||||
echo >&2 "non-executable tests:" $$bad; exit 1; }
|
echo >&2 "non-executable tests:" $$bad; exit 1; }
|
||||||
|
|
||||||
|
test-lint-shell-syntax:
|
||||||
|
@'$(PERL_PATH_SQ)' ../../../t/check-non-portable-shell.pl $(T) $(THELPERS)
|
||||||
|
|
||||||
aggregate-results-and-cleanup: $(T)
|
aggregate-results-and-cleanup: $(T)
|
||||||
$(MAKE) aggregate-results
|
$(MAKE) aggregate-results
|
||||||
$(MAKE) clean
|
$(MAKE) clean
|
||||||
|
|
||||||
aggregate-results:
|
aggregate-results:
|
||||||
for f in ../../../t/test-results/t*-*.counts; do \
|
for f in '$(TEST_RESULTS_DIRECTORY_SQ)'/t*-*.counts; do \
|
||||||
echo "$$f"; \
|
echo "$$f"; \
|
||||||
done | '$(SHELL_PATH_SQ)' ../../../t/aggregate-results.sh
|
done | '$(SHELL_PATH_SQ)' ../../../t/aggregate-results.sh
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user