X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=Makefile;h=28ea503bfe7641e8ff77311c0951eeee947becdc;hp=0f1d942177b0cb83a4d3a354c1a2c2837ad800b4;hb=142afe327024262a0eaa0731bcf31def91c146e0;hpb=dca596459198ea77f35e4b6e767453fa5a7e1318 diff --git a/Makefile b/Makefile index 0f1d9421..28ea503b 100644 --- a/Makefile +++ b/Makefile @@ -20,6 +20,45 @@ ALL_DEPENDS=$(patsubst %, ccan/%/.depends, $(ALL)) # Not all modules have tests. ALL_TESTS=$(patsubst ccan/%/test/, %, $(foreach dir, $(ALL), $(wildcard ccan/$(dir)/test/))) +# Here's my rough logarithmic timeout graph for my laptop: +# +# 302 - +# | / --* +# | / +# | / +# | / +# |Execution Time, seconds / +# | / +# | ---// +# | / +# | // +# | ---\ --- +# | --- \\ ------ +# |----------------- \--- +# 19 +------------------------------------------------------+-- +# 0 Timeout (ms, logarithmic) 262144 +# +# 140 +# | +# |------------ +# | --- +# | --------- +# | ------- +# | --\ +# | \\- +# | Tests skipped --\ +# | \ +# | \\ +# | \\\ +# | \ +# | \---- +# --+0---------------------------------------------------==+-- +# 0 Timeout (ms, logarithmic) 262144 +# +# On my laptop, this runs 574 tests in 40 seconds, vs. a full check which +# runs 676 tests in 260 seconds. +FASTTIMEOUT=750 + default: libccan.a include Makefile-ccan @@ -32,21 +71,21 @@ distclean: clean rm -f $(ALL_DEPENDS) $(ALL_DEPENDS): %/.depends: %/_info tools/ccan_depends - @tools/ccan_depends $* > $@ || ( rm -f $@; exit 1 ) + tools/ccan_depends $* > $@ || ( rm -f $@; exit 1 ) # Actual dependencies are created in inter-depends check-%: tools/ccanlint/ccanlint - @tools/ccanlint/ccanlint -d ccan/$* + tools/ccanlint/ccanlint -d ccan/$* fastcheck-%: tools/ccanlint/ccanlint - @tools/ccanlint/ccanlint -t -d ccan/$* + tools/ccanlint/ccanlint -t $(FASTTIMEOUT) -d ccan/$* # Doesn't test dependencies, doesn't print verbose fail results. summary-check-%: tools/ccanlint/ccanlint $(OBJFILES) - @tools/ccanlint/ccanlint -s -d ccan/$* + tools/ccanlint/ccanlint -s -d ccan/$* summary-fastcheck-%: tools/ccanlint/ccanlint $(OBJFILES) - @tools/ccanlint/ccanlint -t -s -d ccan/$* + tools/ccanlint/ccanlint -t $(FASTTIMEOUT) -s -d ccan/$* ccan/%/info: ccan/%/_info $(CC) $(CFLAGS) -o $@ -x c $< @@ -60,12 +99,12 @@ clean: tools-clean # Creates a dependency from the tests to the object files which it needs. inter-depends: $(ALL_DEPENDS) Makefile - @for f in $(ALL_DEPENDS); do echo check-$$(basename $$(dirname $$f) ): $$(for dir in $$(cat $$f) $$(dirname $$f); do [ "$$(echo $$dir/*.c)" = "$$dir/*.c" ] || echo ccan/"$$(basename $$dir)".o; done); done > $@ + for f in $(ALL_DEPENDS); do echo check-$$(basename $$(dirname $$f) ): $$(for dir in $$(cat $$f) $$(dirname $$f); do [ "$$(echo $$dir/*.c)" = "$$dir/*.c" ] || echo ccan/"$$(basename $$dir)".o; done); done > $@ # Creates dependencies between tests, so if foo depends on bar, bar is tested # first test-depends: $(ALL_DEPENDS) Makefile - @for f in $(ALL_DEPENDS); do echo check-`basename \`dirname $$f\``: `sed -n 's,ccan/\(.*\),check-\1,p' < $$f`; done > $@ + for f in $(ALL_DEPENDS); do echo check-`basename \`dirname $$f\``: `sed -n 's,ccan/\(.*\),check-\1,p' < $$f`; done > $@ include tools/Makefile -include inter-depends