.DEFAULT_GOAL=build TOKUROOT=../../ INCLUDEDIRS=-I. -I.. -I../../include CFLAGS+=-Werror ifeq ($(CYGWIN),) LINK_FILES += $(FT) else ifneq ($(CC),icc) LINK_FILES += $(FT) else ifeq ($(DEBUG),0) LINK_FILES += $(IPO_FT) else ifeq ($(DEBUG),) LINK_FILES += $(IPO_FT) else LINK_FILES += $(FT) endif include $(TOKUROOT)toku_include/Makefile.include CPPFLAGS+=-D_GNU_SOURCE ifeq ($(CC),icc) SKIP_WARNING += $(ICC_NOWARN)1418 #Non static functions do not need prototypes. endif # On cygwin do: # make CYGWIN=cygwin check # For verbose output do # make VERBOSE=1 # For very verbose output do # make VERBOSE=2 # Exclude orthopush-flush until it is fixed. SRCS=$(sort $(filter-out dir.%.c,$(wildcard *.c))) REGRESSION_TESTS_RAW = $(patsubst %.c,%,$(SRCS)) EXTRA_ARGS= # Add in the binaries that must be run in various ways. BINS_RAW = $(REGRESSION_TESTS_RAW) \ # This line intentially kept commented so I can have a \ on the end of the previous line # BINS will be defined by adding .exe if appropriate. CHECKS = \ benchmarktest_256 \ test-assertA \ test-assertB \ $(REGRESSION_TESTS) \ # This line intentially kept commented so I can have a \ on the previous line #CHECKS will be defined automatically. build: $(BINS) check: $(PTHREAD_LOCAL) $(patsubst %,check_%,$(CHECKS)) fastcheck: $(PTHREAD_LOCAL) $(patsubst %,fastcheck_%,$(CHECKS)) fastcheckonlyfail: $(PTHREAD_LOCAL) $(patsubst %,fastcheckonlyfail_%,$(CHECKS)) check_fail: test 0 = 1 $(SUMMARIZE_CMD) check_ok: test 0 = 0 $(SUMMARIZE_CMD) ifeq ($(TOKU_SKIP_MINICRON),1) check_minicron-test$(BINSUF): @echo "SKIPPED TEST $@ (Fails in win64 vm due to timing issues)" endif check_benchmark-test$(BINSUF): benchmark-test$(BINSUF); check_logcursor-fw$(BINSUF): logcursor-fw$(BINSUF); @echo "$@ must be run manually (needs logs to iterate over)." check_logcursor-bw$(BINSUF): logcursor-bw$(BINSUF); @echo "$@ must be run manually (needs logs to iterate over)." check_benchmarktest_256: benchmark-test$(BINSUF) $(PTHREAD_LOCAL) $(VGRIND) ./$< $(VERBVERBOSE) --valsize 256 --verify 1 $(SUMMARIZE_CMD) check_test-assertA: test-assert$(BINSUF) $(PTHREAD_LOCAL) @# no arguments, should err $(VGRIND) ./$< > /dev/null 2>&1 ; test $$? = 1 $(SUMMARIZE_CMD) ifeq ($(OS_CHOICE),windows) TEST_ASSERT_FAILCODE=134 #Does not use raise(SIGABRT) to fail assert, so will not overwrite 134 with 1. else TEST_ASSERT_FAILCODE=1 endif check_test-assertB: test-assert$(BINSUF) $(PTHREAD_LOCAL) @# one argument, not "ok" should err @rm -f test-assert.out ($(VGRIND) ./$< notok) > test-assert.out 2>&1 ; test $$? = $(TEST_ASSERT_FAILCODE) && fgrep failed test-assert.out > /dev/null && rm test-assert.out $(SUMMARIZE_CMD) check_test-assertC: test-assert$(BINSUF) $(PTHREAD_LOCAL) check_test-assert$(BINSUF): test-assert$(BINSUF) $(PTHREAD_LOCAL) @# one argument, "ok" should not error $(VGRIND) ./$< ok $(SUMMARIZE_CMD) check_ft_loader-test-merge-files-dbufio: EXTRA_ARGS=-r 8000 -s dir.$@ check_ft_loader-test$(BINSUF): EXTRA_ARGS=dir.$@ check_ft_loader-test-bad-generate$(BINSUF): EXTRA_ARGS=dir.$@ check_ft_loader-test-extractor$(BINSUF): $(patsubst %,check_ft_loader-test-extractor-%, 1 2 3 1a 2a 3a 4a 5a) true $(SUMMARIZE_CMD) # the 1,2,3 tests don't use valgrind, the 1a,2a,3a,4a,5a tests use valgrind. check_ft_loader-test-extractor-1: ft_loader-test-extractor$(BINSUF) ./$< $(VERBVERBOSE) -s -r 1000 --rowsets 1000 --asc dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-2: ft_loader-test-extractor$(BINSUF) ./$< $(VERBVERBOSE) -s -r 1000 --rowsets 1000 --dsc dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-3: ft_loader-test-extractor$(BINSUF) ./$< $(VERBVERBOSE) -s -r 1000 --rowsets 1000 --random dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-1a: ft_loader-test-extractor$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -s -r 1000 --rowsets 1000 --asc dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-2a: ft_loader-test-extractor$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -s -r 1000 --rowsets 1000 --dsc dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-3a: ft_loader-test-extractor$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -s -r 1000 --rowsets 1000 --random dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-4a: ft_loader-test-extractor$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -s -r 1000 --rowsets 3 --asc dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-5a: ft_loader-test-extractor$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -s -r 1000 --rowsets 3 --asc --asc-poison dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-errors$(BINSUF): $(patsubst %,check_ft_loader-test-extractor-errors-%, 1 2) true $(SUMMARIZE_CMD) check_ft_loader-test-extractor-errors-1: ft_loader-test-extractor-errors$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -w -m -u -r 1 dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-extractor-errors-2: ft_loader-test-extractor-errors$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -m -r 10000 dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-open$(BINSUF): EXTRA_ARGS=dir_$@ check_ft_loader-test-writer$(BINSUF): $(patsubst %,check_ft_loader-test-writer-%, 1 1000 100000 1000000 1-x 1000-x 100000-x 1000000-x) true $(SUMMARIZE_CMD) check_ft_loader-test-writer-1: ft_loader-test-writer$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -r 1 -s dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-1000: ft_loader-test-writer$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -r 1000 -s dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-100000: ft_loader-test-writer$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -r 100000 -s dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-1000000: ft_loader-test-writer$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -r 1000000 -s dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-1-x: ft_loader-test-writer$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -r 1 -s -x 42 dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-1000-x: ft_loader-test-writer$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -r 1000 -s -x 42 dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-100000-x: ft_loader-test-writer$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -r 100000 -s -x 42 dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-1000000-x: ft_loader-test-writer$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -r 1000000 -s -x 42 dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-errors$(BINSUF): $(patsubst %,check_ft_loader-test-writer-errors-%, 1 2 3 4) true $(SUMMARIZE_CMD) check_ft_loader-test-writer-errors-1: ft_loader-test-writer-errors$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -w -m -u -r 100000 dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-errors-2: ft_loader-test-writer-errors$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -s -w -m -u -r 10000 dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-errors-3: ft_loader-test-writer-errors$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -s -r 20000 --malloc_limit 0 --realloc_errors dir.$@ $(SUMMARIZE_CMD) check_ft_loader-test-writer-errors-4: ft_loader-test-writer-errors$(BINSUF) $(VGRIND) ./$< $(VERBVERBOSE) -s -m --malloc_limit 0 -r 10000 dir.$@ $(SUMMARIZE_CMD) check_ft-serialize-benchmark: brt-serialize-benchmark$(BINSUF) ./$< 92 200000 > /dev/null 2>&1 $(SUMMARIZE_CMD) check_bnc-insert-benchmark: bnc-insert-benchmark$(BINSUF) ./$< 100 4096000 1000 > /dev/null 2>&1 $(SUMMARIZE_CMD) check_%: % $(PTHREAD_LOCAL) $(VGRIND) ./$< $(VERBVERBOSE) $(EXTRA_ARGS) $(SUMMARIZE_CMD) fastcheck_%: $(PTHREAD_LOCAL) @(perl -e 'alarm ($(FASTCHECKTIMEOUT) * 60) ; exec @ARGV' $(MAKE) VGRIND= SUMMARIZE=0 check_$*) &>$*.fastlog ; \ if test $$? != 0 ; then \ printf "%-60s FAIL\nexamine %s\n" check_$* $*.fastlog; \ exit 2 ; \ else \ printf "%-60s PASS\n" check_$* ; \ $(RM) $*.fastlog ; \ fi fastcheckonlyfail_%: $(PTHREAD_LOCAL) @(perl -e 'alarm ($(FASTCHECKTIMEOUT) * 60) ; exec @ARGV' $(MAKE) VGRIND= SUMMARIZE=0 check_$*) &>$*.fastlog ; \ if test $$? != 0 ; then \ printf "%-60s FAIL\nexamine %s\n" check_$* $*.fastlog; \ exit 2 ; \ else \ $(RM) $*.fastlog ; \ fi benchmark-test.$(OEXT): ../ft-ops.h ../ft-search.h ../../include/db.h ft_loader_test$(BINSUF): ../ftloader-internal.h ../ft_loader.o ../ft_loader.$(OEXT): ../ft_loader.c ../ftloader-internal.h cd $(@D) && $(MAKE) $(@F) CILKSCREEN=../../scripts/tokucilkscreen check_ft_loader: check_ft_loader-test-bad-generate check_ft_loader-test-extractor check_ft_loader-test-extractor-errors check_ft_loader-test-merge-files-dbufio check_ft_loader-test-open check_ft_loader-test-writer check_ft_loader-test-writer-errors cilkscreen_ft_loader-tests: cilkscreen_ft_loader-test-1 true $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-1: ft_loader-test$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-extractor-tests: $(patsubst %,cilkscreen_ft_loader-test-extractor-%, 1 2) true $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-extractor-1: ft_loader-test-extractor$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-extractor-2: ft_loader-test-extractor$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-extractor-3: ft_loader-test-extractor$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 100 --rowsets 100 dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-writer-tests: $(patsubst %,cilkscreen_ft_loader-test-writer-%, 1000 10000 1000-x 10000-x) true $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-1: ft_loader-test-writer$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 1 dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-1000: ft_loader-test-writer$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 1000 dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-10000: ft_loader-test-writer$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 10000 dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-1000000: ft_loader-test-writer$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 1000000 dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-1000-x: ft_loader-test-writer$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 1000 -x 42 dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-10000-x: ft_loader-test-writer$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 10000 -x 42 dir.$@ $(SUMMARIZE_CMD) # this test sometimes crashes cilkscreen 8503, omit for now cilkscreen_ft_loader-test-writer-3: ft_loader-test-writer$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 100000 dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-writer-error-tests: $(patsubst %,cilkscreen_ft_loader-test-writer-errors-%, 1 2 3 4) true $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-errors-1: ft_loader-test-writer-errors$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 10000 -u dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-errors-2: ft_loader-test-writer-errors$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 10000 -w dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-errors-3: ft_loader-test-writer-errors$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 10000 -m dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader-test-writer-errors-4: ft_loader-test-writer-errors$(BINSUF) $(CILKSCREEN) ./$< $(VERBVERBOSE) -s -r 10000 --realloc_errors dir.$@ $(SUMMARIZE_CMD) cilkscreen_ft_loader: cilkscreen_ft_loader-tests cilkscreen_ft_loader-extractor-tests cilkscreen_ft_loader-writer-tests cilkscreen_ft_loader-writer-error-tests check_upgrade_test_simple: VGRIND= check_upgrade_test_simple_with_valgrind: upgrade_test_simple $(VGRIND) ./$< $(VERBVERBOSE) $(EXTRA_ARGS) $(SUMMARIZE_CMD) clean: rm -rf log-test7.c.dir_* rm -rf *.dir dir.* rm -f test_oexcl.c.tmp rm -f *.ft_handle *.clean *.dirty *.tdb *.dat *.data *.out *.check.valgrind *.fastlog ifeq ($(PROF),1) $(BINS): LDFLAGS=$(TOKUROOT)lib/libft.$(AEXT) $(LIBPORTABILITY_A) $(ALWAYS_LINK) else $(BINS): LDFLAGS=-L../../lib -l$(LIBTOKUPORTABILITY) -lft $(ALWAYS_LINK) -Wl,-rpath,$(shell pwd)/$(TOKUROOT)lib endif $(BINS): test.h foo: echo $(LDFLAGS)