summaryrefslogtreecommitdiff
path: root/grade-lab-lock
diff options
context:
space:
mode:
authorMole Shang <[email protected]>2024-02-17 11:55:33 +0800
committerMole Shang <[email protected]>2024-02-17 12:22:07 +0800
commite8e0a7b4c97064eb5e9415726d7e38aaceccd3fd (patch)
treefb42ba5be7a8ae608b968266f62fd71fa889a89d /grade-lab-lock
parenta6af72924b115c1177d18d9b1eaba56623e4248b (diff)
parentd85aec2689c4250d0384904bdc11aa618c726bec (diff)
downloadxv6-labs-e8e0a7b4c97064eb5e9415726d7e38aaceccd3fd.tar.gz
xv6-labs-e8e0a7b4c97064eb5e9415726d7e38aaceccd3fd.tar.bz2
xv6-labs-e8e0a7b4c97064eb5e9415726d7e38aaceccd3fd.zip
Merge branch 'thread' into fs
Conflicts: .gitignore Makefile conf/lab.mk kernel/param.h
Diffstat (limited to 'grade-lab-lock')
-rwxr-xr-xgrade-lab-lock62
1 files changed, 62 insertions, 0 deletions
diff --git a/grade-lab-lock b/grade-lab-lock
new file mode 100755
index 0000000..fa90fef
--- /dev/null
+++ b/grade-lab-lock
@@ -0,0 +1,62 @@
+#!/usr/bin/env python3
+
+import re
+from gradelib import *
+
+r = Runner(save("xv6.out"))
+
+@test(0, "running kalloctest")
+def test_kalloctest():
+ r.run_qemu(shell_script([
+ 'kalloctest'
+ ]), timeout=200)
+
+@test(10, "kalloctest: test1", parent=test_kalloctest)
+def test_kalloctest_test1():
+ r.match('^test1 OK$')
+
+@test(10, "kalloctest: test2", parent=test_kalloctest)
+def test_kalloctest_test2():
+ r.match('^test2 OK$')
+
+@test(10, "kalloctest: test3", parent=test_kalloctest)
+def test_kalloctest_test3():
+ r.match('^test3 OK$')
+
+@test(10, "kalloctest: sbrkmuch")
+def test_sbrkmuch():
+ r.run_qemu(shell_script([
+ 'usertests sbrkmuch'
+ ]), timeout=90)
+ r.match('^ALL TESTS PASSED$')
+
+@test(0, "running bcachetest")
+def test_bcachetest():
+ r.run_qemu(shell_script([
+ 'bcachetest'
+ ]), timeout=90)
+
+@test(10, "bcachetest: test0", parent=test_bcachetest)
+def test_bcachetest_test0():
+ r.match('^test0: OK$')
+
+@test(10, "bcachetest: test1", parent=test_bcachetest)
+def test_bcachetest_test1():
+ r.match('^test1 OK$')
+
+@test(10, "bcachetest: test2", parent=test_bcachetest)
+def test_bcachetest_test2():
+ r.match('^test2 OK$')
+
+@test(19, "usertests")
+def test_usertests():
+ r.run_qemu(shell_script([
+ 'usertests -q'
+ ]), timeout=300)
+ r.match('^ALL TESTS PASSED$')
+
+@test(1, "time")
+def test_time():
+ check_time()
+
+run_tests()