readme.txt 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. Usage
  2. -----
  3. To start the test suite execute:
  4. make full TEST_FPC=path_to_your_compiler
  5. This should run all tests, scan the created log file and output some
  6. statistics.
  7. make digest TEST_FPC=path_to_your_compiler
  8. scans the created log file and outputs some statistics
  9. make digest USESQL=YES TEST_FPC=path_to_your_compiler
  10. sends the results to an SQL database
  11. When the tests are performed, first the units (e.g. rtl) needed by the
  12. tests are compiled in a clean determined way and put in the units
  13. directory. Then webtbs/webtbf/test/tbs/tbf are searched for t*.pp to be
  14. compiled and executed as tests.
  15. Directories
  16. -----------
  17. webtbs...........Tests for web-bug-database bugs (should compile/run)
  18. Digits in filename refer to bug database entry
  19. webtbf...........Tests for web-bug-database bugs (should not compile/run)
  20. Digits in filename refer to bug database entry
  21. test.............Test suites for different aspects of the compiler/rtl etc
  22. test/packages....Tests depending on packages. The tests are sorted by package
  23. though this is not mandatory because tests can depend on
  24. multiple packages
  25. tbs..............Tests for other bugs, added by the fpc core team
  26. (success in compilation) Digits in filename is a serial no
  27. tbf..............Tests for other bugs, added by the fpc core team
  28. (fail compile) Digits in filename is a serial no
  29. units............Helper units for doing the tests
  30. utils............Utilities for processing tests
  31. Writing a test
  32. --------------
  33. A test should have a name on the form t*.pp, to be recognized as a test.
  34. It should return 0 on success, any other value indicates failure.
  35. Test directives
  36. ---------------
  37. At the top of the test source code, some directives can be used to
  38. determine how the tests will be processed (if processed automatically via
  39. make), e.g. {%CPU=i386}:
  40. OPT................Compiler option required to compile
  41. CPU................Only for these CPU's (i386,m68k,etc). Might be a list.
  42. SKIPCPU............Not for these CPU's (i386,m68k,etc). Might be a list.
  43. TARGET.............Only for these OS targets (win32,MacOS,etc).
  44. Might be a list.
  45. SKIPTARGET.........Not for these OS targets (win32,MacOS,etc).
  46. Might be a list.
  47. VERSION............Compiler with at lest this version number required.
  48. MAXVERSION.........Compiler with at most this version number required.
  49. RESULT.............Exit code of execution of test expected
  50. TIMEOUT............Timeout indication for test in seconds (only used if
  51. enabled by defining TEST_TIMEOUT)
  52. FILES..............List of files (separated by spaces) required by test,
  53. will be copied to remote before execution
  54. GRAPH..............Requires graph unit
  55. FAIL...............Compilation must fail
  56. RECOMPILE..........After compiling a test, recompile the test for a second
  57. time. This is needed to test ppu loading issues.
  58. NORUN..............Do not execute test, only compile it
  59. INTERACTIVE........Do not execute test, as it requires user intervention
  60. NOTE...............Output note when compiling/executing test
  61. NEEDLIBRARY........Adds -rpath to the linker for unix. This is needed to
  62. test runtime library tests. The library needs the -FE.
  63. option to place the .so in the correct directory.
  64. KNOWNRUNERROR......Known bug, which manifest itself at runtime. To the
  65. right of the equal sign is the expected exit code,
  66. followed by an optional note. Will not be logged
  67. as a bug.
  68. KNOWNCOMPILEERROR..Known bug, which manifest itself at compile time. To
  69. the right of the equal sign is the expected exit code
  70. from compiler, followed by an optional note. Will not
  71. be logged as a bug.
  72. QUICKTEST..........If set, only tests without package dependencies are executed
  73. NOTE: A list consists of comma separated items, e. g. CPU=i386,m68k,powerpc
  74. No space between the elements and the comma.
  75. Controling testing in more detail
  76. ---------------------------------
  77. Calling "make full" will perform tests in a standard manner. To have
  78. more control of the test process one must distinguish between:
  79. * Driver enviroment: compiler/rtl etc. to be used by the tools which
  80. runs and analyze the tests. All normal options to make, like FPC
  81. OS_TARGET, OPT etc. controls this.
  82. * Test environment: compiler/rtl etc. to be tested, to be used
  83. *in* the tests. Ususal options, prepended with TEST_ , controls
  84. this. If no such options are given, test and driver environment
  85. will be the same.
  86. This differentiation also enables cross testing.
  87. The following test options can be given:
  88. TEST_FPC compiler to test (no default)
  89. TEST_OS_TARGET defaults to default target of TEST_FPC
  90. TEST_CPU_TARGET defaults to default target of TEST_FPC
  91. TEST_OPT defaults to ""
  92. TEST_FPC_VERSION defaults to version of TEST_FPC
  93. TEST_CCOMPILER defaults to installed gcc compiler, but only
  94. if driver and test full-targets are the same.
  95. TEST_VERBOSE let dotest be more verbose, only usefull for debugging
  96. TEST_DELTEMP delete temporary executable/object/ppu file,
  97. default is off
  98. TEST_TIMEOUT use timeout wrapper for (remote) execution
  99. V print dotest commandline
  100. (Please add more test options if needed)
  101. NOTE: To clean after a test session, "make clean TEST_FPC=path_to_your_compiler"
  102. must be given the same options as when running the tests.
  103. The utils directory is considerd to belong to the driver environment,
  104. all other directories belong to the test environment.
  105. Remote execution
  106. ----------------
  107. Also remote execution of the test suite is possible.
  108. Requirements:
  109. - rsh/ssh must work without keyboard interaction or extra parameters
  110. Test options:
  111. TEST_RSH set this to the hostname when you want to use rsh/rcp
  112. to execute/copy the test
  113. TEST_SSH set this to use ssh/scp to execute the test
  114. TEST_PUTTY test using putty when remote testing (pscp and plink)
  115. TEST_REMOTEOPT extra options to remote program
  116. TEST_REMOTEPATH set remote path to use, default is /tmp
  117. TEST_DELBEFORE delete remote executable before uploading
  118. TEST_DELTEMP delete executable after running, so the remote system
  119. doesn't need much free disk space
  120. TEST_REMOTEPW pass a password with -pw to remote tools,
  121. mainly usefull for putty
  122. Examples:
  123. -------
  124. make TEST_FPC=$HOME/fpc/compiler/ppcsparc TEST_BINUTILSPREFIX=sparc-linux- \
  125. TEST_RSH=sunny TEST_REMOTEPATH=/tmp/tests
  126. make TEST_FPC=$HOME/fpc/compiler/ppcsparc TEST_BINUTILSPREFIX=sparc-linux- \
  127. TEST_SSH=fpc@sunny TEST_REMOTEPATH=/tmp/tests
  128. Example for win32/putty:
  129. make TEST_FPC=c:\fpc\compiler\ppcarm TEST_BINUTILSPREFIX=arm-linux- \
  130. [email protected] TEST_REMOTEPATH=/tmp TEST_DELTEMP=1 \
  131. "TEST_REMOTEPW=xxx" FPC=c:\fpc\compiler\ppc386
  132. Emulator execution
  133. ------------------
  134. Emulator execution is possible as well. It can't be combined with remote
  135. execution though.
  136. EMULATOR: name of the emulator to use
  137. Examples:
  138. make TEST_FPC=~/fpc/compiler/ppcrossarm TEST_OPT=-XParm-linux- \
  139. EMULATOR=qemu-arm
  140. make TEST_FPC=~/fpc/compiler/ppcrossarm TEST_OPT=-XParm-linux- \
  141. EMULATOR=qemu-arm digest DBDIGESTOPT="-C qemu-arm" USESQL=YES
  142. Example cross testing of target Mac OS with driver Darwin
  143. --------------------------------------------------------
  144. NOTE: Today, it is possible to run the test suite Mac OS native.
  145. A machine with both Mac OS X and classic Mac OS installed is required.
  146. Note that make will not run the tests. This has to be done in MPW with the
  147. scripts in utils/MacOS.
  148. make clean alltest TEST_OS_TARGET=MacOS TEST_OPT="-WT -st" \
  149. USEUNITDIR=/Projekt/Freepascal/fpc/rtl/MacOS
  150. To clean. Note that same options as above has to be given so that the
  151. correct files will be removed.
  152. make clean TEST_OS_TARGET=MacOS USEUNITDIR=/Projekt/Freepascal/fpc/rtl/MacOS
  153. Example cross testing of target arm-wince
  154. -----------------------------------------
  155. //arm-wince example:
  156. see FPCTRUNK\DEMO\WINCE\TESTEMU\ for additionally required tools
  157. Connect your device via ActiveSync and execute:
  158. make TEST_FPC=ppcrossarm TEST_CPU_TARGET=arm TEST_OS_TARGET=wince \
  159. TEST_OPT="-XParm-wince- -WC -Xs" \
  160. EMULATOR=MyDisc:\My\Path\to\wcetemu.exe
  161. Tests will be performed in the \fpctests folder on the device.
  162. Result uploading
  163. ----------------
  164. Results can be uploaded to the test suite result DB
  165. (http://www.freepascal.org/testsuite/cgi-bin/testsuite.cgi) by executing
  166. make uploadrun
  167. On unix:
  168. - The testing machine must be enabled to login on www.freepascal.org
  169. automatically as user fpc with ssh.
  170. On Windows:
  171. - The putty utilities plink.exe and pscp.exe must be in the path
  172. - There must be a putty session named [email protected] which is
  173. enabled to login automatically into www.freepascal.org