|
@@ -23,10 +23,7 @@ include ../Rules.mak
|
|
|
|
|
|
U_TARGETS := $(TESTS)
|
|
U_TARGETS := $(TESTS)
|
|
G_TARGETS := $(patsubst %,%_glibc,$(U_TARGETS))
|
|
G_TARGETS := $(patsubst %,%_glibc,$(U_TARGETS))
|
|
-U_TARGETS += $(U_TESTS)
|
|
|
|
-G_TARGETS += $(G_TESTS)
|
|
|
|
|
|
|
|
-TARGETS := $(SHELL_TESTS)
|
|
|
|
ifeq ($(GLIBC_ONLY),)
|
|
ifeq ($(GLIBC_ONLY),)
|
|
TARGETS += $(U_TARGETS)
|
|
TARGETS += $(U_TARGETS)
|
|
endif
|
|
endif
|
|
@@ -34,72 +31,78 @@ ifeq ($(UCLIBC_ONLY),)
|
|
TARGETS += $(G_TARGETS)
|
|
TARGETS += $(G_TARGETS)
|
|
endif
|
|
endif
|
|
CLEAN_TARGETS := $(U_TARGETS) $(G_TARGETS)
|
|
CLEAN_TARGETS := $(U_TARGETS) $(G_TARGETS)
|
|
|
|
+COMPILE_TARGETS := $(TARGETS)
|
|
|
|
+TARGETS += $(SHELL_TESTS)
|
|
|
|
+RUN_TARGETS := $(patsubst %,%.exe,$(TARGETS))
|
|
|
|
|
|
-test check all: $(TARGETS)
|
|
+define binary_name
|
|
- @true
|
|
+$(patsubst %.exe,%,$@)
|
|
-
|
|
+endef
|
|
-$(TARGETS): Makefile $(TESTDIR)Makefile $(TESTDIR)Rules.mak $(TESTDIR)Test.mak
|
|
|
|
-$(U_TARGETS): $(patsubst %,%.c,$(U_TARGETS))
|
|
|
|
-$(G_TARGETS): $(patsubst %_glibc,%.c,$(G_TARGETS))
|
|
|
|
|
|
|
|
define diff_test
|
|
define diff_test
|
|
$(Q)\
|
|
$(Q)\
|
|
- for x in "$@.out" "$(patsubst %_glibc,%,$@).out" ; do \
|
|
+ for x in "$(binary_name).out" "$(patsubst %_glibc,%,$(binary_name)).out" ; do \
|
|
- test -e "$$x.good" && $(do_showdiff) "$@.out" "$$x.good" && exec diff -u "$@.out" "$$x.good" ; \
|
|
+ test -e "$$x.good" && $(do_showdiff) "$(binary_name).out" "$$x.good" && exec diff -u "$(binary_name).out" "$$x.good" ; \
|
|
done ; \
|
|
done ; \
|
|
true
|
|
true
|
|
endef
|
|
endef
|
|
define uclibc_glibc_diff_test
|
|
define uclibc_glibc_diff_test
|
|
$(Q)\
|
|
$(Q)\
|
|
- test -z "$(DODIFF_$(patsubst %_glibc,%,$@))" && exec true ; \
|
|
+ test -z "$(DODIFF_$(patsubst %_glibc,%,$(binary_name)))" && exec true ; \
|
|
- uclibc_out="$@.out" ; \
|
|
+ uclibc_out="$(binary_name).out" ; \
|
|
- glibc_out="$(patsubst %_glibc,%,$@).out" ; \
|
|
+ glibc_out="$(patsubst %_glibc,%,$(binary_name)).out" ; \
|
|
$(do_showdiff) $$uclibc_out $$glibc_out ; \
|
|
$(do_showdiff) $$uclibc_out $$glibc_out ; \
|
|
exec diff -u "$$uclibc_out" "$$glibc_out"
|
|
exec diff -u "$$uclibc_out" "$$glibc_out"
|
|
endef
|
|
endef
|
|
define exec_test
|
|
define exec_test
|
|
$(showtest)
|
|
$(showtest)
|
|
$(Q)\
|
|
$(Q)\
|
|
- $(WRAPPER) $(WRAPPER_$(patsubst %_glibc,%,$@)) \
|
|
+ $(WRAPPER) $(WRAPPER_$(patsubst %_glibc,%,$(binary_name))) \
|
|
- ./$@ $(OPTS) $(OPTS_$(patsubst %_glibc,%,$@)) &> "$@.out" ; \
|
|
+ ./$(binary_name) $(OPTS) $(OPTS_$(patsubst %_glibc,%,$(binary_name))) &> "$(binary_name).out" ; \
|
|
ret=$$? ; \
|
|
ret=$$? ; \
|
|
- expected_ret="$(RET_$(patsubst %_glibc,%,$@))" ; \
|
|
+ expected_ret="$(RET_$(patsubst %_glibc,%,$(binary_name)))" ; \
|
|
test -z "$$expected_ret" && export expected_ret=0 ; \
|
|
test -z "$$expected_ret" && export expected_ret=0 ; \
|
|
if ! test $$ret -eq $$expected_ret ; then \
|
|
if ! test $$ret -eq $$expected_ret ; then \
|
|
- $(RM) $@ ; \
|
|
+ $(RM) $(binary_name) ; \
|
|
echo "ret == $$ret ; expected_ret == $$expected_ret" ; \
|
|
echo "ret == $$ret ; expected_ret == $$expected_ret" ; \
|
|
- cat "$@.out" ; \
|
|
+ cat "$(binary_name).out" ; \
|
|
exit 1 ; \
|
|
exit 1 ; \
|
|
fi
|
|
fi
|
|
- $(SCAT) "$@.out"
|
|
+ $(SCAT) "$(binary_name).out"
|
|
endef
|
|
endef
|
|
|
|
|
|
-$(U_TARGETS):
|
|
+test check all: run
|
|
-ifeq ($(CHECK_ONLY),)
|
|
+run: $(RUN_TARGETS) compile
|
|
- $(showlink)
|
|
+$(RUN_TARGETS): $(TARGETS)
|
|
- $(Q)$(CC) $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$@) -c $@.c -o $@.o
|
|
+ifeq ($(shell echo "$(SHELL_TESTS)"|grep "$(binary_name)"),)
|
|
- $(Q)$(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LDFLAGS) $(LDFLAGS_$@)
|
|
|
|
-endif
|
|
|
|
-ifeq ($(COMPILE_ONLY),)
|
|
|
|
$(exec_test)
|
|
$(exec_test)
|
|
$(diff_test)
|
|
$(diff_test)
|
|
|
|
+ifeq ($(UCLIBC_ONLY),)
|
|
|
|
+ $(uclibc_glibc_diff_test)
|
|
|
|
+endif
|
|
endif
|
|
endif
|
|
|
|
|
|
-$(G_TARGETS):
|
|
+compile: $(COMPILE_TARGETS)
|
|
|
|
+
|
|
|
|
+G_TARGET_SRCS := $(patsubst %,%.c,$(G_TARGETS))
|
|
|
|
+U_TARGET_SRCS := $(patsubst %,%.c,$(U_TARGETS))
|
|
|
|
+
|
|
|
|
+$(MAKE_SRCS): Makefile $(TESTDIR)Makefile $(TESTDIR)Rules.mak $(TESTDIR)Test.mak
|
|
|
|
+
|
|
|
|
+$(U_TARGETS): $(U_TARGET_SRCS) $(MAKE_SRCS)
|
|
|
|
+ $(showlink)
|
|
|
|
+ $(Q)$(CC) $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$@) -c $@.c -o $@.o
|
|
|
|
+ $(Q)$(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LDFLAGS) $(LDFLAGS_$@)
|
|
|
|
+
|
|
|
|
+$(G_TARGETS): $(U_TARGET_SRCS) $(MAKE_SRCS)
|
|
$(showlink)
|
|
$(showlink)
|
|
$(Q)$(HOSTCC) $(HOST_CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$(patsubst %_glibc,%,$@)) -c $(patsubst %_glibc,%,$@).c -o $@.o
|
|
$(Q)$(HOSTCC) $(HOST_CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$(patsubst %_glibc,%,$@)) -c $(patsubst %_glibc,%,$@).c -o $@.o
|
|
$(Q)$(HOSTCC) $(HOST_LDFLAGS) $@.o -o $@ $(EXTRA_LDFLAGS) $(LDFLAGS_$(patsubst %_glibc,%,$@))
|
|
$(Q)$(HOSTCC) $(HOST_LDFLAGS) $@.o -o $@ $(EXTRA_LDFLAGS) $(LDFLAGS_$(patsubst %_glibc,%,$@))
|
|
-ifeq ($(COMPILE_ONLY),)
|
|
+
|
|
- $(exec_test)
|
|
|
|
- $(diff_test)
|
|
|
|
- $(uclibc_glibc_diff_test)
|
|
|
|
-endif
|
|
|
|
|
|
|
|
shell_%:
|
|
shell_%:
|
|
-ifeq ($(COMPILE_ONLY),)
|
|
|
|
$(showtest)
|
|
$(showtest)
|
|
- $(Q)$(SHELL) $(patsubst shell_%,%.sh,$@)
|
|
+ $(Q)$(SHELL) $(patsubst shell_%,%.sh,$(binary_name))
|
|
-endif
|
|
|
|
|
|
|
|
%.so: %.c
|
|
%.so: %.c
|
|
$(showlink)
|
|
$(showlink)
|
|
@@ -112,4 +115,4 @@ clean:
|
|
$(showclean)
|
|
$(showclean)
|
|
$(Q)$(RM) *.a *.o *.so *~ core *.out *.gdb $(CLEAN_TARGETS) $(EXTRA_CLEAN)
|
|
$(Q)$(RM) *.a *.o *.so *~ core *.out *.gdb $(CLEAN_TARGETS) $(EXTRA_CLEAN)
|
|
|
|
|
|
-.PHONY: all check clean test
|
|
+.PHONY: all check clean test run compile
|