X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=tests%2FMakefile;h=38751cd1f4e7484a92a72de3968e8b06d9fe7f56;hb=a705e9ae16e14e24d313916a0c5402e175f8cce5;hp=efea7a5078db3e7da0cb6621a588f4f0ed9b313f;hpb=6070611faac84bdf95c4405b3970c6928202f26b;p=pintos-anon diff --git a/tests/Makefile b/tests/Makefile index efea7a5..38751cd 100644 --- a/tests/Makefile +++ b/tests/Makefile @@ -1,4 +1,4 @@ -TESTS = threads p1-1 p1-2 p1-3 list stdlib userprog p2 vm filesys +TESTS = threads p1 userprog p2 vm p3 filesys p4 PATH := $(shell pwd)/../src/utils:$(PATH) @@ -13,105 +13,66 @@ check: clean: rm -rf $(TESTS) -define prep-threads-grading -endef - -define prep-userprog-grading -$(MAKE) -C ../src/userprog -s -$(MAKE) -C ../grading/userprog -s -endef - -define prep-vm-grading -$(MAKE) -C ../src/userprog -s -$(MAKE) -C ../grading/vm -s -endef - -define prep-filesys-grading -$(MAKE) -C ../grading/filesys -s -endef - -define prep-grading -$(prep-$(PROJECT)-grading) -endef +SUBMAKEFLAGS = -s define mk-sandbox -rm -rf $@ && mkdir -p $@/pintos && cp -R ../src $@/pintos +rm -rf $@ && mkdir $@ && cp -R ../src $@/src +cd $@/src && $(MAKE) clean $(SUBMAKEFLAGS) endef define run-tests -cd $@ && ../../grading/$(PROJECT)/run-tests +cd $@/src/$(PROJECT) && make check && make grade +endef + +define compile +cd $@/src/$(PROJECT) && make endef define clean -rm -rf $@/pintos +rm -rf $@ endef define apply-patch -(cd $@/pintos && patch -p0 -s) < +(cd $@ && patch -p0) endef -threads: PROJECT = threads -threads:: - $(mk-sandbox) - $(run-tests) -d alarm-single - $(clean) - -p1-1: PROJECT = threads -p1-1:: - $(mk-sandbox) - $(apply-patch) ../solutions/p1-1.patch - $(run-tests) -d alarm.* - $(clean) - -p1-2: PROJECT = threads -p1-2:: - $(mk-sandbox) - $(apply-patch) ../solutions/p1-2.patch - $(run-tests) -d join.* - $(clean) +PROJECT = $@ -p1-3: PROJECT = threads -p1-3:: +threads:: $(mk-sandbox) - $(apply-patch) ../solutions/p1-3.patch - $(run-tests) -d priority.* + $(compile) + $(run-tests) TESTS=tests/threads/alarm-single $(clean) -list: PROJECT = threads -list stdlib:: +userprog vm filesys:: $(mk-sandbox) - cp ../src/tests/threads/$@.c $@/pintos/src/threads/test.c - $(MAKE) -C $@/pintos/src/threads -s - -(cd $@/pintos/src/threads/build && pintos -v run -q) | tee $@/output - grep -q '$@: PASS' $@/output + $(compile) $(clean) -userprog: PROJECT = userprog -userprog:: - $(prep-grading) +p1: PROJECT = threads +p1:: $(mk-sandbox) - $(apply-patch) ../solutions/p1-2.patch - $(run-tests) null + $(apply-patch) < ../solutions/p1.patch + $(run-tests) $(clean) p2: PROJECT = userprog p2:: - $(prep-grading) $(mk-sandbox) - $(apply-patch) ../solutions/p2.patch + $(apply-patch) < ../solutions/p2.patch $(run-tests) $(clean) -vm: PROJECT = vm -vm:: - $(prep-grading) +p3: PROJECT = vm +p3:: $(mk-sandbox) - $(MAKE) -C $@/pintos/src/vm -s + $(apply-patch) < ../solutions/p3.patch + $(run-tests) $(clean) -filesys: PROJECT = filesys -filesys:: - $(prep-grading) +p4: PROJECT = filesys +p4:: $(mk-sandbox) - $(MAKE) -C $@/pintos/src/filesys -s + $(apply-patch) < ../solutions/p4.patch + $(run-tests) $(clean)