191 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			191 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
#!/usr/bin/env python
 | 
						|
 | 
						|
import re
 | 
						|
from gradelib import *
 | 
						|
 | 
						|
r = Runner(save("jos.out"),
 | 
						|
           stop_breakpoint("readline"))
 | 
						|
 | 
						|
def E(s, trim=False):
 | 
						|
    """Expand $En in s to the environment ID of the n'th user
 | 
						|
    environment."""
 | 
						|
 | 
						|
    tmpl = "%x" if trim else "%08x"
 | 
						|
    return re.sub(r"\$E([0-9]+)",
 | 
						|
                  lambda m: tmpl % (0x1000 + int(m.group(1))-1), s)
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_dumbfork():
 | 
						|
    r.user_test("dumbfork")
 | 
						|
    r.match(E(".00000000. new env $E1"),
 | 
						|
            E(".$E1. new env $E2"),
 | 
						|
            "0: I am the parent.",
 | 
						|
            "9: I am the parent.",
 | 
						|
            "0: I am the child.",
 | 
						|
            "9: I am the child.",
 | 
						|
            "19: I am the child.",
 | 
						|
            E(".$E1. exiting gracefully"),
 | 
						|
            E(".$E1. free env $E1"),
 | 
						|
            E(".$E2. exiting gracefully"),
 | 
						|
            E(".$E2. free env $E2"))
 | 
						|
 | 
						|
end_part("A")
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultread():
 | 
						|
    r.user_test("faultread")
 | 
						|
    r.match(E(".$E1. user fault va 00000000 ip 008....."),
 | 
						|
            "TRAP frame at 0xf....... from CPU .",
 | 
						|
            "  trap 0x0000000e Page Fault",
 | 
						|
            "  err  0x00000004.*",
 | 
						|
            E(".$E1. free env $E1"),
 | 
						|
            no=["I read ........ from location 0."])
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultwrite():
 | 
						|
    r.user_test("faultwrite")
 | 
						|
    r.match(E(".$E1. user fault va 00000000 ip 008....."),
 | 
						|
            "TRAP frame at 0xf....... from CPU .",
 | 
						|
            "  trap 0x0000000e Page Fault",
 | 
						|
            "  err  0x00000006.*",
 | 
						|
            E(".$E1. free env $E1"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultdie():
 | 
						|
    r.user_test("faultdie")
 | 
						|
    r.match("i faulted at va deadbeef, err 6",
 | 
						|
            E(".$E1. exiting gracefully"),
 | 
						|
            E(".$E1. free env $E1"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultregs():
 | 
						|
    r.user_test("faultregs")
 | 
						|
    r.match("Registers in UTrapframe OK",
 | 
						|
            "Registers after page-fault OK",
 | 
						|
            no=["Registers in UTrapframe MISMATCH",
 | 
						|
                "Registers after page-fault MISMATCH"])
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultalloc():
 | 
						|
    r.user_test("faultalloc")
 | 
						|
    r.match("fault deadbeef",
 | 
						|
            "this string was faulted in at deadbeef",
 | 
						|
            "fault cafebffe",
 | 
						|
            "fault cafec000",
 | 
						|
            "this string was faulted in at cafebffe",
 | 
						|
            E(".$E1. exiting gracefully"),
 | 
						|
            E(".$E1. free env $E1"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultallocbad():
 | 
						|
    r.user_test("faultallocbad")
 | 
						|
    r.match(E(".$E1. user_mem_check assertion failure for va deadbeef"),
 | 
						|
            E(".$E1. free env $E1"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultnostack():
 | 
						|
    r.user_test("faultnostack")
 | 
						|
    r.match(E(".$E1. user_mem_check assertion failure for va eebfff.."),
 | 
						|
            E(".$E1. free env $E1"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultbadhandler():
 | 
						|
    r.user_test("faultbadhandler")
 | 
						|
    r.match(E(".$E1. user_mem_check assertion failure for va (deadb|eebfe)..."),
 | 
						|
            E(".$E1. free env $E1"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_faultevilhandler():
 | 
						|
    r.user_test("faultevilhandler")
 | 
						|
    r.match(E(".$E1. user_mem_check assertion failure for va (f0100|eebfe)..."),
 | 
						|
            E(".$E1. free env $E1"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_forktree():
 | 
						|
    r.user_test("forktree")
 | 
						|
    r.match("....: I am .0.",
 | 
						|
            "....: I am .1.",
 | 
						|
            "....: I am .000.",
 | 
						|
            "....: I am .100.",
 | 
						|
            "....: I am .110.",
 | 
						|
            "....: I am .111.",
 | 
						|
            "....: I am .011.",
 | 
						|
            "....: I am .001.",
 | 
						|
            E(".$E1. exiting gracefully"),
 | 
						|
            E(".$E2. exiting gracefully"),
 | 
						|
            ".0000200.. exiting gracefully",
 | 
						|
            ".0000200.. free env 0000200.")
 | 
						|
 | 
						|
end_part("B")
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_spin():
 | 
						|
    r.user_test("spin")
 | 
						|
    r.match(E(".00000000. new env $E1"),
 | 
						|
            "I am the parent.  Forking the child...",
 | 
						|
            E(".$E1. new env $E2"),
 | 
						|
            "I am the parent.  Running the child...",
 | 
						|
            "I am the child.  Spinning...",
 | 
						|
            "I am the parent.  Killing the child...",
 | 
						|
            E(".$E1. destroying $E2"),
 | 
						|
            E(".$E1. free env $E2"),
 | 
						|
            E(".$E1. exiting gracefully"),
 | 
						|
            E(".$E1. free env $E1"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_stresssched():
 | 
						|
    r.user_test("stresssched", make_args=["CPUS=4"])
 | 
						|
    r.match(".000010... stresssched on CPU 0",
 | 
						|
            ".000010... stresssched on CPU 1",
 | 
						|
            ".000010... stresssched on CPU 2",
 | 
						|
            ".000010... stresssched on CPU 3",
 | 
						|
            no=[".*ran on two CPUs at once"])
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_sendpage():
 | 
						|
    r.user_test("sendpage", make_args=["CPUS=2"])
 | 
						|
    r.match(".00000000. new env 00001000",
 | 
						|
            E(".00000000. new env $E1"),
 | 
						|
            E(".$E1. new env $E2"),
 | 
						|
            E("$E1 got message: hello child environment! how are you?", trim=True),
 | 
						|
            E("child received correct message", trim=True),
 | 
						|
            E("$E2 got message: hello parent environment! I'm good", trim=True),
 | 
						|
            E("parent received correct message", trim=True),
 | 
						|
            E(".$E1. exiting gracefully"),
 | 
						|
            E(".$E1. free env $E1"),
 | 
						|
            E(".$E2. exiting gracefully"),
 | 
						|
            E(".$E2. free env $E2"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_pingpong():
 | 
						|
    r.user_test("pingpong", make_args=["CPUS=4"])
 | 
						|
    r.match(E(".00000000. new env $E1"),
 | 
						|
            E(".$E1. new env $E2"),
 | 
						|
            E("send 0 from $E1 to $E2", trim=True),
 | 
						|
            E("$E2 got 0 from $E1", trim=True),
 | 
						|
            E("$E1 got 1 from $E2", trim=True),
 | 
						|
            E("$E2 got 8 from $E1", trim=True),
 | 
						|
            E("$E1 got 9 from $E2", trim=True),
 | 
						|
            E("$E2 got 10 from $E1", trim=True),
 | 
						|
            E(".$E1. exiting gracefully"),
 | 
						|
            E(".$E1. free env $E1"),
 | 
						|
            E(".$E2. exiting gracefully"),
 | 
						|
            E(".$E2. free env $E2"))
 | 
						|
 | 
						|
@test(5)
 | 
						|
def test_primes():
 | 
						|
    r.user_test("primes", stop_on_line("CPU .: 1877"), stop_on_line(".*panic"),
 | 
						|
                make_args=["CPUS=4"], timeout=60)
 | 
						|
    r.match(E(".00000000. new env $E1"),
 | 
						|
            E(".$E1. new env $E2"),
 | 
						|
            E("CPU .: 2 .$E2. new env $E3"),
 | 
						|
            E("CPU .: 3 .$E3. new env $E4"),
 | 
						|
            E("CPU .: 5 .$E4. new env $E5"),
 | 
						|
            E("CPU .: 7 .$E5. new env $E6"),
 | 
						|
            E("CPU .: 11 .$E6. new env $E7"),
 | 
						|
            E("CPU .: 1877 .$E289. new env $E290"))
 | 
						|
 | 
						|
end_part("C")
 | 
						|
 | 
						|
run_tests()
 |