# The paths below assume that sdcc, sdcc-extra, and gbdk-lib all reside in
# the same directory.
-# Old nores:
+# Old notes:
# Starting at the bottom
# Set of source test suites
# Each source suite is processesd producing multiple device specific test suites.
# Uncomment this to show only errors and the summary.
# Comment this out for debugging.
-.SILENT:
+#.SILENT:
# All original tests live in TESTS_DIR and below
-TESTS_DIR = tests
+TESTS_DIR = tests-min
+TESTS_NAME = $(TESTS_DIR)
# All suite results go in RESULTS_DIR
RESULTS_DIR = results
# All data relating to supported ports live in their own directory
# files and how to run the emulator.
ALL_PORTS = $(filter-out CVS,$(notdir $(wildcard $(PORTS_DIR)/*)))
+all: test-ports
+
# Test all of the ports
test-ports:
for i in $(ALL_PORTS); do $(MAKE) inter-port-clean test-port PORT=$$i; done
test-z80:
$(MAKE) inter-port-clean clean test-port PORT=z80
-test-z80:
+# Helper rule for testing the host cc only
+test-host:
+ $(MAKE) inter-port-clean clean test-port PORT=host
+
+test-host2:
+ $(MAKE) test-port PORT=host
+
# Begin per-port rules
# List of all of the known source test suites.
ALL_TESTS = $(shell find $(TESTS_DIR) -name "*.c")
# Rule to generate the iterations of a test suite off the soure suite.
$(PORT_CASES_DIR)/%$(DIREXT): $(TESTS_DIR)/%.c $(GENERATE_CASES)
- rm -rf $(CASES_DIR)/tests
- mkdir -p $(CASES_DIR)/tests
+ echo Processing $<
+ rm -rf $(CASES_DIR)/$(TESTS_NAME)
+ mkdir -p $(CASES_DIR)/$(TESTS_NAME)
mkdir -p $@
python $(GENERATE_CASES) $< > /dev/null
- cp $(CASES_DIR)/tests/*.c $@
+ cp $(CASES_DIR)/$(TESTS_NAME)/*.c $@
touch $@
# Rule linking the combined results log to all of the files in the
# test
# List of all of the generated iteration source files.
-SUB_CASES = $(wildcard $(CASES)/*.c)
+SUB_CASES = $(sort $(wildcard $(CASES)/*.c))
# List of all the sub result logs generated from the iterations.
SUB_RESULTS = $(SUB_CASES:%.c=%.out)
# Overall target. Concatenation of all of the sub results.