summaryrefslogtreecommitdiff
path: root/grade-lab-lock
diff options
context:
space:
mode:
authorMole Shang <[email protected]>2024-02-19 14:10:32 +0800
committerMole Shang <[email protected]>2024-02-19 14:36:21 +0800
commitd86118fc80267649b4791c8c0c72ebd60edf1ef2 (patch)
treeb792b617b4df80a5803a9c1164d0e3fdfe9cfe31 /grade-lab-lock
parentb20ef9d0210fd7d9403acde1857eed1b9880c0b2 (diff)
parent0cf897cbe05fd8485162619db4244f4159d0eb52 (diff)
downloadxv6-labs-d86118fc80267649b4791c8c0c72ebd60edf1ef2.tar.gz
xv6-labs-d86118fc80267649b4791c8c0c72ebd60edf1ef2.tar.bz2
xv6-labs-d86118fc80267649b4791c8c0c72ebd60edf1ef2.zip
Merge branch 'fs' into mmap
Conflicts: .gitignore Makefile conf/lab.mk kernel/defs.h user/user.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()