12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- #!/usr/bin/python
- import os, sys, mmap
- from regression import Regression
- loader = os.environ['PAL_LOADER']
- regression = Regression(loader, "Process")
- def check_times(target, lines, times):
- count = 0
- for line in lines:
- if target == line:
- count += 1
- return count == times
- regression.add_check(name="Process Creation",
- check=lambda res: check_times("Child Process Created", res[0].log, 3))
- regression.add_check(name="Process Creation Arguments",
- check=lambda res: check_times("argv[0] = Process", res[0].log, 3) and
- check_times("argv[1] = Child", res[0].log, 3))
- regression.add_check(name="Process Channel Transmission",
- check=lambda res: check_times("Process Write 1 OK", res[0].log, 3) and
- check_times("Process Read 1: Hello World 1", res[0].log, 3) and
- check_times("Process Write 2 OK", res[0].log, 3) and
- check_times("Process Read 2: Hello World 2", res[0].log, 3))
- regression.add_check(name="Multi-Process Broadcast Channel Transmission",
- check=lambda res: check_times("Broadcast Write OK", res[0].log, 1) and
- check_times("Broadcast Read: Hello World 1", res[0].log, 3))
- rv = regression.run_checks()
- if rv: sys.exit(rv)
- regression = Regression(loader, "Process2")
- regression.add_check(name="Process Creation with a Different Binary",
- check=lambda res: check_times("User Program Started", res[0].log, 1))
- rv = regression.run_checks()
- if rv: sys.exit(rv)
- regression = Regression(loader, "Process3")
- regression.add_check(name="Process Creation without Executable",
- check=lambda res: check_times("Binary 1 Preloaded", res[0].log, 2) and
- check_times("Binary 2 Preloaded", res[0].log, 2))
- rv = regression.run_checks()
- if rv: sys.exit(rv)
|