X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=Makefile;h=c1f5ea8f6d78a17d8c5dd4cb087e4b4092726fb0;hp=0f1d942177b0cb83a4d3a354c1a2c2837ad800b4;hb=3fb6b6be5a395fbe293e61339e6be67118234508;hpb=dca596459198ea77f35e4b6e767453fa5a7e1318 diff --git a/Makefile b/Makefile index 0f1d9421..c1f5ea8f 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 $< @@ -55,17 +94,17 @@ libccan.a(%.o): ccan/%.o $(AR) r $@ $< clean: tools-clean - $(RM) `find . -name '*.o'` `find . -name '.depends'` `find . -name '*.a'` `find . -name info` `find . -name '*.d'` + $(RM) `find * -name '*.o'` `find * -name '.depends'` `find * -name '*.a'` `find * -name info` `find * -name '*.d'` $(RM) inter-depends lib-depends test-depends ccan/*-Makefile # 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