The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/tools/tests/xnu_quick_test/README

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    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.
    3 
    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.
    7 
    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
   13 will stop running it.
   14 
   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
   19 looks like:
   20 struct foo {
   21              int             an_int;
   22              long    a_long;
   23              int             another_int;
   24 }
   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
   27 is 32 or 64 bits.
   28 
   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.
   35 
   36 To build a fat binary, export ARCH="i386 x86_64". This will work
   37 for any architectures that Apple gcc recognizes.
   38 
   39 Added four defines which you can use at the compile line to build variants.
   40 DEBUG
   41        turn on additional printfs
   42 CONFORMANCE_TESTS_IN_XNU 
   43        when conformance tests are in xnu, set this to 1
   44 TEST_SYSTEM_CALLS
   45        test system calls (doesn't compile; a different bug)
   46 RUN_UNDER_TESTBOTS
   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"
   51 
   52 todo:
   53 -- have folks with area expertise fix lame tests
   54    (most of the networking related tests are pretty lame)
   55 -- mach system calls support
   56 
   57 
   58 USAGE:  xnu_quick_test -target TARGET_PATH 
   59 
   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          -x[ilog]                        # To run the xnu_quick_test with xilog reporting enabled. 
   66 
   67 examples:  
   68 --- Place all test files and directories at the root of volume "test_vol" --- 
   69 xnu_quick_test -t /Volumes/test_vol/ 
   70  
   71 --- Run the tool for tests 10 thru 15, test 18 and test 20 --- 
   72 xnu_quick_test -r 10-15, 18, 20 
   73 
   74 
   75 --- example of running the tool to list all the tests it currently supports ---
   76 xnu_quick_test -l
   77 List of all tests this tool performs... 
   78  1         syscall 
   79  2         fork, wait4, exit 
   80  3         fsync, ftruncate, lseek, pread, pwrite, read, readv, truncate, write, writev 
   81  4         close, fpathconf, fstat, open, pathconf 
   82  5         link, stat, unlink 
   83  6         chdir, fchdir 
   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 
   90  13        mknod, sync 
   91  14        fsync, getsockopt, poll, select, setsockopt, socketpair 
   92  15        accept, bind, connect, getpeername, getsockname, listen, socket, recvmsg, sendmsg, sendto, sendfile
   93  16        chflags, fchflags 
   94  17        kill, vfork, execve 
   95  18        getegid, getgid, getgroups, setegid, setgid, setgroups 
   96  19        dup, dup2, getdtablesize 
   97  20        getrusage, profil 
   98  21        getitimer, setitimer, sigaction, sigpending, sigprocmask, sigsuspend, sigwait 
   99  22        acct 
  100  23        ioctl 
  101  24        chroot 
  102  25        madvise, mincore, minherit, mlock, mlock, mmap, mprotect, msync, munmap 
  103  26        getpgrp, getpgid, getsid, setpgid, setpgrp, setsid 
  104  27        fcntl 
  105  28        getlogin, setlogin 
  106  29        getpriority, setpriority 
  107  30        futimes, gettimeofday, settimeofday, utimes 
  108  31        rename, stat 
  109  32        flock 
  110  33        mkfifo, read, write 
  111  34        quotactl 
  112  35        getrlimit, setrlimit 
  113  36        getattrlist, getdirentries, getdirentriesattr, setattrlist 
  114  37        exchangedata 
  115  38        searchfs 
  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 
  122  45        kevent, kqueue 
  123  46        msgctl, msgget, msgrcv, msgsnd 
  124 
  125 
  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 
  130 
  131 Begin testing - Tue Dec 13 15:56:50 2005
  132  
  133 test #1 - syscall 
  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 
  153 test #21 - ktrace 
  154 test #22 - getitimer, setitimer, sigaction, sigpending, sigprocmask, sigsuspend, sigwait 
  155 test #23 - acct 
  156 test #24 - ioctl 
  157 test #25 - chroot 
  158 test #26 - madvise, mincore, minherit, mlock, mlock, mmap, mprotect, msync, munmap 
  159 test #27 - getpgrp, getpgid, getsid, setpgid, setpgrp, setsid 
  160 test #28 - fcntl 
  161 test #29 - getlogin, setlogin 
  162 test #30 - getpriority, setpriority 
  163 test #31 - futimes, gettimeofday, settimeofday, utimes 
  164 test #32 - rename, stat 
  165 test #33 - flock 
  166 test #34 - mkfifo, read, write 
  167 test #35 - quotactl 
  168 test #36 - getrlimit, setrlimit 
  169 test #37 - getattrlist, getdirentries, getdirentriesattr, setattrlist 
  170 test #38 - exchangedata 
  171 test #39 - searchfs 
  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 
  180 
  181 End testing - Tue Dec 13 15:57:08 2005

Cache object: c26129e9665144e41efffc58feb13b7a


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.