t / Makefileon commit merge-recursive: Improve handling of rename target vs. directory addition (51931bf)
   1# Run tests
   2#
   3# Copyright (c) 2005 Junio C Hamano
   4#
   5
   6-include ../config.mak.autogen
   7-include ../config.mak
   8
   9#GIT_TEST_OPTS=--verbose --debug
  10SHELL_PATH ?= $(SHELL)
  11PERL_PATH ?= /usr/bin/perl
  12TAR ?= $(TAR)
  13RM ?= rm -f
  14PROVE ?= prove
  15DEFAULT_TEST_TARGET ?= test
  16
  17# Shell quote;
  18SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
  19
  20T = $(wildcard t[0-9][0-9][0-9][0-9]-*.sh)
  21TSVN = $(wildcard t91[0-9][0-9]-*.sh)
  22TGITWEB = $(wildcard t95[0-9][0-9]-*.sh)
  23
  24all: $(DEFAULT_TEST_TARGET)
  25
  26test: pre-clean $(TEST_LINT)
  27        $(MAKE) aggregate-results-and-cleanup
  28
  29prove: pre-clean $(TEST_LINT)
  30        @echo "*** prove ***"; GIT_CONFIG=.git/config $(PROVE) --exec '$(SHELL_PATH_SQ)' $(GIT_PROVE_OPTS) $(T) :: $(GIT_TEST_OPTS)
  31        $(MAKE) clean
  32
  33$(T):
  34        @echo "*** $@ ***"; GIT_CONFIG=.git/config '$(SHELL_PATH_SQ)' $@ $(GIT_TEST_OPTS)
  35
  36pre-clean:
  37        $(RM) -r test-results
  38
  39clean:
  40        $(RM) -r 'trash directory'.* test-results
  41        $(RM) -r valgrind/bin
  42        $(RM) .prove
  43
  44test-lint: test-lint-duplicates test-lint-executable
  45
  46test-lint-duplicates:
  47        @dups=`echo $(T) | tr ' ' '\n' | sed 's/-.*//' | sort | uniq -d` && \
  48                test -z "$$dups" || { \
  49                echo >&2 "duplicate test numbers:" $$dups; exit 1; }
  50
  51test-lint-executable:
  52        @bad=`for i in $(T); do test -x "$$i" || echo $$i; done` && \
  53                test -z "$$bad" || { \
  54                echo >&2 "non-executable tests:" $$bad; exit 1; }
  55
  56aggregate-results-and-cleanup: $(T)
  57        $(MAKE) aggregate-results
  58        $(MAKE) clean
  59
  60aggregate-results:
  61        for f in test-results/t*-*.counts; do \
  62                echo "$$f"; \
  63        done | '$(SHELL_PATH_SQ)' ./aggregate-results.sh
  64
  65# we can test NO_OPTIMIZE_COMMITS independently of LC_ALL
  66full-svn-test:
  67        $(MAKE) $(TSVN) GIT_SVN_NO_OPTIMIZE_COMMITS=1 LC_ALL=C
  68        $(MAKE) $(TSVN) GIT_SVN_NO_OPTIMIZE_COMMITS=0 LC_ALL=en_US.UTF-8
  69
  70gitweb-test:
  71        $(MAKE) $(TGITWEB)
  72
  73valgrind:
  74        GIT_TEST_OPTS=--valgrind $(MAKE)
  75
  76# Smoke testing targets
  77-include ../GIT-VERSION-FILE
  78uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo unknown')
  79uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo unknown')
  80
  81test-results:
  82        mkdir -p test-results
  83
  84test-results/git-smoke.tar.gz: test-results
  85        $(PERL_PATH) ./harness \
  86                --archive="test-results/git-smoke.tar.gz" \
  87                $(T)
  88
  89smoke: test-results/git-smoke.tar.gz
  90
  91SMOKE_UPLOAD_FLAGS =
  92ifdef SMOKE_USERNAME
  93        SMOKE_UPLOAD_FLAGS += -F username="$(SMOKE_USERNAME)" -F password="$(SMOKE_PASSWORD)"
  94endif
  95ifdef SMOKE_COMMENT
  96        SMOKE_UPLOAD_FLAGS += -F comments="$(SMOKE_COMMENT)"
  97endif
  98ifdef SMOKE_TAGS
  99        SMOKE_UPLOAD_FLAGS += -F tags="$(SMOKE_TAGS)"
 100endif
 101
 102smoke_report: smoke
 103        curl \
 104                -H "Expect: " \
 105                -F project=Git \
 106                -F architecture="$(uname_M)" \
 107                -F platform="$(uname_S)" \
 108                -F revision="$(GIT_VERSION)" \
 109                -F report_file=@test-results/git-smoke.tar.gz \
 110                $(SMOKE_UPLOAD_FLAGS) \
 111                http://smoke.git.nix.is/app/projects/process_add_report/1 \
 112        | grep -v ^Redirecting
 113
 114.PHONY: pre-clean $(T) aggregate-results clean valgrind smoke smoke_report