[tests] awesomize make output

Summary:
Hide the output of all the toplevel `make` actions and print messages instead, as if we had a better build system than Makefiles. When a command fails, print its stdout and stderr and prefix it with bold red letters. Also display timing information.

```
$ make -j 4 test
[17:39:18][27290] Facebook setup...
[17:39:18][27363] Building checkCopyright...
[17:39:18][27443] Validating facebook/...
[      0s][27363] SUCCESS Building checkCopyright
[      0s][27290] SUCCESS Facebook setup
[17:39:18][27863] Building clang plugin...
[      0s][27443] SUCCESS Validating facebook/
[      0s][27863] SUCCESS Building clang plugin
[17:39:18][27898] Building clang plugin OCaml interface...
[      0s][27898] SUCCESS Building clang plugin OCaml interface
[17:39:18][27974] Testing Infer builds without warnings...
[17:39:18][28033] Building native Infer...
[     12s][27974] SUCCESS Testing Infer builds without warnings
[17:39:30][28998] Testing Infer toplevel builds...
[      6s][28998] SUCCESS Testing Infer toplevel builds
[17:39:36][31417] Running OCaml unit tests...
[17:39:36][31456] Testing infer OCaml REPL...
[      6s][31417] SUCCESS Running OCaml unit tests
[      9s][31456] SUCCESS Testing infer OCaml REPL
[     92s][28033] SUCCESS Building native Infer
[17:40:50][ 2170] Building Java annotations...
[      0s][ 2170] SUCCESS Building Java annotations
[17:40:50][ 2186] Building Infer models...
[     11s][ 2186] SUCCESS Building Infer models
[17:41:01][ 2803] Running build assembly test...
[17:41:01][ 2861] Running build ck analytics test...
[17:41:01][ 2941] Running build ck imports test...
[17:41:01][ 3035] Running build clang compilation db escaped test...
[      1s][ 3035] SUCCESS Running build clang compilation db escaped test
[17:41:02][ 3139] Running build clang compilation db relpath test...
[      3s][ 2861] SUCCESS Running build ck analytics test
[17:41:04][ 3296] Running build clang multiple files test...
[*ERROR**][2803] *** ERROR Running build assembly test
[*ERROR**][2803] *** command:    ( make INTERACTIVE=1 -C /home/jul/infer/infer/tests/build_systems/assembly test 2> >(grep -v warning: (ignoring old|overriding) (commands|recipe) for target) ; exit 0)
[*ERROR**][2803] *** CWD: /home/jul/infer
[*ERROR**][2803] *** stdout:
[*ERROR**][2803] make[1]: Entering directory '/home/jul/infer/infer/tests/build_systems/assembly'
[*ERROR**][2803] *** inner Testing infer/clang in build_systems/assembly
[*ERROR**][2803] *** inner command:  /home/jul/infer/infer/bin/infer --results-dir infer-out --dump-duplicate-symbols --report-custom-error --developer-mode --project-root ../codetoanalyze --no-failures-allowed -a infer -- clang -c ../codetoanalyze/example.S ../codetoanalyze/hello.c
[*ERROR**][2803] *** inner CWD: /home/jul/infer/infer/tests/build_systems/assembly
[*ERROR**][2803] Capturing in make/cc mode...
[*ERROR**][2803] Starting analysis...
[*ERROR**][2803]
[*ERROR**][2803] legend:
[*ERROR**][2803]   "F" analyzing a file
[*ERROR**][2803]   "." analyzing a procedure
[*ERROR**][2803]
[*ERROR**][2803] Found 1 (out of 1) source files to be analyzed in /home/jul/infer/infer/tests/build_systems/assembly/infer-out
[*ERROR**][2803]
[*ERROR**][2803]
[*ERROR**][2803]   No issues found
[*ERROR**][2803]
[*ERROR**][2803] ../../infer.make:30: recipe for target 'test' failed
[*ERROR**][2803] make[1]: Leaving directory '/home/jul/infer/infer/tests/build_systems/assembly'
[*ERROR**][2803] F.--- build_systems/assembly/issues.exp        2017-03-22 16:25:44.583854270 +0000
[*ERROR**][2803] +++ build_systems/assembly/issues.exp.test     2017-03-28 17:41:04.743678254 +0100
[*ERROR**][2803] @@ -1 +0,0 @@
[*ERROR**][2803] -hello.c, test, 2, NULL_DEREFERENCE, [start of procedure test()]
[*ERROR**][2803]
[*ERROR**][2803] Test output (build_systems/assembly/issues.exp.test) differs from expected test output build_systems/assembly/issues.exp
[*ERROR**][2803] Run the following command to replace the expected test output with the new output:
[*ERROR**][2803]
[*ERROR**][2803]   make -C build_systems/assembly replace
[*ERROR**][2803]
[*ERROR**][2803] make[1]: *** [test] Error 1
[*ERROR**][2803] *** stderr:
Makefile:230: recipe for target 'build_assembly_test' failed
make: *** [build_assembly_test] Error 1
make: *** Waiting for unfinished jobs....
[...]
```

Reviewed By: jberdine

Differential Revision: D4781857

fbshipit-source-id: cbce26d
master
Jules Villard 8 years ago committed by Facebook Github Bot
parent 41d615c351
commit 3ab6c43fb6

1
.gitignore vendored

@ -15,6 +15,7 @@
# generated by build and tests # generated by build and tests
/_build /_build
/_build_logs
/infer/_build /infer/_build
/infer/tests/codetoanalyze/java/*/codetoanalyze /infer/tests/codetoanalyze/java/*/codetoanalyze
/infer-deps-* /infer-deps-*

@ -90,37 +90,60 @@ endif
all: infer all: infer
configure: configure.ac $(wildcard m4/*.m4) configure: configure.ac $(wildcard m4/*.m4)
# rerun ./autogen.sh in case of failure as the failure may be due to needing to rerun
# ./configure
$(QUIET)($(call silent_on_success,Generate ./configure,./autogen.sh)) || \
./autogen.sh ./autogen.sh
Makefile.autoconf: configure Makefile.autoconf.in Makefile.autoconf: configure Makefile.autoconf.in
# rerun ./configure with the flags that were used last time it was run (if available) # rerun ./configure with the flags that were used last time it was run (if available)
# retry in case of failure as the failure may be due to needing to rerun ./configure
$(QUIET)($(call silent_on_success,Running\
./configure $(shell ./config.status --config || true),\
./configure $(shell ./config.status --config || true))) || \
./configure $(shell ./config.status --config || true) ./configure $(shell ./config.status --config || true)
.PHONY: fb-setup
fb-setup:
$(QUIET)$(call silent_on_success,Facebook setup,\
$(MAKE) -C facebook setup)
.PHONY: src_build .PHONY: src_build
src_build: $(MAKEFILE_LIST) src_build:
ifeq ($(IS_FACEBOOK_TREE),yes) $(QUIET)$(call silent_on_success,Building native Infer,\
$(QUIET)$(MAKE) -C facebook setup $(MAKE) -C $(SRC_DIR) infer)
endif
$(QUIET)$(MAKE) -C $(SRC_DIR) infer
.PHONY: byte .PHONY: byte
byte: byte:
$(QUIET)$(call silent_on_success,Building byte Infer,\
$(MAKE) -C $(SRC_DIR) byte)
.PHONY: test_build
test_build:
$(QUIET)$(call silent_on_success,Testing Infer builds without warnings,\
$(MAKE) -C $(SRC_DIR) TEST=1 byte_no_install)
# byte_no_install builds most of what toplevel needs, so it's more efficient to run the
# toplevel build straight after it rather than in parallel. Note that both targets build files
# that the other doesn't.
$(QUIET)$(call silent_on_success,Testing Infer toplevel builds,\
$(MAKE) -C $(SRC_DIR) TEST=1 toplevel)
ifeq ($(IS_FACEBOOK_TREE),yes) ifeq ($(IS_FACEBOOK_TREE),yes)
$(QUIET)$(MAKE) -C facebook setup byte src_build test_build: fb-setup
endif endif
$(QUIET)$(MAKE) -C $(SRC_DIR) byte
ifeq ($(BUILD_C_ANALYZERS),yes) ifeq ($(BUILD_C_ANALYZERS),yes)
src_build: clang_plugin byte src_build test_build: clang_plugin
byte: clang_plugin
endif endif
.PHONY: infer .PHONY: infer
infer: src_build infer: src_build
ifeq ($(BUILD_JAVA_ANALYZERS),yes) ifeq ($(BUILD_JAVA_ANALYZERS),yes)
$(QUIET)$(MAKE) -C $(ANNOTATIONS_DIR) $(QUIET)$(call silent_on_success,Building Java annotations,\
$(MAKE) -C $(ANNOTATIONS_DIR))
endif endif
$(QUIET)$(MAKE) -C $(MODELS_DIR) all $(QUIET)$(call silent_on_success,Building Infer models,\
$(MAKE) -C $(MODELS_DIR) all)
.PHONY: clang_setup .PHONY: clang_setup
clang_setup: clang_setup:
@ -133,37 +156,29 @@ clang_setup:
.PHONY: clang_plugin .PHONY: clang_plugin
clang_plugin: clang_setup clang_plugin: clang_setup
ifeq ($(IS_RELEASE_TREE),no) ifeq ($(IS_RELEASE_TREE),no)
$(QUIET)$(MAKE) -C $(FCP_DIR)/libtooling all \ $(QUIET)$(call silent_on_success,Building clang plugin,\
$(MAKE) -C $(FCP_DIR)/libtooling all \
CC=$(CC) CXX=$(CXX) \ CC=$(CC) CXX=$(CXX) \
CFLAGS="$(CFLAGS)" CXXFLAGS="$(CXXFLAGS)" \ CFLAGS="$(CFLAGS)" CXXFLAGS="$(CXXFLAGS)" \
CPP="$(CPP)" LDFLAGS="$(LDFLAGS)" LIBS="$(LIBS)" \ CPP="$(CPP)" LDFLAGS="$(LDFLAGS)" LIBS="$(LIBS)" \
LOCAL_CLANG=$(CLANG_PREFIX)/bin/clang \ LOCAL_CLANG=$(CLANG_PREFIX)/bin/clang \
CLANG_PREFIX=$(CLANG_PREFIX) \ CLANG_PREFIX=$(CLANG_PREFIX) \
CLANG_INCLUDES=$(CLANG_INCLUDES) CLANG_INCLUDES=$(CLANG_INCLUDES))
$(QUIET)$(MAKE) -C $(FCP_DIR)/clang-ocaml all \ $(QUIET)$(call silent_on_success,Building clang plugin OCaml interface,\
$(MAKE) -C $(FCP_DIR)/clang-ocaml all \
build/clang_ast_proj.ml build/clang_ast_proj.mli \ build/clang_ast_proj.ml build/clang_ast_proj.mli \
CC=$(CC) CXX=$(CXX) \ CC=$(CC) CXX=$(CXX) \
CFLAGS="$(CFLAGS)" CXXFLAGS="$(CXXFLAGS)" \ CFLAGS="$(CFLAGS)" CXXFLAGS="$(CXXFLAGS)" \
CPP="$(CPP)" LDFLAGS="$(LDFLAGS)" LIBS="$(LIBS)" \ CPP="$(CPP)" LDFLAGS="$(LDFLAGS)" LIBS="$(LIBS)" \
LOCAL_CLANG=$(CLANG_PREFIX)/bin/clang \ LOCAL_CLANG=$(CLANG_PREFIX)/bin/clang \
CLANG_PREFIX=$(CLANG_PREFIX) \ CLANG_PREFIX=$(CLANG_PREFIX) \
CLANG_INCLUDES=$(CLANG_INCLUDES) CLANG_INCLUDES=$(CLANG_INCLUDES))
endif endif
.PHONY: test_build
test_build: clang_plugin
ifeq ($(IS_FACEBOOK_TREE),yes)
$(QUIET)$(MAKE) -C facebook setup
endif
$(QUIET)$(MAKE) -C $(SRC_DIR) TEST=1 byte_no_install
# byte_no_install builds most of what toplevel needs, so it's more efficient to run the
# toplevel build straight after it rather than in parallel. Note that both targets build files
# that the other doesn't.
$(QUIET)$(MAKE) -C $(SRC_DIR) TEST=1 toplevel
.PHONY: ocaml_unit_test .PHONY: ocaml_unit_test
ocaml_unit_test: test_build ocaml_unit_test: test_build
$(call silent_on_success,$(BUILD_DIR)/test/infer/unit/inferunit.byte) $(QUIET)$(call silent_on_success,Running OCaml unit tests,\
$(BUILD_DIR)/test/infer/unit/inferunit.byte)
define silence_make define silence_make
($(1) 2> >(grep -v "warning: \(ignoring old\|overriding\) \(commands\|recipe\) for target") \ ($(1) 2> >(grep -v "warning: \(ignoring old\|overriding\) \(commands\|recipe\) for target") \
@ -172,10 +187,11 @@ endef
.PHONY: $(DIRECT_TESTS:%=direct_%_test) .PHONY: $(DIRECT_TESTS:%=direct_%_test)
$(DIRECT_TESTS:%=direct_%_test): infer $(DIRECT_TESTS:%=direct_%_test): infer
$(QUIET)$(call silence_make,\ $(QUIET)$(call silent_on_success,Running $(subst _, ,$@),\
$(call silence_make,\
$(MAKE) -C \ $(MAKE) -C \
$(INFER_DIR)/tests/codetoanalyze/$(shell printf $@ | cut -f 2 -d _)/$(shell printf $@ | cut -f 3 -d _) \ $(INFER_DIR)/tests/codetoanalyze/$(shell printf $@ | cut -f 2 -d _)/$(shell printf $@ | cut -f 3 -d _) \
test) test))
.PHONY: $(DIRECT_TESTS:%=direct_%_print) .PHONY: $(DIRECT_TESTS:%=direct_%_print)
$(DIRECT_TESTS:%=direct_%_print): infer $(DIRECT_TESTS:%=direct_%_print): infer
@ -211,8 +227,9 @@ build_waf_print: build_make_print
.PHONY: $(BUILD_SYSTEMS_TESTS:%=build_%_test) .PHONY: $(BUILD_SYSTEMS_TESTS:%=build_%_test)
$(BUILD_SYSTEMS_TESTS:%=build_%_test): infer $(BUILD_SYSTEMS_TESTS:%=build_%_test): infer
$(QUIET)$(call silence_make,\ $(QUIET)$(call silent_on_success,Running $(subst _, ,$@),\
$(MAKE) -C $(INFER_DIR)/tests/build_systems/$(patsubst build_%_test,%,$@) test) $(call silence_make,\
$(MAKE) -C $(INFER_DIR)/tests/build_systems/$(patsubst build_%_test,%,$@) test))
.PHONY: $(BUILD_SYSTEMS_TESTS:%=build_%_print) .PHONY: $(BUILD_SYSTEMS_TESTS:%=build_%_print)
$(BUILD_SYSTEMS_TESTS:%=build_%_print): infer $(BUILD_SYSTEMS_TESTS:%=build_%_print): infer
@ -233,31 +250,33 @@ $(BUILD_SYSTEMS_TESTS:%=build_%_replace): infer
build_systems_tests: $(BUILD_SYSTEMS_TESTS:%=build_%_test) build_systems_tests: $(BUILD_SYSTEMS_TESTS:%=build_%_test)
.PHONY: endtoend_test .PHONY: endtoend_test
endtoend_test: $(BUILD_SYSTEMS_TESTS:%=build_%_print) $(DIRECT_TESTS:%=direct_%_print) endtoend_test: $(BUILD_SYSTEMS_TESTS:%=build_%_test) $(DIRECT_TESTS:%=direct_%_test)
# pre-compute all the results first so that the test failures show up near the end of the output
$(MAKE) direct_tests build_systems_tests
.PHONY: inferTraceBugs_test .PHONY: inferTraceBugs_test
inferTraceBugs_test: infer inferTraceBugs_test: infer
ifeq ($(BUILD_JAVA_ANALYZERS),yes) ifeq ($(BUILD_JAVA_ANALYZERS),yes)
$(QUIET)$(call silent_on_success,Testing inferTraceBugs: running infer,\
$(INFER_BIN) -o __test-infer-out__ -- \ $(INFER_BIN) -o __test-infer-out__ -- \
$(JAVAC) $(EXAMPLES_DIR)/Hello.java \ $(JAVAC) $(EXAMPLES_DIR)/Hello.java)
> /dev/null
else else
$(QUIET)$(call silent_on_success,Testing inferTraceBugs: running infer,\
$(INFER_BIN) -o __test-infer-out__ -- \ $(INFER_BIN) -o __test-infer-out__ -- \
clang -c $(EXAMPLES_DIR)/hello.c \ clang -c $(EXAMPLES_DIR)/hello.c)
> /dev/null
endif endif
$(QUIET)rm -f Hello.class $(QUIET)$(REMOVE) Hello.class
$(QUIET)$(call silent_on_success,Testing inferTraceBugs: --max-level=max,\
$(PYTHON_DIR)/inferTraceBugs -o __test-infer-out__ \ $(PYTHON_DIR)/inferTraceBugs -o __test-infer-out__ \
--select 0 --max-level max > /dev/null --select 0 --max-level max)
$(QUIET)$(call silent_on_success,Testing inferTraceBugs: --max-level=0,\
$(PYTHON_DIR)/inferTraceBugs -o __test-infer-out__ \ $(PYTHON_DIR)/inferTraceBugs -o __test-infer-out__ \
--select 0 --max-level 0 > /dev/null --select 0 --max-level 0)
$(QUIET)$(call silent_on_success,Testing inferTraceBugs: --max-level=max --no-source,\
$(PYTHON_DIR)/inferTraceBugs -o __test-infer-out__ \ $(PYTHON_DIR)/inferTraceBugs -o __test-infer-out__ \
--select 0 --max-level max --no-source > /dev/null --select 0 --max-level max --no-source)
$(QUIET)$(call silent_on_success,Testing inferTraceBugs: --only-show,\
$(PYTHON_DIR)/inferTraceBugs -o __test-infer-out__ \ $(PYTHON_DIR)/inferTraceBugs -o __test-infer-out__ \
--only-show > /dev/null --only-show)
$(QUIET)rm -fr __test-infer-out__ $(QUIET)$(REMOVE_DIR) __test-infer-out__
.PHONY: check_missing_mli .PHONY: check_missing_mli
check_missing_mli: check_missing_mli:
@ -270,26 +289,29 @@ toplevel: clang_plugin
.PHONY: inferScriptMode_test .PHONY: inferScriptMode_test
inferScriptMode_test: test_build inferScriptMode_test: test_build
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing infer OCaml REPL,\
INFER_REPL_BINARY=ocaml $(SCRIPT_DIR)/infer_repl $(INFER_DIR)/tests/repl/infer_batch_script.ml) INFER_REPL_BINARY=ocaml $(SCRIPT_DIR)/infer_repl $(INFER_DIR)/tests/repl/infer_batch_script.ml)
.PHONY: checkCopyright .PHONY: checkCopyright
checkCopyright: checkCopyright:
$(QUIET)$(MAKE) -C $(SRC_DIR) checkCopyright $(QUIET)$(call silent_on_success,Building checkCopyright,\
$(MAKE) -C $(SRC_DIR) checkCopyright)
.PHONY: validate-skel .PHONY: validate-skel
validate-skel: validate-skel:
ifeq ($(IS_FACEBOOK_TREE),yes) ifeq ($(IS_FACEBOOK_TREE),yes)
$(QUIET)$(MAKE) -C facebook validate $(QUIET)$(call silent_on_success,Validating facebook/,\
$(MAKE) -C facebook validate)
endif endif
.PHONY: test .PHONY: test
test: test_build ocaml_unit_test endtoend_test inferTraceBugs_test inferScriptMode_test \ test: test_build ocaml_unit_test endtoend_test inferTraceBugs_test inferScriptMode_test \
checkCopyright validate-skel checkCopyright validate-skel
$(QUIET)$(MAKE) -C $(SRC_DIR) mod_dep.dot $(QUIET)$(call silent_on_success,Building Infer source dependency graph,\
$(MAKE) -C $(SRC_DIR) mod_dep.dot)
ifeq (,$(findstring s,$(MAKEFLAGS))) ifeq (,$(findstring s,$(MAKEFLAGS)))
$(QUIET)echo "ALL TESTS PASSED" $(QUIET)echo "$(TERM_INFO)ALL TESTS PASSED$(TERM_RESET)"
endif endif
.PHONY: quick-test .PHONY: quick-test
@ -432,7 +454,8 @@ ifeq ($(IS_FACEBOOK_TREE),yes)
$(QUIET)$(MAKE) -C facebook clean $(QUIET)$(MAKE) -C facebook clean
endif endif
$(QUIET)$(MAKE) -C $(DEPENDENCIES_DIR)/ocamldot clean $(QUIET)$(MAKE) -C $(DEPENDENCIES_DIR)/ocamldot clean
find $(INFER_DIR)/tests -name '*.o' -or -name '*.o.sh' -delete find $(INFER_DIR)/tests \( -name '*.o' -o -name '*.o.sh' \) -delete
$(REMOVE_DIR) _build_logs
.PHONY: conf-clean .PHONY: conf-clean
conf-clean: clean conf-clean: clean

@ -55,6 +55,7 @@ OCAMLOPT = @OCAMLOPT@
prefix = @prefix@ prefix = @prefix@
PYTHON_lxml = @PYTHON_lxml@ PYTHON_lxml = @PYTHON_lxml@
REBUILD = @REBUILD@ REBUILD = @REBUILD@
SHASUM = @SHASUM@
USER_JAVA_HOME = @USER_JAVA_HOME@ USER_JAVA_HOME = @USER_JAVA_HOME@
XCODE_SELECT = @XCODE_SELECT@ XCODE_SELECT = @XCODE_SELECT@
XCPRETTY = @XCPRETTY@ XCPRETTY = @XCPRETTY@

@ -97,10 +97,75 @@ ifneq ($(XCODE_SELECT),no)
CLANG_DEPS += $(OBJC_MODELS_FILE) CLANG_DEPS += $(OBJC_MODELS_FILE)
endif endif
define silent_on_success INTERACTIVE = $(shell [ -t 0 ] && echo 1)
$(1) >/dev/null 2>/dev/null || ($(1) && exit 1) # remove "jobserver-fds" because it contains "s"...
endef SILENT = $(findstring s,$(subst jobserver-fds,,$(MAKEFLAGS)))
ifeq (1,$(INTERACTIVE))
TERM_ERROR = $(shell printf '\e[31;1m')
TERM_INFO = $(shell printf '\e[;1m')
TERM_SUCCESS = $(shell printf '\e[;2m')
TERM_RESET = $(shell printf '\e[0m')
endif
ifneq ($(VERBOSE),1) ifneq ($(VERBOSE),1)
# quiet
QUIET = @ QUIET = @
endif endif
MAKE := $(MAKE) INTERACTIVE=$(INTERACTIVE)
# 99999 PIDs ought to be enough for anybody, but check if pid_max can be found just in case
MAX_PID_SIZE = \
$(shell PID_MAX=$$(cat /proc/sys/kernel/pid_max 2>/dev/null); echo $${\#PID_MAX} || echo 5)
# Arguments:
# $(1) is a string describing the command
# $(2) is the command to run
#
# Run and time the command and redirect its stdout and stderr to files. Display info about the
# command only in case of error. Try to be as helpful as possible in the error case.
#
# The PID of the process is used in the names of the output files, and as a prefix for each error
# message so that it's possible to piece error messages together even when they are interleaved with
# other messages from concurrent `make` processes.
#
# Detect if we are already wrapped inside a silent_on_success call and try not to clutter the output
# too much in that case.
define silent_on_success
if [ "$$INSIDE_SILENT_ON_SUCCESS" = 1 ]; then \
echo "*** inner $(1)"; \
echo "*** inner command: $(2)"; \
echo "*** inner CWD: $(CURDIR)"; \
($(2)); \
exit $$?; \
fi; \
export INSIDE_SILENT_ON_SUCCESS=1; \
HASH="$$$$"; \
UNIX_START_DATE=$$(date +"%s"); \
HUMAN_START_DATE=$$(date +"%H:%M:%S"); \
if [ -z $(SILENT) ]; then \
printf '[%s][%$(MAX_PID_SIZE)s] $(TERM_INFO)$(1)...$(TERM_RESET)\n' \
"$$HUMAN_START_DATE" "$$HASH"; \
fi; \
$(MKDIR_P) $(ABSOLUTE_ROOT_DIR)/_build_logs; \
($(2)) 1>$(ABSOLUTE_ROOT_DIR)/_build_logs/cmd-$$HASH.out \
2>$(ABSOLUTE_ROOT_DIR)/_build_logs/cmd-$$HASH.err; \
ERRCODE=$$?; \
if [ $$ERRCODE != 0 ]; then \
echo "$(TERM_ERROR)[*ERROR**][$$HASH] *** ERROR $(1)$(TERM_RESET)" >&2; \
echo "$(TERM_ERROR)[*ERROR**][$$HASH] *** command: $(2)$(TERM_RESET)" >&2; \
echo "$(TERM_ERROR)[*ERROR**][$$HASH] *** CWD: $(CURDIR)$(TERM_RESET)" >&2; \
echo "$(TERM_ERROR)[*ERROR**][$$HASH] *** stdout:$(TERM_RESET)" >&2; \
sed -e "s/^\(.*\)$$/$(TERM_ERROR)[*ERROR**][$$HASH]$(TERM_RESET) \1/" \
$(ABSOLUTE_ROOT_DIR)/_build_logs/cmd-$$HASH.out; >&2; \
echo "$(TERM_ERROR)[*ERROR**][$$HASH] *** stderr:$(TERM_RESET)" >&2; \
sed -e "s/^\(.*\)$$/$(TERM_ERROR)[*ERROR**][$$HASH]$(TERM_RESET) \1/" \
$(ABSOLUTE_ROOT_DIR)/_build_logs/cmd-$$HASH.err; >&2; \
exit 1; \
elif [ -z $(SILENT) ]; then \
UNIX_END_DATE=$$(date +"%s"); \
printf '[%7ss][%$(MAX_PID_SIZE)s] $(TERM_SUCCESS)SUCCESS $(1)$(TERM_RESET)\n' \
"$$(($$UNIX_END_DATE - $$UNIX_START_DATE))" "$$HASH"; \
fi
endef

@ -14,8 +14,8 @@ INFER_RESULTS = out/report.json
all: install all: install
$(INFER_RESULTS): $(C_MODELS_SOURCES) $(CLANG_DEPS_NO_MODELS) $(INFER_RESULTS): $(C_MODELS_SOURCES) $(CLANG_DEPS_NO_MODELS)
# make clean in src/ to recompile all the models # make clean in src/ to recompile all the models
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Building C models,\
$(INFER_BIN) -o $(@D) --models-mode --no-failures-allowed -- $(MAKE) -C src clean all) $(INFER_BIN) -o $(@D) --models-mode --no-failures-allowed -- $(MAKE) -C src clean all)
$(C_MODELS_FILE): $(INFER_RESULTS) $(C_MODELS_FILE): $(INFER_RESULTS)

@ -15,8 +15,8 @@ INFER_RESULTS = out/report.json
all: install all: install
$(INFER_RESULTS): $(CPP_MODELS_SOURCES) $(C_MODELS_SOURCES) $(CLANG_DEPS_NO_MODELS) $(INFER_RESULTS): $(CPP_MODELS_SOURCES) $(C_MODELS_SOURCES) $(CLANG_DEPS_NO_MODELS)
# make clean in src/ to recompile all the models # make clean in src/ to recompile all the models
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Building C++ models,\
$(INFER_BIN) -o $(@D) --models-mode --no-failures-allowed -- $(MAKE) -C src clean all) $(INFER_BIN) -o $(@D) --models-mode --no-failures-allowed -- $(MAKE) -C src clean all)
$(CPP_MODELS_FILE): $(INFER_RESULTS) $(CPP_MODELS_FILE): $(INFER_RESULTS)

@ -29,9 +29,9 @@ compile:
$(INFER_REPORT): $(JAVA_DEPS_NO_MODELS) $(JAVA_SOURCES) $(INFER_REPORT): $(JAVA_DEPS_NO_MODELS) $(JAVA_SOURCES)
$(QUIET)rm -fr $(MODELS_OUT) $(QUIET)rm -fr $(MODELS_OUT)
mkdir -p $(MODELS_OUT) $(QUIET)$(MKDIR_P) $(MODELS_OUT)
$(QUIET)rm -f $(JAVA_MODELS_JAR) $(QUIET)rm -f $(JAVA_MODELS_JAR)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Building Java models,\
$(INFER_BIN) --jobs 1 --results-dir $(INFER_RESULTS_DIR) --models-mode -- \ $(INFER_BIN) --jobs 1 --results-dir $(INFER_RESULTS_DIR) --models-mode -- \
$(JAVAC) -bootclasspath $(ANDROID_JAR) -d $(MODELS_OUT) -classpath $(MODELS_CLASSPATH) \ $(JAVAC) -bootclasspath $(ANDROID_JAR) -d $(MODELS_OUT) -classpath $(MODELS_CLASSPATH) \
$(JAVA_SOURCES)) $(JAVA_SOURCES))

@ -15,7 +15,7 @@ all: install
$(INFER_RESULTS): $(OBJC_MODELS_SOURCES) $(CLANG_DEPS_NO_MODELS) $(INFER_RESULTS): $(OBJC_MODELS_SOURCES) $(CLANG_DEPS_NO_MODELS)
# make clean in src/ to recompile all the models # make clean in src/ to recompile all the models
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Building Objective-C models,\
$(INFER_BIN) -o $(@D) --models-mode --no-failures-allowed -- $(MAKE) -C src clean all) $(INFER_BIN) -o $(@D) --models-mode --no-failures-allowed -- $(MAKE) -C src clean all)
$(OBJC_MODELS_FILE): $(INFER_RESULTS) $(OBJC_MODELS_FILE): $(INFER_RESULTS)

@ -6,38 +6,27 @@
# of patent rights can be found in the PATENTS file in the same directory. # of patent rights can be found in the PATENTS file in the same directory.
ROOT_DIR = $(TESTS_DIR)/../.. ROOT_DIR = $(TESTS_DIR)/../..
include $(ROOT_DIR)/Makefile.config
# The relative path from infer/tests/ to the directory containing the current Makefile. This is # The relative path from infer/tests/ to the directory containing the current Makefile. This is
# computed in a hacky way and might not always be a relative path, so only use this for cosmetic # computed in a hacky way and might not always be a relative path, so only use this for cosmetic
# reasons. # reasons.
TEST_REL_DIR = $(patsubst $(abspath $(TESTS_DIR))/%,%,$(abspath $(CURDIR))) TEST_REL_DIR = $(patsubst $(abspath $(TESTS_DIR))/%,%,$(abspath $(CURDIR)))
include $(ROOT_DIR)/Makefile.config define check_no_duplicates
grep "DUPLICATE_SYMBOLS" $(1); test $$? -ne 0 || \
default: compile (echo '$(TEST_ERROR)Duplicate symbols found in $(CURDIR).' \
'Please make sure all the function names in all the source test files are different.$(TEST_RESET)';\
issues.exp.test$(TEST_SUFFIX): infer-out$(TEST_SUFFIX)/report.json $(INFERPRINT_BIN) exit 1)
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@ --from-json-report $< endef
.PHONY: compile define check_no_diff
compile: $(OBJECTS) diff -u $(1) $(2) >&2 || \
(printf '\n' >&2; \
.PHONY: analyze printf '$(TERM_ERROR)Test output ($(2)) differs from expected test output $(1)$(TERM_RESET)\n' >&2; \
analyze: infer-out$(TEST_SUFFIX)/report.json printf '$(TERM_ERROR)Run the following command to replace the expected test output with the new output:$(TERM_RESET)\n' >&2; \
printf '\n' >&2; \
.PHONY: print printf '$(TERM_ERROR) make -C $(TEST_REL_DIR) replace\n$(TERM_RESET)' >&2; \
print: issues.exp.test$(TEST_SUFFIX) printf '\n' >&2; \
exit 1)
.PHONY: test endef
test: issues.exp.test$(TEST_SUFFIX)
$(QUIET)cd $(TESTS_DIR) && \
diff -u $(TEST_REL_DIR)/issues.exp $(TEST_REL_DIR)/issues.exp.test$(TEST_SUFFIX)
.PHONY: print
replace: issues.exp.test$(TEST_SUFFIX)
cp $< issues.exp
.PHONY: clean
clean:
$(REMOVE_DIR) codetoanalyze com issues.exp.test$(TEST_SUFFIX) infer-out$(TEST_SUFFIX) \
$(OBJECTS) $(CLEAN_EXTRA)

@ -13,13 +13,13 @@ OBJECTS = $(patsubst %.java,ant_out/%.class,$(SOURCES))
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
include $(TESTS_DIR)/java.make include $(TESTS_DIR)/java.make
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
$(OBJECTS): $(SOURCES) $(OBJECTS): $(SOURCES)
$(ANT) $(ANT)
infer-out/report.json: $(JAVA_DEPS) $(SOURCES) infer-out/report.json: $(JAVA_DEPS) $(SOURCES)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing ant integration,\
$(INFER_BIN) -a $(ANALYZER) --project-root $(TESTS_DIR) --inferconfig-home . -- $(ANT)) $(INFER_BIN) -a $(ANALYZER) --project-root $(TESTS_DIR) --inferconfig-home . -- $(ANT))
clean: clean:

@ -16,11 +16,11 @@ OBJECTS = '$(SOURCE_DIR)/buck-out/gen/clang_compilation_database/__Hel lo\#compi
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
CLEAN_EXTRA = $(SOURCE_DIR)/buck-out CLEAN_EXTRA = $(SOURCE_DIR)/buck-out
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
infer-out/report.json: $(CLANG_DEPS) $(SOURCES) infer-out/report.json: $(CLANG_DEPS) $(SOURCES)
cd $(SOURCE_DIR) && \ $(QUIET)cd $(SOURCE_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Testing Buck Clang compilation database integration,\
NO_BUCKD=1 \ NO_BUCKD=1 \
$(INFER_BIN) -a $(ANALYZER) --stats $(INFER_OPTIONS) -o $(CURDIR)/$(@D) \ $(INFER_BIN) -a $(ANALYZER) --stats $(INFER_OPTIONS) -o $(CURDIR)/$(@D) \
--buck-compilation-database no-deps \ --buck-compilation-database no-deps \

@ -16,18 +16,18 @@ INFERPRINT_OPTIONS = --project-root $(ROOT_DIR) --issues-tests
CLEAN_EXTRA = $(ROOT_DIR)/buck-out CLEAN_EXTRA = $(ROOT_DIR)/buck-out
include $(TESTS_DIR)/java.make include $(TESTS_DIR)/java.make
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
$(OBJECTS): $(JAVA_SOURCE_FILES) $(OBJECTS): $(JAVA_SOURCE_FILES)
cd $(ROOT_DIR) && \ $(QUIET)cd $(ROOT_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Compiling Buck Java tests,\
INFER_BIN=$(INFER_BIN) NO_BUCKD=1 \ INFER_BIN=$(INFER_BIN) NO_BUCKD=1 \
$(BUCK) build --no-cache $(BUCK_TARGET)) $(BUCK) build --no-cache $(BUCK_TARGET))
infer-out/report.json: $(JAVA_DEPS) $(JAVA_SOURCE_FILES) infer-out/report.json: $(JAVA_DEPS) $(JAVA_SOURCE_FILES)
cd $(ROOT_DIR) && \ $(QUIET)cd $(ROOT_DIR) && \
$(REMOVE_DIR) buck-out && \ $(REMOVE_DIR) buck-out && \
$(call silent_on_success,\ $(call silent_on_success,Testing Buck Java integration,\
INFER_BIN=$(INFER_BIN) NO_BUCKD=1 \ INFER_BIN=$(INFER_BIN) NO_BUCKD=1 \
$(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/infer-out -- \ $(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/infer-out -- \
$(BUCK) build --no-cache $(BUCK_TARGET)) $(BUCK) build --no-cache $(BUCK_TARGET))

@ -17,36 +17,38 @@ SOURCES = $(CMAKE_DIR)/hello.cpp
OBJECTS = $(CMAKE_BUILD_DIR)/compile_commands.json OBJECTS = $(CMAKE_BUILD_DIR)/compile_commands.json
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
$(CMAKE_BUILD_DIR): $(CMAKE_BUILD_DIR):
$(MKDIR_P) $@ $(QUIET)$(MKDIR_P) $@
$(CMAKE_BUILD_DIR)/compile_commands.json: $(SOURCES) $(CMAKE_DIR)/CMakeLists.txt $(CMAKE_BUILD_DIR) $(CMAKE_BUILD_DIR)/compile_commands.json: $(SOURCES) $(CMAKE_DIR)/CMakeLists.txt $(CMAKE_BUILD_DIR)
cd $(CMAKE_BUILD_DIR) && \ $(QUIET)cd $(CMAKE_BUILD_DIR) && \
$(CMAKE) -DCMAKE_EXPORT_COMPILE_COMMANDS=1 .. $(call silent_on_success,Running cmake to generate Makefiles,\
$(CMAKE) -DCMAKE_EXPORT_COMPILE_COMMANDS=1 ..)
infer-out/report.json: infer-out/report.json:
# make this target empty - since this test defines issues.exp.test directly # make this target empty - since this test defines issues.exp.test directly
infer-out-with-index/report.json: $(CMAKE_BUILD_DIR)/compile_commands.json $(CLANG_DEPS) $(SOURCES) infer-out-with-index/report.json: $(CMAKE_BUILD_DIR)/compile_commands.json $(CLANG_DEPS) $(SOURCES)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing Clang compilation database with index integration,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) -o infer-out-with-index --changed-files-index $(CMAKE_DIR)/index.txt --compilation-database $<) $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) -o $(@D) \
--changed-files-index $(CMAKE_DIR)/index.txt --compilation-database $<)
infer-out-no-index/report.json: $(CMAKE_BUILD_DIR)/compile_commands.json $(CLANG_DEPS) $(SOURCES) infer-out-no-index/report.json: $(CMAKE_BUILD_DIR)/compile_commands.json $(CLANG_DEPS) $(SOURCES)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing Clang compilation database integration,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) -o infer-out-no-index --compilation-database $<) $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) -o $(@D) --compilation-database $<)
infer-out-reactive-capture/report.json: $(CMAKE_BUILD_DIR)/compile_commands.json $(CLANG_DEPS) $(SOURCES) infer-out-reactive-capture/report.json: $(CMAKE_BUILD_DIR)/compile_commands.json $(CLANG_DEPS) $(SOURCES)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing Clang compilation database reactive capture integration,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) -o infer-out-reactive-capture --reactive-capture \ $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) -o $(@D) --reactive-capture \
--changed-files-index $(CMAKE_DIR)/index.txt --compilation-database $<) --changed-files-index $(CMAKE_DIR)/index.txt --compilation-database $<)
issues.exp.test: infer-out-with-index/report.json infer-out-no-index/report.json infer-out-reactive-capture/report.json issues.exp.test: infer-out-with-index/report.json infer-out-no-index/report.json infer-out-reactive-capture/report.json
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.with-index \ $(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.with-index \
--from-json-report infer-out-with-index/report.json --from-json-report infer-out-with-index/report.json
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.no-index \ $(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.no-index \
--from-json-report infer-out-no-index/report.json --from-json-report infer-out-no-index/report.json
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.reactive-capture \ $(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.reactive-capture \
--from-json-report infer-out-reactive-capture/report.json --from-json-report infer-out-reactive-capture/report.json
cat $@.with-index $@.no-index $@.reactive-capture > $@ $(QUIET)cat $@.with-index $@.no-index $@.reactive-capture > $@

@ -14,19 +14,19 @@ OBJECTS = $(SOURCES:.c=.o)
CLEAN_EXTRA = compile_commands.json CLEAN_EXTRA = compile_commands.json
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
../codetoanalyze/path\ with\ spaces/hel\ lo.c: ../codetoanalyze/path_with_spaces/hel_lo.c ../codetoanalyze/path\ with\ spaces/hel\ lo.c: ../codetoanalyze/path_with_spaces/hel_lo.c
# make does not want to interpret "$(@D)" in the right way here... # make does not want to interpret "$(@D)" in the right way here...
$(MKDIR_P) ../codetoanalyze/path\ with\ spaces/ $(QUIET)$(MKDIR_P) ../codetoanalyze/path\ with\ spaces/
$(QUIET)cp "$<" "$@" $(QUIET)cp "$<" "$@"
$(QUIET)touch "$@" $(QUIET)touch "$@"
compile_commands.json: compile_commands.json.in compile_commands.json: compile_commands.json.in
sed -e 's#%pwd%#$(CURDIR)#g' $< > $@ || $(REMOVE) $@ $(QUIET)sed -e 's#%pwd%#$(CURDIR)#g' $< > $@ || $(REMOVE) $@
infer-out/report.json: compile_commands.json $(SOURCES) Makefile \ infer-out/report.json: compile_commands.json $(SOURCES) Makefile \
../codetoanalyze/path\ with\ spaces/hel\ lo.c ../codetoanalyze/path\ with\ spaces/hel\ lo.c
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Clang compilation database escaped integration,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --project-root $(TESTS_DIR) \ $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --project-root $(TESTS_DIR) \
--compilation-database-escaped $<) --compilation-database-escaped $<)

@ -16,19 +16,19 @@ OBJECTS = $(SOURCES:.c=.o)
CLEAN_EXTRA = compile_commands.json ../codetoanalyze/path\ with\ spaces CLEAN_EXTRA = compile_commands.json ../codetoanalyze/path\ with\ spaces
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
../codetoanalyze/path\ with\ spaces/hel\ lo.c: ../codetoanalyze/path_with_spaces/hel_lo.c ../codetoanalyze/path\ with\ spaces/hel\ lo.c: ../codetoanalyze/path_with_spaces/hel_lo.c
# make does not want to interpret "$(@D)" in the right way here... # make does not want to interpret "$(@D)" in the right way here...
$(MKDIR_P) ../codetoanalyze/path\ with\ spaces/ $(QUIET)$(MKDIR_P) ../codetoanalyze/path\ with\ spaces/
$(QUIET)cp "$<" "$@" $(QUIET)cp "$<" "$@"
$(QUIET)touch "$@" $(QUIET)touch "$@"
compile_commands.json: compile_commands.json.in compile_commands.json: compile_commands.json.in
sed -e 's#%pwd%#$(CURDIR)#g' $< > $@ || $(REMOVE) $@ $(QUIET)sed -e 's#%pwd%#$(CURDIR)#g' $< > $@ || $(REMOVE) $@
infer-out/report.json: compile_commands.json $(SOURCES) Makefile \ infer-out/report.json: compile_commands.json $(SOURCES) Makefile \
../codetoanalyze/path\ with\ spaces/hel\ lo.c ../codetoanalyze/path\ with\ spaces/hel\ lo.c
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Clang compilation database with relative paths integration,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --project-root $(TESTS_DIR) \ $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --project-root $(TESTS_DIR) \
--compilation-database $<) --compilation-database $<)

@ -29,15 +29,15 @@ INFER_OPTIONS = -a capture --frontend-tests --skip-translation-headers exclude_d
capture: $(DOT_FILES) capture: $(DOT_FILES)
$(ROOT)/main.cpp.test.dot $(SYM_ROOT)/main_symlink.cpp.test.dot: $(SOURCES) $(CLANG_DEPS) $(ROOT)/main.cpp.test.dot $(SYM_ROOT)/main_symlink.cpp.test.dot: $(SOURCES) $(CLANG_DEPS)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing clang translation with symlinks with project root,\
$(INFER_BIN) $(INFER_OPTIONS) --results-dir infer-out-$(basename $(@F:.test.dot=)) \ $(INFER_BIN) $(INFER_OPTIONS) --results-dir infer-out-$(basename $(@F:.test.dot=)) \
--project-root $(ROOT) --icfg-dotty-outfile $@ -- \ --project-root $(ROOT) --icfg-dotty-outfile $@ -- \
clang $(CLANG_OPTIONS) $(@:.test.dot=)) clang $(CLANG_OPTIONS) $(@:.test.dot=))
$(ROOT)/main_default_root.cpp.test.dot $(SYM_ROOT)/main_default_symlink.cpp.test.dot: \ $(ROOT)/main_default_root.cpp.test.dot $(SYM_ROOT)/main_default_symlink.cpp.test.dot: \
$(CLANG_DEPS) $(SOURCES) $(CLANG_DEPS) $(SOURCES)
cd $(@D) && \ $(QUIET)cd $(@D) && \
$(call silent_on_success,\ $(call silent_on_success,Testing clang translation with symlinks with CWD=project root,\
$(INFER_BIN) $(INFER_OPTIONS) --results-dir $(CURDIR)/infer-out-$(basename $(@F:.test.dot=)) \ $(INFER_BIN) $(INFER_OPTIONS) --results-dir $(CURDIR)/infer-out-$(basename $(@F:.test.dot=)) \
--icfg-dotty-outfile $(@F) -- \ --icfg-dotty-outfile $(@F) -- \
clang $(CLANG_OPTIONS) $(@F:.test.dot=)) clang $(CLANG_OPTIONS) $(@F:.test.dot=))
@ -48,6 +48,9 @@ test: test_extra
# all dot files should be exactly the same - if they aren't there is something wrong # all dot files should be exactly the same - if they aren't there is something wrong
test_extra: $(DOT_FILES) test_extra: $(DOT_FILES)
diff -u $(ROOT)/main.cpp.test.dot $(SYM_ROOT)/main_symlink.cpp.test.dot $(QUIET)$(call check_no_diff,$(ROOT)/main.cpp.test.dot,\
diff -u $(ROOT)/main.cpp.test.dot $(ROOT)/main_default_root.cpp.test.dot $(SYM_ROOT)/main_symlink.cpp.test.dot)
diff -u $(ROOT)/main.cpp.test.dot $(SYM_ROOT)/main_default_symlink.cpp.test.dot $(QUIET)$(call check_no_diff,$(ROOT)/main.cpp.test.dot,\
$(ROOT)/main_default_root.cpp.test.dot)
$(QUIET)$(call check_no_diff,$(ROOT)/main.cpp.test.dot,\
$(SYM_ROOT)/main_default_symlink.cpp.test.dot)

@ -18,7 +18,7 @@ SOURCES = $(CMAKE_DIR)/hello.c
OBJECTS = $(CMAKE_BUILD_DIR)/CMakeFiles/Hello.dir/hello.c.o OBJECTS = $(CMAKE_BUILD_DIR)/CMakeFiles/Hello.dir/hello.c.o
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
$(CMAKE_BUILD_DIR)/Makefile: $(CMAKE_DIR)/CMakeLists.txt $(CMAKE_BUILD_DIR)/Makefile: $(CMAKE_DIR)/CMakeLists.txt
$(QUIET)$(MKDIR_P) $(CMAKE_BUILD_DIR) $(QUIET)$(MKDIR_P) $(CMAKE_BUILD_DIR)
@ -31,12 +31,12 @@ $(OBJECTS): $(SOURCES) $(CMAKE_BUILD_DIR)/Makefile
infer-out/report.json: $(SOURCES) $(CMAKE_DIR)/CMakeLists.txt $(CLANG_DEPS) infer-out/report.json: $(SOURCES) $(CMAKE_DIR)/CMakeLists.txt $(CLANG_DEPS)
# nuke the build dir and recreate everything to avoid stale compilation/analysis results # nuke the build dir and recreate everything to avoid stale compilation/analysis results
$(QUIET)$(REMOVE_DIR) $(CMAKE_ANALYZE_DIR) && \ $(QUIET)$(REMOVE_DIR) $(CMAKE_ANALYZE_DIR)
$(MKDIR_P) $(CMAKE_ANALYZE_DIR) && \ $(QUIET)$(MKDIR_P) $(CMAKE_ANALYZE_DIR)
cd $(CMAKE_ANALYZE_DIR) && \ $(QUIET)cd $(CMAKE_ANALYZE_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Testing CMake integration: Generate Makefiles,\
$(INFER_BIN) -a compile $(INFER_OPTIONS) -- cmake ..) $(INFER_BIN) -a compile $(INFER_OPTIONS) -- cmake ..)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing CMake integration: Run Makefiles,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) -- $(MAKE) -C $(CMAKE_ANALYZE_DIR)) $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) -- $(MAKE) -C $(CMAKE_ANALYZE_DIR))
# cmake makes all paths absolute # cmake makes all paths absolute
$(QUIET)sed -i -e 's#$(abspath $(TESTS_DIR))/##g' $@ $(QUIET)sed -i -e 's#$(abspath $(TESTS_DIR))/##g' $@

@ -14,4 +14,4 @@ all: $(OBJECTS)
$(CC) -c $< $(CC) -c $<
clean: clean:
$(QUIET)rm -rf $(OBJECTS) rm -rf $(OBJECTS)

@ -23,9 +23,9 @@ SOURCES = $(CODETOANALYZE_DIR)/hello.c $(CODETOANALYZE_DIR)/hello2.c
include $(TESTS_DIR)/clang.make include $(TESTS_DIR)/clang.make
infer-out/report.json: $(CLANG_DEPS) $(SOURCES) infer-out/report.json: $(CLANG_DEPS) $(SOURCES)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing that infer deletes the results directory: part 1/2,\
$(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- clang $(CLANG_OPTIONS) $(CODETOANALYZE_DIR)/hello.c) $(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- clang $(CLANG_OPTIONS) $(CODETOANALYZE_DIR)/hello.c)
grep "DUPLICATE_SYMBOLS" infer-out/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out/duplicates.txt)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing that infer deletes the results directory: part 2/2,\
$(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- clang $(CLANG_OPTIONS) $(CODETOANALYZE_DIR)/hello2.c) $(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- clang $(CLANG_OPTIONS) $(CODETOANALYZE_DIR)/hello2.c)
grep "DUPLICATE_SYMBOLS" infer-out/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out/duplicates.txt)

@ -14,13 +14,13 @@ CLEAN_EXTRA = src/com/example/Diff*.java src/Diff*.java *.class com/
include ../../differential.make include ../../differential.make
$(CURRENT_REPORT): .inferconfig $(CURRENT_REPORT): .inferconfig
cp src/com/example/DiffExample.java.current src/com/example/DiffExample.java $(QUIET)$(COPY) src/com/example/DiffExample.java.current src/com/example/DiffExample.java
cp src/DiffExampleTwo.java.current src/DiffExampleTwo.java $(QUIET)$(COPY) src/DiffExampleTwo.java.current src/DiffExampleTwo.java
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing Differential resolves Infer/Eradicate conflicts: current,\
$(INFER_BIN) \ $(INFER_BIN) \
-o $(CURRENT_DIR) -- $(JAVAC) src/com/example/DiffExample.java src/DiffExampleTwo.java) -o $(CURRENT_DIR) -- $(JAVAC) src/com/example/DiffExample.java src/DiffExampleTwo.java)
$(PREVIOUS_REPORT): .inferconfig $(PREVIOUS_REPORT): .inferconfig
cp src/com/example/DiffExample.java.previous src/com/example/DiffExample.java $(QUIET)$(COPY) src/com/example/DiffExample.java.previous src/com/example/DiffExample.java
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing Differential resolves Infer/Eradicate conflicts: previous,\
$(INFER_BIN) -o $(PREVIOUS_DIR) -- $(JAVAC) src/com/example/DiffExample.java) $(INFER_BIN) -o $(PREVIOUS_DIR) -- $(JAVAC) src/com/example/DiffExample.java)

@ -13,9 +13,11 @@ CLEAN_EXTRA = src/Diff*.java *.class
include ../../differential.make include ../../differential.make
$(CURRENT_REPORT): $(CURRENT_REPORT):
cp src/DiffExample.java.current src/DiffExample.java $(QUIET)$(COPY) src/DiffExample.java.current src/DiffExample.java
$(call silent_on_success, $(INFER_BIN) -o $(CURRENT_DIR) -- $(JAVAC) src/*.java) $(QUIET)$(call silent_on_success,Testing Differential skips anon class renamings: current,\
$(INFER_BIN) -o $(CURRENT_DIR) -- $(JAVAC) src/*.java)
$(PREVIOUS_REPORT): $(PREVIOUS_REPORT):
cp src/DiffExample.java.previous src/DiffExample.java $(QUIET)$(COPY) src/DiffExample.java.previous src/DiffExample.java
$(call silent_on_success, $(INFER_BIN) -o $(PREVIOUS_DIR) -- $(JAVAC) src/*.java) $(QUIET)$(call silent_on_success,Testing Differential skips anon class renamings: previous,\
$(INFER_BIN) -o $(PREVIOUS_DIR) -- $(JAVAC) src/*.java)

@ -13,12 +13,14 @@ CLEAN_EXTRA = src/Diff*.java src/Diff*.java *.class
include ../../differential.make include ../../differential.make
$(CURRENT_REPORT): $(CURRENT_REPORT):
cp src/DiffExample.java.current src/DiffExample.java $(QUIET)$(COPY) src/DiffExample.java.current src/DiffExample.java
cp src/DiffExampleTwo.java.current src/DiffExampleTwo.java $(QUIET)$(COPY) src/DiffExampleTwo.java.current src/DiffExampleTwo.java
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing\
Differential skips duplicated types on filenames: current,\
$(INFER_BIN) -o $(CURRENT_DIR) -- $(JAVAC) src/DiffExample.java src/DiffExampleTwo.java) $(INFER_BIN) -o $(CURRENT_DIR) -- $(JAVAC) src/DiffExample.java src/DiffExampleTwo.java)
$(PREVIOUS_REPORT): $(PREVIOUS_REPORT):
cp src/DiffExample.java.previous src/DiffExample.java $(QUIET)$(COPY) src/DiffExample.java.previous src/DiffExample.java
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing\
Differential skips duplicated types on filenames: previous,\
$(INFER_BIN) -o $(PREVIOUS_DIR) -- $(JAVAC) src/DiffExample.java) $(INFER_BIN) -o $(PREVIOUS_DIR) -- $(JAVAC) src/DiffExample.java)

@ -14,11 +14,13 @@ CLEAN_EXTRA = src/Diff*.java *.class
include ../../differential.make include ../../differential.make
$(CURRENT_REPORT): $(CURRENT_REPORT):
cp src/DiffExampleRenamed.java.current src/DiffExampleRenamed.java $(QUIET)$(COPY) src/DiffExampleRenamed.java.current src/DiffExampleRenamed.java
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing\
Differential skips duplicated types on renamed files: current,\
$(INFER_BIN) -o $(CURRENT_DIR) -- $(JAVAC) src/DiffExampleRenamed.java) $(INFER_BIN) -o $(CURRENT_DIR) -- $(JAVAC) src/DiffExampleRenamed.java)
$(PREVIOUS_REPORT): $(PREVIOUS_REPORT):
cp src/DiffExample.java.previous src/DiffExample.java $(QUIET)$(COPY) src/DiffExample.java.previous src/DiffExample.java
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing\
Differential skips duplicated types on renamed files: previous,\
$(INFER_BIN) -o $(PREVIOUS_DIR) -- $(JAVAC) src/DiffExample.java) $(INFER_BIN) -o $(PREVIOUS_DIR) -- $(JAVAC) src/DiffExample.java)

@ -7,6 +7,8 @@
TESTS_DIR = ../.. TESTS_DIR = ../..
include $(TESTS_DIR)/base.make
ANALYZER = infer ANALYZER = infer
CODETOANALYZE_DIR = ../codetoanalyze CODETOANALYZE_DIR = ../codetoanalyze
@ -18,17 +20,10 @@ INFERPRINT_OPTIONS = --issues-tests
SOURCES = $(CODETOANALYZE_DIR)/hello.c SOURCES = $(CODETOANALYZE_DIR)/hello.c
OBJECTS = $(foreach source,$(SOURCES),$(basename $(source)).o) OBJECTS = $(foreach source,$(SOURCES),$(basename $(source)).o)
ROOT_DIR = $(TESTS_DIR)/../..
include $(ROOT_DIR)/Makefile.config
# see base.make
TEST_REL_DIR = $(patsubst $(abspath $(TESTS_DIR))/%,%,$(abspath $(CURDIR)))
default: compile default: compile
issues.exp.test: $(CLANG_DEPS) $(SOURCES) issues.exp.test: $(CLANG_DEPS) $(SOURCES)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing Infer fails on issue,\
($(INFER_BIN) --fail-on-issue -- clang $(CLANG_OPTIONS) $(SOURCES); \ ($(INFER_BIN) --fail-on-issue -- clang $(CLANG_OPTIONS) $(SOURCES); \
echo "infer exit code: $$?" > $@)) echo "infer exit code: $$?" > $@))
@ -41,7 +36,7 @@ print: issues.exp.test
.PHONY: test .PHONY: test
test: issues.exp.test test: issues.exp.test
$(QUIET)cd $(TESTS_DIR) && \ $(QUIET)cd $(TESTS_DIR) && \
diff -u $(TEST_REL_DIR)/issues.exp $(TEST_REL_DIR)/issues.exp.test $(call check_no_diff,$(TEST_REL_DIR)/issues.exp,$(TEST_REL_DIR)/issues.exp.test)
.PHONY: replace .PHONY: replace
replace: issues.exp.test replace: issues.exp.test

@ -19,11 +19,11 @@ INFERPRINT_OPTIONS = --project-root $(ROOT_DIR) --issues-tests
CLEAN_EXTRA = $(ROOT_DIR)/buck-out/genruletest CLEAN_EXTRA = $(ROOT_DIR)/buck-out/genruletest
include $(TESTS_DIR)/java.make include $(TESTS_DIR)/java.make
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
$(OBJECTS): $(JAVA_SOURCE_FILES) $(OBJECTS): $(JAVA_SOURCE_FILES)
cd $(ROOT_DIR) && \ $(QUIET)cd $(ROOT_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Compiling Buck genrule for Java sources,\
NO_BUCKD=1 $(BUCK) build --no-cache $(BUCK_TARGET)) NO_BUCKD=1 $(BUCK) build --no-cache $(BUCK_TARGET))
.PHONY: genrule .PHONY: genrule
@ -31,14 +31,14 @@ genrule: $(JSON_REPORT)
$(JSON_REPORT): $(JAVA_DEPS) $(JAVA_SOURCE_FILES) $(JSON_REPORT): $(JAVA_DEPS) $(JAVA_SOURCE_FILES)
cd $(ROOT_DIR) && \ $(QUIET)cd $(ROOT_DIR) && \
$(REMOVE_DIR) buck-out && \ $(REMOVE_DIR) buck-out && \
$(call silent_on_success,\ $(call silent_on_success,Testing Buck genrule for Java integration,\
INFER_BIN="$(INFER_BIN)" NO_BUCKD=1 GENERATE_INFER_GENRULES=1 \ INFER_BIN="$(INFER_BIN)" NO_BUCKD=1 GENERATE_INFER_GENRULES=1 \
$(BUCK) build --no-cache $(INFER_TARGET)) $(BUCK) build --no-cache $(INFER_TARGET))
touch $@ $(QUIET)touch $@
infer-out/report.json: $(JSON_REPORT) infer-out/report.json: $(JSON_REPORT)
$(MKDIR_P) infer-out $(QUIET)$(MKDIR_P) infer-out
# the report contains absolute paths # the report contains absolute paths
$(QUIET)sed -e 's#$(abspath $(TESTS_DIR))/##g' $< > $@ $(QUIET)sed -e 's#$(abspath $(TESTS_DIR))/##g' $< > $@

@ -16,11 +16,11 @@ OBJECTS =
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
include $(TESTS_DIR)/java.make include $(TESTS_DIR)/java.make
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
infer-out/report.json: $(JAVA_DEPS) $(SOURCES) infer-out/report.json: $(JAVA_DEPS) $(SOURCES)
# mock version of gradle # mock version of gradle
PATH=$(CURDIR)/../mock:"$$PATH"; \ $(QUIET)PATH=$(CURDIR)/../mock:"$$PATH"; \
cd $(SOURCES_DIR) && \ cd $(SOURCES_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Testing gradle Java integration,\
$(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/infer-out -- gradle build) $(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/infer-out -- gradle build)

@ -5,8 +5,11 @@
# LICENSE file in the root directory of this source tree. An additional grant # LICENSE file in the root directory of this source tree. An additional grant
# of patent rights can be found in the PATENTS file in the same directory. # of patent rights can be found in the PATENTS file in the same directory.
ROOT_DIR = ../../../..
include $(ROOT_DIR)/Makefile.config
default: compile default: compile
.PHONY: print replace test clean .PHONY: print replace test clean
print replace test clean: print replace test clean:
INFER_ARGS=-j^1 $(MAKE) -C ../../codetoanalyze/cpp/checkers TEST_SUFFIX=-j1 $@ $(QUIET)INFER_ARGS=-j^1 $(MAKE) -C ../../codetoanalyze/cpp/checkers TEST_SUFFIX=-j1 $@

@ -17,7 +17,7 @@ SOURCES = $(wildcard ../codetoanalyze/make/*.c)
include $(TESTS_DIR)/clang.make include $(TESTS_DIR)/clang.make
infer-out/report.json: $(CLANG_DEPS) $(SOURCES) $(HEADERS) infer-out/report.json: $(CLANG_DEPS) $(SOURCES) $(HEADERS)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing make clang integration,\
$(INFER_BIN) --dump-duplicate-symbols --project-root $(TESTS_DIR) -a $(ANALYZER) -- \ $(INFER_BIN) --dump-duplicate-symbols --project-root $(TESTS_DIR) -a $(ANALYZER) -- \
make -C ../codetoanalyze/make clean all) make -C ../codetoanalyze/make clean all)
grep "DUPLICATE_SYMBOLS" infer-out/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out/duplicates.txt)

@ -19,15 +19,15 @@ CLEAN_EXTRA = \
$(MVN_DIRS:%=issues-%.exp.test) $(MVN_DIRS:%=issues-%.exp.test)
include $(TESTS_DIR)/java.make include $(TESTS_DIR)/java.make
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
infer-out/report.json: infer-out/report.json:
$(MKDIR_P) $(@D) $(QUIET)$(MKDIR_P) $(@D)
touch $@ $(QUIET)touch $@
infer-out-%/report.json: $(JAVA_DEPS) $(SOURCES) infer-out-%/report.json: $(JAVA_DEPS) $(SOURCES)
cd ../codetoanalyze/mvn/$* && \ $(QUIET)cd ../codetoanalyze/mvn/$* && \
$(call silent_on_success,\ $(call silent_on_success,Testing mvn Java integration: $*,\
$(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) \ $(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) \
--project-root $(CURDIR)/$(TESTS_DIR) -- \ --project-root $(CURDIR)/$(TESTS_DIR) -- \
$(MVN) clean compile) $(MVN) clean compile)
@ -39,13 +39,13 @@ infer-out-simple_app/report.json: infer-out-app_with_infer_profile/report.json
infer-out-app_with_infer_profile/report.json: infer-out-app_with_profiles/report.json infer-out-app_with_infer_profile/report.json: infer-out-app_with_profiles/report.json
issues-%.exp.test: infer-out-%/report.json issues-%.exp.test: infer-out-%/report.json
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@ --from-json-report $< $(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@ --from-json-report $<
issues.exp.test: $(foreach mvndir,$(MVN_DIRS),issues-$(mvndir).exp.test) issues.exp.test: $(foreach mvndir,$(MVN_DIRS),issues-$(mvndir).exp.test)
# erase the contents of the file # erase the contents of the file
: > $@ $(QUIET): > $@
# remember the file name so it's easier to know which bug is from where # remember the file name so it's easier to know which bug is from where
for mvndir in $(MVN_DIRS); do \ $(QUIET)for mvndir in $(MVN_DIRS); do \
echo "-- $$mvndir" >> $@; \ echo "-- $$mvndir" >> $@; \
cat issues-$$mvndir.exp.test >> $@; \ cat issues-$$mvndir.exp.test >> $@; \
done done

@ -15,14 +15,14 @@ OBJECTS = $(PROJECT_ROOT)/hello.o
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
CLEAN_EXTRA = libs obj CLEAN_EXTRA = libs obj
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
$(OBJECTS): $(SOURCES) $(OBJECTS): $(SOURCES)
cd $(PROJECT_ROOT) && \ cd $(PROJECT_ROOT) && \
$(NDKBUILD) -B NDK_LIBS_OUT=./libs NDK_OUT=./obj $(NDKBUILD) -B NDK_LIBS_OUT=./libs NDK_OUT=./obj
infer-out/report.json: $(CLANG_DEPS) $(SOURCES) infer-out/report.json: $(CLANG_DEPS) $(SOURCES)
cd $(PROJECT_ROOT) && \ $(QUIET)cd $(PROJECT_ROOT) && \
$(call silent_on_success,\ $(call silent_on_success,Testing ndk-build clang integration,\
$(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/infer-out -- \ $(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/infer-out -- \
$(NDKBUILD) -B NDK_LIBS_OUT=./libs NDK_OUT=./obj) $(NDKBUILD) -B NDK_LIBS_OUT=./libs NDK_OUT=./obj)

@ -21,15 +21,15 @@ SOURCES = $(SOURCES1) $(SOURCES2) $(SOURCES3)
include $(TESTS_DIR)/clang.make include $(TESTS_DIR)/clang.make
infer-out/report.json: $(CLANG_DEPS) $(SOURCES) $(HEADERS) infer-out/report.json: $(CLANG_DEPS) $(SOURCES) $(HEADERS)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing reactive mode: capture 1/3,\
$(INFER_BIN) $(INFER_OPTIONS) -a capture -- \ $(INFER_BIN) $(INFER_OPTIONS) -a capture -- \
clang $(CLANG_OPTIONS) $(SOURCES1)) clang $(CLANG_OPTIONS) $(SOURCES1))
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing reactive mode: capture 2/3,\
$(INFER_BIN) $(INFER_OPTIONS) -a capture --reactive --continue -- \ $(INFER_BIN) $(INFER_OPTIONS) -a capture --reactive --continue -- \
clang $(CLANG_OPTIONS) $(SOURCES2)) clang $(CLANG_OPTIONS) $(SOURCES2))
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing reactive mode: capture 3/3,\
$(INFER_BIN) $(INFER_OPTIONS) -a capture --reactive --continue -- \ $(INFER_BIN) $(INFER_OPTIONS) -a capture --reactive --continue -- \
clang $(CLANG_OPTIONS) $(SOURCES3)) clang $(CLANG_OPTIONS) $(SOURCES3))
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing reactive mode: analysis,\
$(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- analyze) $(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- analyze)
grep "DUPLICATE_SYMBOLS" infer-out/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out/duplicates.txt)

@ -19,16 +19,18 @@ include $(TESTS_DIR)/clang.make
infer-out/report.json: $(CLANG_DEPS) $(INFERTRACEBUGS_BIN) $(SOURCES) $(HEADERS) $(MAKEFILE_LIST) infer-out/report.json: $(CLANG_DEPS) $(INFERTRACEBUGS_BIN) $(SOURCES) $(HEADERS) $(MAKEFILE_LIST)
# set non-utf8-supporting locale # set non-utf8-supporting locale
LC_ALL=C; \ $(QUIET)LC_ALL=C; \
$(call silent_on_success,\ $(call silent_on_success,Testing Infer is immune to UTF-8 in procnames,\
$(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- clang $(CLANG_OPTIONS) $(SOURCES)) $(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- clang $(CLANG_OPTIONS) $(SOURCES))
grep "DUPLICATE_SYMBOLS" infer-out/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out/duplicates.txt)
# make sure inferTraceBugs is immune to UTF-8 # make sure inferTraceBugs is immune to UTF-8
$(call silent_on_success, $(INFERTRACEBUGS_BIN) --max-level max --select 0) $(QUIET)$(call silent_on_success,Testing inferTraceBugs is immune to UTF-8 in procnames,\
$(call silent_on_success, $(INFERTRACEBUGS_BIN) --html) $(INFERTRACEBUGS_BIN) --max-level max --select 0)
[ -f infer-out/report.html/index.html ] $(QUIET)$(call silent_on_success,Testing inferTraceBugs --html is immune to UTF-8 in procnames,\
$(INFERTRACEBUGS_BIN) --html)
$(QUIET)[ -f infer-out/report.html/index.html ]
# run again to check that infer manages to delete the results directory # run again to check that infer manages to delete the results directory
LC_ALL=C; \ $(QUIET)LC_ALL=C; \
$(call silent_on_success,\ $(call silent_on_success,Testing Infer rerun is immune to UTF-8 in procnames,\
$(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- clang $(CLANG_OPTIONS) $(SOURCES)) $(INFER_BIN) --dump-duplicate-symbols $(INFER_OPTIONS) -a $(ANALYZER) -- clang $(CLANG_OPTIONS) $(SOURCES))
grep "DUPLICATE_SYMBOLS" infer-out/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out/duplicates.txt)

@ -10,13 +10,9 @@
# or 'analyze' target. # or 'analyze' target.
TESTS_DIR = ../.. TESTS_DIR = ../..
ROOT_DIR = $(TESTS_DIR)/../..
include $(TESTS_DIR)/java.make include $(TESTS_DIR)/java.make
include $(ROOT_DIR)/Makefile.config include $(TESTS_DIR)/base.make
# see base.make
TEST_REL_DIR = $(patsubst $(abspath $(TESTS_DIR))/%,%,$(abspath $(CURDIR)))
UTF8_DIR = $(shell printf '../codetoanalyze/utf8_\u03B9n_pwd') UTF8_DIR = $(shell printf '../codetoanalyze/utf8_\u03B9n_pwd')
@ -44,61 +40,63 @@ INFERPRINT_OPTIONS = --issues-tests
default: print default: print
$(UTF8_DIR): $(UTF8_DIR):
$(MKDIR_P) $@ $(QUIET)$(MKDIR_P) $@
$(CMAKE_DIR): $(CMAKE_SOURCES) $(UTF8_DIR) $(CMAKE_DIR): $(CMAKE_SOURCES) $(UTF8_DIR)
rsync -aL --exclude='_build*' $(CMAKE_SOURCES_DIR)/ $@/ $(QUIET)rsync -aL --exclude='_build*' $(CMAKE_SOURCES_DIR)/ $@/
touch $@ $(QUIET)touch $@
$(GRADLE_DIR): $(GRADLE_SOURCES) $(UTF8_DIR) $(GRADLE_DIR): $(GRADLE_SOURCES) $(UTF8_DIR)
rsync -a $(GRADLE_SOURCES_DIR)/ $@/ $(QUIET)rsync -a $(GRADLE_SOURCES_DIR)/ $@/
touch $@ $(QUIET)touch $@
$(JAVAC_DIR): $(JAVAC_SOURCES) $(UTF8_DIR) $(JAVAC_DIR): $(JAVAC_SOURCES) $(UTF8_DIR)
$(MKDIR_P) $(JAVAC_DIR) $(QUIET)$(MKDIR_P) $(JAVAC_DIR)
rsync -a $(JAVAC_SOURCES) $@ $(QUIET)rsync -a $(JAVAC_SOURCES) $@
touch $@ $(QUIET)touch $@
$(MAKE_DIR): $(MAKE_SOURCES) $(UTF8_DIR) $(MAKE_DIR): $(MAKE_SOURCES) $(UTF8_DIR)
rsync -a $(MAKE_SOURCES_DIR)/ $@/ $(QUIET)rsync -a $(MAKE_SOURCES_DIR)/ $@/
touch $@ $(QUIET)touch $@
infer-out-cmake/report.json: $(CMAKE_DIR) $(CMAKE_SOURCES_DIR)/CMakeLists.txt $(CLANG_DEPS) infer-out-cmake/report.json: $(CMAKE_DIR) $(CMAKE_SOURCES_DIR)/CMakeLists.txt $(CLANG_DEPS)
$(REMOVE_DIR) $(CMAKE_ANALYZE_DIR) && \ $(QUIET)$(REMOVE_DIR) $(CMAKE_ANALYZE_DIR)
$(MKDIR_P) $(CMAKE_ANALYZE_DIR) && \ $(QUIET)$(MKDIR_P) $(CMAKE_ANALYZE_DIR)
cd $(CMAKE_ANALYZE_DIR) && \ $(QUIET)cd $(CMAKE_ANALYZE_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Testing\
Infer/CMake is immune to UTF-8 in PWD: Makefile generation,\
$(INFER_BIN) -a compile --project-root $(CMAKE_DIR) --results-dir $(CURDIR)/$(@D) -- cmake ..) $(INFER_BIN) -a compile --project-root $(CMAKE_DIR) --results-dir $(CURDIR)/$(@D) -- cmake ..)
cd $(CMAKE_ANALYZE_DIR) && \ $(QUIET)cd $(CMAKE_ANALYZE_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Testing\
$(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) -- $(MAKE)) Infer/CMake is immune to UTF-8 in PWD: Makefile execution,\
sed -i -e 's#$(abspath $(CMAKE_DIR))/##g' $@ $(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) -- make)
$(QUIET)sed -i -e 's#$(abspath $(CMAKE_DIR))/##g' $@
infer-out-gradle/report.json: $(JAVA_DEPS) $(GRADLE_DIR) infer-out-gradle/report.json: $(JAVA_DEPS) $(GRADLE_DIR)
# mock version of gradle # mock version of gradle
PATH=$(CURDIR)/../mock:"$$PATH"; \ $(QUIET)PATH=$(CURDIR)/../mock:"$$PATH"; \
cd $(GRADLE_DIR) && \ cd $(GRADLE_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Testing Infer/gradle is immune to UTF-8 in PWD,\
$(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) -- gradle build) $(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) -- gradle build)
infer-out-javac/report.json: $(JAVA_DEPS) $(JAVAC_DIR) infer-out-javac/report.json: $(JAVA_DEPS) $(JAVAC_DIR)
cd $(JAVAC_DIR) && \ $(QUIET)cd $(JAVAC_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Testing Infer/javac is immune to UTF-8 in PWD,\
$(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) -- \ $(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) -- \
$(JAVAC) -cp $(CLASSPATH) $(foreach source,$(JAVAC_SOURCES),$(notdir $(source)))) $(JAVAC) -cp $(CLASSPATH) $(foreach source,$(JAVAC_SOURCES),$(notdir $(source))))
infer-out-make/report.json: $(CLANG_DEPS) $(MAKE_DIR) infer-out-make/report.json: $(CLANG_DEPS) $(MAKE_DIR)
cd $(MAKE_DIR) && \ $(QUIET)cd $(MAKE_DIR) && \
$(call silent_on_success,\ $(call silent_on_success,Testing Infer/make is immune to UTF-8 in PWD,\
$(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) -- \ $(INFER_BIN) -a $(ANALYZER) --results-dir $(CURDIR)/$(@D) -- \
make clean all) make clean all)
issues-%.exp.test: infer-out-%/report.json $(INFERPRINT_BIN) issues-%.exp.test: infer-out-%/report.json $(INFERPRINT_BIN)
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@ --from-json-report $< $(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@ --from-json-report $<
issues.exp.test: issues-cmake.exp.test issues-gradle.exp.test issues-javac.exp.test \ issues.exp.test: issues-cmake.exp.test issues-gradle.exp.test issues-javac.exp.test \
issues-make.exp.test issues-make.exp.test
cat $^ > $@ $(QUIET)cat $^ > $@
.PHONY: print .PHONY: print
print: issues.exp.test print: issues.exp.test
@ -106,7 +104,7 @@ print: issues.exp.test
.PHONY: test .PHONY: test
test: issues.exp.test test: issues.exp.test
$(QUIET)cd $(TESTS_DIR) && \ $(QUIET)cd $(TESTS_DIR) && \
diff -u $(TEST_REL_DIR)/issues.exp $(TEST_REL_DIR)/issues.exp.test $(call check_no_diff,$(TEST_REL_DIR)/issues.exp,$(TEST_REL_DIR)/issues.exp.test)
.PHONY: replace .PHONY: replace
replace: issues.exp.test replace: issues.exp.test

@ -18,8 +18,8 @@ SOURCES = $(wildcard ../codetoanalyze/make/*.c)
include $(TESTS_DIR)/clang.make include $(TESTS_DIR)/clang.make
infer-out/report.json: $(CLANG_DEPS) $(SOURCES) infer-out/report.json: $(CLANG_DEPS) $(SOURCES)
$(MAKE) -C ../codetoanalyze/make clean $(QUIET)$(MAKE) -C ../codetoanalyze/make clean
cd ../codetoanalyze/make && \ $(QUIET)cd ../codetoanalyze/make && \
$(call silent_on_success,\ $(call silent_on_success,Testing Waf clang integration,\
$(INFER_BIN) --dump-duplicate-symbols --results-dir $(CUR_DIR)/$(@D) -a $(ANALYZER) -- \ $(INFER_BIN) --dump-duplicate-symbols --results-dir $(CUR_DIR)/$(@D) -a $(ANALYZER) -- \
./waf) ./waf)

@ -13,7 +13,7 @@ SOURCES = $(wildcard $(APP_DIR)/simple_app/*.m)
OBJECTS = $(APP_DIR)/app_built OBJECTS = $(APP_DIR)/app_built
INFERPRINT_OPTIONS = --issues-tests INFERPRINT_OPTIONS = --issues-tests
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
XCODEBUILD = xcodebuild -verbose -target simple_app -configuration Release -sdk iphonesimulator XCODEBUILD = xcodebuild -verbose -target simple_app -configuration Release -sdk iphonesimulator
@ -23,10 +23,11 @@ $(OBJECTS): $(SOURCES)
touch app_built touch app_built
infer-out/report.json: $(CLANG_DEPS) $(SOURCES) infer-out/report.json: $(CLANG_DEPS) $(SOURCES)
cd $(APP_DIR) && \ $(QUIET)cd $(APP_DIR) && \
$(XCODEBUILD) clean && \ $(XCODEBUILD) clean && \
$(call silent_on_success,\ $(call silent_on_success,Testing xcodebuild default integration,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --project-root $(TESTS_DIR) --results-dir $(CURDIR)/$(@D) -- $(XCODEBUILD)) $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --project-root $(TESTS_DIR) \
--results-dir $(CURDIR)/$(@D) -- $(XCODEBUILD))
clean: clean:
cd $(APP_DIR) && \ cd $(APP_DIR) && \

@ -5,11 +5,9 @@
# LICENSE file in the root directory of this source tree. An additional grant # LICENSE file in the root directory of this source tree. An additional grant
# of patent rights can be found in the PATENTS file in the same directory. # of patent rights can be found in the PATENTS file in the same directory.
ROOT_DIR = $(TESTS_DIR)/../..
include $(ROOT_DIR)/Makefile.config
OBJECTS = $(foreach source,$(SOURCES),$(basename $(source)).o) OBJECTS = $(foreach source,$(SOURCES),$(basename $(source)).o)
include $(TESTS_DIR)/base.make
include $(TESTS_DIR)/clang-base.make include $(TESTS_DIR)/clang-base.make
ONE_SOURCE = $(lastword $(SOURCES)) ONE_SOURCE = $(lastword $(SOURCES))
@ -19,7 +17,7 @@ default: compile
compile: $(OBJECTS) compile: $(OBJECTS)
$(ONE_SOURCE).test.dot: $(CLANG_DEPS) $(SOURCES) $(HEADERS) $(ONE_SOURCE).test.dot: $(CLANG_DEPS) $(SOURCES) $(HEADERS)
$(call silent_on_success, \ $(QUIET)$(call silent_on_success,Testing the infer/clang frontend in $(TEST_REL_DIR),\
$(INFER_BIN) -a capture --frontend-tests --project-root $(TESTS_DIR) $(INFER_OPTIONS) -- \ $(INFER_BIN) -a capture --frontend-tests --project-root $(TESTS_DIR) $(INFER_OPTIONS) -- \
clang $(CLANG_OPTIONS) $(SOURCES)) clang $(CLANG_OPTIONS) $(SOURCES))

@ -11,12 +11,12 @@ CLEAN_EXTRA += duplicates.txt
OBJECTS = $(foreach source,$(SOURCES),$(basename $(source)).o) OBJECTS = $(foreach source,$(SOURCES),$(basename $(source)).o)
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
include $(TESTS_DIR)/clang-base.make include $(TESTS_DIR)/clang-base.make
infer-out$(TEST_SUFFIX)/report.json: $(CLANG_DEPS) $(SOURCES) $(HEADERS) $(TESTS_DIR)/.inferconfig infer-out$(TEST_SUFFIX)/report.json: $(CLANG_DEPS) $(SOURCES) $(HEADERS) $(TESTS_DIR)/.inferconfig
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing infer/clang$(ANALYZER_STRING) in $(TEST_REL_DIR),\
$(INFER_BIN) --results-dir $(@D) --dump-duplicate-symbols \ $(INFER_BIN) --results-dir $(@D) --dump-duplicate-symbols \
$(INFER_OPTIONS) -a $(ANALYZER) -- \ $(INFER_OPTIONS) -a $(ANALYZER) -- \
clang $(CLANG_OPTIONS) $(SOURCES)) clang $(CLANG_OPTIONS) $(SOURCES))
grep "DUPLICATE_SYMBOLS" infer-out$(TEST_SUFFIX)/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out$(TEST_SUFFIX)/duplicates.txt)

@ -7,9 +7,7 @@
TESTS_DIR = ../../.. TESTS_DIR = ../../..
include $(TESTS_DIR)/java.make include $(TESTS_DIR)/java.make
include $(TESTS_DIR)/base.make
# see base.make
TEST_REL_DIR = $(patsubst $(abspath $(TESTS_DIR))/%,%,$(abspath $(CURDIR)))
ANALYZER = crashcontext ANALYZER = crashcontext
@ -23,15 +21,15 @@ $(OBJECTS): $(SOURCES)
# analyze a single source file and generate the test results for it # analyze a single source file and generate the test results for it
issues-%.exp.test: $(JAVA_DEPS) %.stacktrace.json %.java issues-%.exp.test: $(JAVA_DEPS) %.stacktrace.json %.java
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing crashcontext: $*,\
$(INFER_BIN) -a $(ANALYZER) -o infer-out-$* --stacktrace $*.stacktrace.json \ $(INFER_BIN) -a $(ANALYZER) -o infer-out-$* --stacktrace $*.stacktrace.json \
-- $(JAVAC) -cp $(CLASSPATH) $*.java) -- $(JAVAC) -cp $(CLASSPATH) $*.java)
# add a newline at the end of the json when creating the exp.test # add a newline at the end of the json when creating the exp.test
$(COPY) infer-out-$*/crashcontext/crashcontext.json $@ && echo >> $@ $(QUIET)$(COPY) infer-out-$*/crashcontext/crashcontext.json $@ && echo >> $@
# combine the test results for all the source files # combine the test results for all the source files
issues.exp.test: $(EXP_TESTs) issues.exp.test: $(EXP_TESTs)
cat $^ > issues.exp.test $(QUIET)cat $^ > $@
default: compile default: compile
@ -47,7 +45,7 @@ print: issues.exp.test
.PHONY: test .PHONY: test
test: issues.exp.test test: issues.exp.test
$(QUIET)cd $(TESTS_DIR) && \ $(QUIET)cd $(TESTS_DIR) && \
diff -u $(TEST_REL_DIR)/issues.exp $(TEST_REL_DIR)/issues.exp.test $(call check_no_diff,$(TEST_REL_DIR)/issues.exp,$(TEST_REL_DIR)/issues.exp.test)
.PHONY: replace .PHONY: replace
replace: issues.exp.test replace: issues.exp.test

@ -115,28 +115,28 @@ $(OBJECTS_BASE) $(OBJECTS_BUCKETS_ALL): $(SOURCES_BASE) $(SOURCES_BUCKET_ALL)
clang $(CLANG_OPTIONS) $* clang $(CLANG_OPTIONS) $*
infer-out-all/report.json: $(CLANG_DEPS) $(SOURCES_BUCKET_ALL) infer-out-all/report.json: $(CLANG_DEPS) $(SOURCES_BUCKET_ALL)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing infer/Objective-C with all memleak buckets,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --ml-buckets all -o infer-out-all -- \ $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --ml-buckets all -o infer-out-all -- \
clang $(CLANG_OPTIONS) $(SOURCES_BUCKET_ALL)) clang $(CLANG_OPTIONS) $(SOURCES_BUCKET_ALL))
grep "DUPLICATE_SYMBOLS" infer-out-all/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out-all/duplicates.txt)
infer-out-arc/report.json: $(CLANG_DEPS) $(SOURCES_ARC) infer-out-arc/report.json: $(CLANG_DEPS) $(SOURCES_ARC)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing infer/Objective-C with arc memleak buckets,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --ml-buckets cf -o infer-out-arc -- \ $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --ml-buckets cf -o infer-out-arc -- \
clang $(CLANG_OPTIONS) -fobjc-arc $(SOURCES_ARC)) clang $(CLANG_OPTIONS) -fobjc-arc $(SOURCES_ARC))
grep "DUPLICATE_SYMBOLS" infer-out-arc/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out-arc/duplicates.txt)
infer-out/report.json: $(CLANG_DEPS) $(SOURCES_DEFAULT) infer-out/report.json: $(CLANG_DEPS) $(SOURCES_DEFAULT)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing infer/Objective-C with CF memleak buckets,\
$(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --ml-buckets cf -o infer-out -- \ $(INFER_BIN) -a $(ANALYZER) $(INFER_OPTIONS) --ml-buckets cf -o infer-out -- \
clang $(CLANG_OPTIONS) $(SOURCES_DEFAULT)) clang $(CLANG_OPTIONS) $(SOURCES_DEFAULT))
grep "DUPLICATE_SYMBOLS" infer-out/duplicates.txt; test $$? -ne 0 $(QUIET)$(call check_no_duplicates,infer-out/duplicates.txt)
issues.exp.test: infer-out-all/report.json infer-out-arc/report.json infer-out/report.json issues.exp.test: infer-out-all/report.json infer-out-arc/report.json infer-out/report.json
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.all \ $(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.all \
--from-json-report infer-out-all/report.json --from-json-report infer-out-all/report.json
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.arc \ $(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.arc \
--from-json-report infer-out-arc/report.json --from-json-report infer-out-arc/report.json
$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.default \ $(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@.default \
--from-json-report infer-out/report.json --from-json-report infer-out/report.json
cat $@.all $@.arc $@.default > $@ $(QUIET)cat $@.all $@.arc $@.default > $@

@ -8,8 +8,7 @@
# Targets that must be defined: CURRENT_REPORT and PREVIOUS_REPORT # Targets that must be defined: CURRENT_REPORT and PREVIOUS_REPORT
# Optional variables: DIFFERENTIAL_ARGS, CLEAN_EXTRA # Optional variables: DIFFERENTIAL_ARGS, CLEAN_EXTRA
ROOT_DIR = $(TESTS_DIR)/../.. include $(TESTS_DIR)/base.make
include $(ROOT_DIR)/Makefile.config
INFER_OUT = infer-out INFER_OUT = infer-out
DIFFERENTIAL_REPORT = $(INFER_OUT)/differential/introduced.json DIFFERENTIAL_REPORT = $(INFER_OUT)/differential/introduced.json
@ -32,20 +31,21 @@ $(PREVIOUS_REPORT): $(CURRENT_REPORT)
analyze: $(CURRENT_REPORT) $(PREVIOUS_REPORT) analyze: $(CURRENT_REPORT) $(PREVIOUS_REPORT)
$(DIFFERENTIAL_REPORT): $(CURRENT_REPORT) $(PREVIOUS_REPORT) $(DIFFERENTIAL_REPORT): $(CURRENT_REPORT) $(PREVIOUS_REPORT)
$(INFER_BIN) -o $(INFER_OUT) --project-root $(CURDIR) --diff \ $(QUIET)$(call silent_on_success,Computing results difference in $(TEST_REL_DIR),\
$(INFER_BIN) -o $(INFER_OUT) --project-root $(CURDIR) --diff \
--report-current $(CURRENT_REPORT) --report-previous $(PREVIOUS_REPORT) \ --report-current $(CURRENT_REPORT) --report-previous $(PREVIOUS_REPORT) \
$(DIFFERENTIAL_ARGS) $(DIFFERENTIAL_ARGS))
$(EXPECTED_TEST_OUTPUT): $(DIFFERENTIAL_REPORT) $(INFERPRINT_BIN) $(EXPECTED_TEST_OUTPUT): $(DIFFERENTIAL_REPORT) $(INFERPRINT_BIN)
$(INFERPRINT_BIN) \ $(QUIET)$(INFERPRINT_BIN) \
--issues-fields $(INFERPRINT_ISSUES_FIELDS) \ --issues-fields $(INFERPRINT_ISSUES_FIELDS) \
--from-json-report $(INFER_OUT)/differential/introduced.json \ --from-json-report $(INFER_OUT)/differential/introduced.json \
--issues-tests introduced.exp.test --issues-tests introduced.exp.test
$(INFERPRINT_BIN) \ $(QUIET)$(INFERPRINT_BIN) \
--issues-fields $(INFERPRINT_ISSUES_FIELDS) \ --issues-fields $(INFERPRINT_ISSUES_FIELDS) \
--from-json-report $(INFER_OUT)/differential/fixed.json \ --from-json-report $(INFER_OUT)/differential/fixed.json \
--issues-tests fixed.exp.test --issues-tests fixed.exp.test
$(INFERPRINT_BIN) \ $(QUIET)$(INFERPRINT_BIN) \
--issues-fields $(INFERPRINT_ISSUES_FIELDS) \ --issues-fields $(INFERPRINT_ISSUES_FIELDS) \
--from-json-report $(INFER_OUT)/differential/preexisting.json \ --from-json-report $(INFER_OUT)/differential/preexisting.json \
--issues-tests preexisting.exp.test --issues-tests preexisting.exp.test
@ -55,9 +55,9 @@ print: $(EXPECTED_TEST_OUTPUT)
.PHONY: test .PHONY: test
test: print test: print
diff -u introduced.exp introduced.exp.test $(QUIET)$(call check_no_diff,introduced.exp,introduced.exp.test)
diff -u fixed.exp fixed.exp.test $(QUIET)$(call check_no_diff,fixed.exp,fixed.exp.test)
diff -u preexisting.exp preexisting.exp.test $(QUIET)$(call check_no_diff,preexisting.exp,preexisting.exp.test)
.PHONY: replace .PHONY: replace
replace: $(EXPECTED_TEST_OUTPUT) replace: $(EXPECTED_TEST_OUTPUT)

@ -0,0 +1,40 @@
# Copyright (c) 2016 - present Facebook, Inc.
# All rights reserved.
#
# This source code is licensed under the BSD style license found in the
# LICENSE file in the root directory of this source tree. An additional grant
# of patent rights can be found in the PATENTS file in the same directory.
include $(TESTS_DIR)/base.make
# useful to print non-default analyzer
ANALYZER_STRING=$(shell if [ -n $(ANALYZER) ] && [ $(ANALYZER) != infer ]; then \
printf ' ($(ANALYZER))'; fi)
default: compile
issues.exp.test$(TEST_SUFFIX): infer-out$(TEST_SUFFIX)/report.json $(INFERPRINT_BIN)
$(QUIET)$(INFERPRINT_BIN) -q -a $(ANALYZER) $(INFERPRINT_OPTIONS) $@ --from-json-report $<
.PHONY: compile
compile: $(OBJECTS)
.PHONY: analyze
analyze: infer-out$(TEST_SUFFIX)/report.json
.PHONY: print
print: issues.exp.test$(TEST_SUFFIX)
.PHONY: test
test: issues.exp.test$(TEST_SUFFIX)
$(QUIET)cd $(TESTS_DIR) && \
$(call check_no_diff,$(TEST_REL_DIR)/issues.exp,$(TEST_REL_DIR)/issues.exp.test$(TEST_SUFFIX))
.PHONY: print
replace: issues.exp.test$(TEST_SUFFIX)
cp $< issues.exp
.PHONY: clean
clean:
$(REMOVE_DIR) codetoanalyze com issues.exp.test$(TEST_SUFFIX) infer-out$(TEST_SUFFIX) \
$(OBJECTS) $(CLEAN_EXTRA)

@ -15,7 +15,7 @@
OBJECTS = $(patsubst %.java,%.class,$(SOURCES)) OBJECTS = $(patsubst %.java,%.class,$(SOURCES))
include $(TESTS_DIR)/java.make include $(TESTS_DIR)/java.make
include $(TESTS_DIR)/base.make include $(TESTS_DIR)/infer.make
PROJECT_ROOT ?= $(TESTS_DIR) PROJECT_ROOT ?= $(TESTS_DIR)
@ -23,6 +23,6 @@ $(OBJECTS): $(SOURCES)
$(JAVAC) -cp $(CLASSPATH) $(SOURCES) $(JAVAC) -cp $(CLASSPATH) $(SOURCES)
infer-out/report.json: $(JAVA_DEPS) $(SOURCES) infer-out/report.json: $(JAVA_DEPS) $(SOURCES)
$(call silent_on_success,\ $(QUIET)$(call silent_on_success,Testing infer/java$(ANALYZER_STRING) in $(TEST_REL_DIR),\
$(INFER_BIN) -a $(ANALYZER) --inferconfig-home . --project-root $(PROJECT_ROOT) $(INFER_OPTIONS) -- \ $(INFER_BIN) -a $(ANALYZER) --inferconfig-home . --project-root $(PROJECT_ROOT) $(INFER_OPTIONS) -- \
$(JAVAC) -cp $(CLASSPATH) $(SOURCES)) $(JAVAC) -cp $(CLASSPATH) $(SOURCES))

Loading…
Cancel
Save