t / Makefileon commit Change remote tracking to remote-tracking in non-trivial places (60109d0)
   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
  14
  15# Shell quote;
  16SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
  17
  18T = $(wildcard t[0-9][0-9][0-9][0-9]-*.sh)
  19TSVN = $(wildcard t91[0-9][0-9]-*.sh)
  20
  21all: pre-clean
  22        $(MAKE) aggregate-results-and-cleanup
  23
  24$(T):
  25        @echo "*** $@ ***"; GIT_CONFIG=.git/config '$(SHELL_PATH_SQ)' $@ $(GIT_TEST_OPTS)
  26
  27pre-clean:
  28        $(RM) -r test-results
  29
  30clean:
  31        $(RM) -r 'trash directory'.* test-results
  32        $(RM) -r valgrind/bin
  33        $(RM) .prove
  34
  35aggregate-results-and-cleanup: $(T)
  36        $(MAKE) aggregate-results
  37        $(MAKE) clean
  38
  39aggregate-results:
  40        for f in test-results/t*-*.counts; do \
  41                echo "$$f"; \
  42        done | '$(SHELL_PATH_SQ)' ./aggregate-results.sh
  43
  44# we can test NO_OPTIMIZE_COMMITS independently of LC_ALL
  45full-svn-test:
  46        $(MAKE) $(TSVN) GIT_SVN_NO_OPTIMIZE_COMMITS=1 LC_ALL=C
  47        $(MAKE) $(TSVN) GIT_SVN_NO_OPTIMIZE_COMMITS=0 LC_ALL=en_US.UTF-8
  48
  49valgrind:
  50        GIT_TEST_OPTS=--valgrind $(MAKE)
  51
  52# Smoke testing targets
  53-include ../GIT-VERSION-FILE
  54uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo unknown')
  55uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo unknown')
  56
  57test-results:
  58        mkdir -p test-results
  59
  60test-results/git-smoke.tar.gz: test-results
  61        $(PERL_PATH) ./harness \
  62                --archive="test-results/git-smoke.tar.gz" \
  63                $(T)
  64
  65smoke: test-results/git-smoke.tar.gz
  66
  67SMOKE_UPLOAD_FLAGS =
  68ifdef SMOKE_USERNAME
  69        SMOKE_UPLOAD_FLAGS += -F username="$(SMOKE_USERNAME)" -F password="$(SMOKE_PASSWORD)"
  70endif
  71ifdef SMOKE_COMMENT
  72        SMOKE_UPLOAD_FLAGS += -F comments="$(SMOKE_COMMENT)"
  73endif
  74ifdef SMOKE_TAGS
  75        SMOKE_UPLOAD_FLAGS += -F tags="$(SMOKE_TAGS)"
  76endif
  77
  78smoke_report: smoke
  79        curl \
  80                -H "Expect: " \
  81                -F project=Git \
  82                -F architecture="$(uname_M)" \
  83                -F platform="$(uname_S)" \
  84                -F revision="$(GIT_VERSION)" \
  85                -F report_file=@test-results/git-smoke.tar.gz \
  86                $(SMOKE_UPLOAD_FLAGS) \
  87                http://smoke.git.nix.is/app/projects/process_add_report/1 \
  88        | grep -v ^Redirecting
  89
  90.PHONY: pre-clean $(T) aggregate-results clean valgrind smoke smoke_report