1 xnu_quick_test - this tool will do a quick test of every (well, to be
2 honest most) system calls we support in xnu.
4 WARNING - this is not meant to be a full regression test of all the
5 system calls. The intent is to have a quick test of each system call that
6 can be run very easily and quickly when a new kernel is built.
8 This tool is meant to grow as we find xnu problems that could have be
9 caught before we submit to a build train. So please add more tests and
10 make the existing ones better. Some of the original tests are nothing
11 more than place holders and quite lame. Just keep in mind that the tool
12 should run as fast as possible. If it gets too slow then most people
15 LP64 testing tip - when adding or modifying tests, keep in mind the
16 variants in the LP64 world. If xnu gets passed a structure the varies in
17 size between 32 and 64-bit processes, try to test that a field in the
18 structure contains valid data. For example, if we know foo structure
25 And if we know what another_int should contain then test for the known
26 value since it's offset will vary depending on whether the calling process
29 NOTE - we have several workarounds and test exceptions for some
30 outstanding bugs in xnu. All the workarounds are marked with "todo" and
31 some comments noting the radar number of the offending bug. Do a search
32 for "todo" in the source files for this project to locate which tests have
33 known failures. And please tag any new exceptions you find with "todo"
34 in the comment and the radar number of the bug.
36 To build a fat binary, export ARCH="i386 x86_64". This will work
37 for any architectures that Apple gcc recognizes.
39 Added four defines which you can use at the compile line to build variants.
41 turn on additional printfs
42 CONFORMANCE_TESTS_IN_XNU
43 when conformance tests are in xnu, set this to 1
45 test system calls (doesn't compile; a different bug)
47 when running under testbots, set this to 1
48 by default, all four are set to 0, i.e. disabled. To build, export
49 MORECFLAGS with the values you want set, e.g.
50 export MORECFLAGS="-D DEBUG=1 -D CONFORMANCE_TESTS_IN_XNU=1"
53 -- have folks with area expertise fix lame tests
54 (most of the networking related tests are pretty lame)
55 -- mach system calls support
58 USAGE: xnu_quick_test -target TARGET_PATH
60 -f[ailures] MAX_FAILS_ALLOWED # number of test cases that may fail before we give up. defaults to 0
61 -l[ist] # list all the tests this tool performs
62 -r[un] 1, 3, 10 - 19 # run specific tests. enter individual test numbers and/or range of numbers. use -list to list tests.
63 -s[kip] # skip setuid tests
64 -t[arget] TARGET_PATH # path to directory where tool will create test files. defaults to "/tmp/"
65 -testbot # output results in CoreOS TestBot compatible format
68 --- Place all test files and directories at the root of volume "test_vol" ---
69 xnu_quick_test -t /Volumes/test_vol/
71 --- Run the tool for tests 10 thru 15, test 18 and test 20 ---
72 xnu_quick_test -r 10-15, 18, 20
75 --- example of running the tool to list all the tests it currently supports ---
77 List of all tests this tool performs...
80 3 fsync, ftruncate, lseek, pread, pwrite, read, readv, truncate, write, writev
81 4 close, fpathconf, fstat, open, pathconf
84 7 access, chmod, fchmod
85 8 chown, fchown, lchown, lstat, readlink, symlink
86 9 fstatfs, getattrlist, getfsstat, statfs
87 10 getpid, getppid, pipe
88 11 getauid, gettid, getuid, geteuid, issetugid, setaudit_addr, seteuid, settid, settid_with_pid, setuid
89 12 mkdir, rmdir, umask
91 14 fsync, getsockopt, poll, select, setsockopt, socketpair
92 15 accept, bind, connect, getpeername, getsockname, listen, socket, recvmsg, sendmsg, sendto, sendfile
94 17 kill, vfork, execve
95 18 getegid, getgid, getgroups, setegid, setgid, setgroups
96 19 dup, dup2, getdtablesize
98 21 getitimer, setitimer, sigaction, sigpending, sigprocmask, sigsuspend, sigwait
102 25 madvise, mincore, minherit, mlock, mlock, mmap, mprotect, msync, munmap
103 26 getpgrp, getpgid, getsid, setpgid, setpgrp, setsid
105 28 getlogin, setlogin
106 29 getpriority, setpriority
107 30 futimes, gettimeofday, settimeofday, utimes
110 33 mkfifo, read, write
112 35 getrlimit, setrlimit
113 36 getattrlist, getdirentries, getdirentriesattr, setattrlist
116 39 sem_close, sem_open, sem_post, sem_trywait, sem_unlink, sem_wait
117 40 semctl, semget, semop
118 41 shm_open, shm_unlink
119 42 shmat, shmctl, shmdt, shmget
120 43 fgetxattr, flistxattr, fremovexattr, fsetxattr, getxattr, listxattr, removexattr, setxattr
121 44 aio_cancel, aio_error, aio_read, aio_return, aio_suspend, aio_write, fcntl, lio_listio
123 46 msgctl, msgget, msgrcv, msgsnd
126 --- example of a full test run ---
127 cottje% ./BUILD/dst/xnu_quick_test
128 created test directory at "/tmp/xnu_quick_test-1660251855"
129 Will allow 0 failures before testing is aborted
131 Begin testing - Tue Dec 13 15:56:50 2005
134 test #2 - fork, wait4, exit
135 test #3 - fsync, ftruncate, lseek, pread, pwrite, read, readv, truncate, write, writev
136 test #4 - close, fpathconf, fstat, open, pathconf
137 test #5 - link, stat, unlink
138 test #6 - chdir, fchdir
139 test #7 - access, chmod, fchmod
140 test #8 - chown, fchown, lchown, lstat, readlink, symlink
141 test #9 - fstatfs, getattrlist, getfsstat, statfs
142 test #10 - getpid, getppid, pipe
143 test #11 - getauid, gettid, getuid, geteuid, issetugid, setauid, seteuid, settid, settid_with_pid, setuid
144 test #12 - mkdir, rmdir, umask
145 test #13 - mknod, sync
146 test #14 - fsync, getsockopt, poll, select, setsockopt, socketpair
147 test #15 - accept, bind, connect, getpeername, getsockname, listen, socket, recvmsg, sendmsg, sendto
148 test #16 - chflags, fchflags
149 test #17 - kill, vfork, execve
150 test #18 - getegid, getgid, getgroups, setegid, setgid, setgroups
151 test #19 - dup, dup2, getdtablesize
152 test #20 - getrusage, profil
154 test #22 - getitimer, setitimer, sigaction, sigpending, sigprocmask, sigsuspend, sigwait
158 test #26 - madvise, mincore, minherit, mlock, mlock, mmap, mprotect, msync, munmap
159 test #27 - getpgrp, getpgid, getsid, setpgid, setpgrp, setsid
161 test #29 - getlogin, setlogin
162 test #30 - getpriority, setpriority
163 test #31 - futimes, gettimeofday, settimeofday, utimes
164 test #32 - rename, stat
166 test #34 - mkfifo, read, write
168 test #36 - getrlimit, setrlimit
169 test #37 - getattrlist, getdirentries, getdirentriesattr, setattrlist
170 test #38 - exchangedata
172 test #40 - sem_close, sem_open, sem_post, sem_trywait, sem_unlink, sem_wait
173 test #41 - semctl, semget, semop
174 test #42 - shm_open, shm_unlink
175 test #43 - shmat, shmctl, shmdt, shmget
176 test #44 - fgetxattr, flistxattr, fremovexattr, fsetxattr, getxattr, listxattr, removexattr, setxattr
177 test #45 - aio_cancel, aio_error, aio_read, aio_return, aio_suspend, aio_write, fcntl, lio_listio
178 test #46 - kevent, kqueue
179 test #47 - msgctl, msgget, msgrcv, msgsnd
181 End testing - Tue Dec 13 15:57:08 2005