| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 1 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" | 
|  | 2 | "http://www.w3.org/TR/html4/strict.dtd"> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 3 | <html> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 4 | <head> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 5 | <title>LLVM Testing Infrastructure Guide</title> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 6 | <link rel="stylesheet" href="llvm.css" type="text/css"> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 7 | </head> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 8 | <body> | 
|  | 9 |  | 
|  | 10 | <div class="doc_title"> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 11 | LLVM Testing Infrastructure Guide | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 12 | </div> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 13 |  | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 14 | <ol> | 
| Reid Spencer | 49fb40c | 2004-11-01 08:30:14 +0000 | [diff] [blame] | 15 | <li><a href="#overview">Overview</a></li> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 16 | <li><a href="#requirements">Requirements</a></li> | 
|  | 17 | <li><a href="#org">LLVM testing infrastructure organization</a> | 
| Reid Spencer | 49fb40c | 2004-11-01 08:30:14 +0000 | [diff] [blame] | 18 | <ul> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 19 | <li><a href="#dejagnu">DejaGNU tests</a></li> | 
|  | 20 | <li><a href="#testsuite">Test suite</a></li> | 
| Reid Spencer | 49fb40c | 2004-11-01 08:30:14 +0000 | [diff] [blame] | 21 | </ul> | 
|  | 22 | </li> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 23 | <li><a href="#quick">Quick start</a> | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 24 | <ul> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 25 | <li><a href="#quickdejagnu">DejaGNU tests</a></li> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 26 | <li><a href="#quicktestsuite">Test suite</a></li> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 27 | </ul> | 
|  | 28 | </li> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 29 | <li><a href="#dgstructure">DejaGNU structure</a> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 30 | <ul> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 31 | <li><a href="#dgcustom">Writing new DejaGNU tests</a></li> | 
| Chris Lattner | 7e11b72 | 2009-08-15 15:40:48 +0000 | [diff] [blame] | 32 | <li><a href="#FileCheck">The FileCheck utility</a></li> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 33 | <li><a href="#dgvars">Variables and substitutions</a></li> | 
|  | 34 | <li><a href="#dgfeatures">Other features</a></li> | 
|  | 35 | </ul> | 
|  | 36 | </li> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 37 | <li><a href="#testsuitestructure">Test suite structure</a></li> | 
|  | 38 | <li><a href="#testsuiterun">Running the test suite</a> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 39 | <ul> | 
| Stuart Hastings | 6d43769 | 2009-05-21 20:23:59 +0000 | [diff] [blame] | 40 | <li><a href="#testsuiteexternal">Configuring External Tests</a></li> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 41 | <li><a href="#testsuitetests">Running different tests</a></li> | 
|  | 42 | <li><a href="#testsuiteoutput">Generating test output</a></li> | 
|  | 43 | <li><a href="#testsuitecustom">Writing custom tests for llvm-test</a></li> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 44 | </ul> | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 45 | </li> | 
| Reid Spencer | 49fb40c | 2004-11-01 08:30:14 +0000 | [diff] [blame] | 46 | <li><a href="#nightly">Running the nightly tester</a></li> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 47 | </ol> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 48 |  | 
| Chris Lattner | 020e1fc | 2004-05-23 21:07:27 +0000 | [diff] [blame] | 49 | <div class="doc_author"> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 50 | <p>Written by John T. Criswell, <a | 
|  | 51 | href="http://llvm.x10sys.com/rspencer">Reid Spencer</a>, and Tanya Lattner</p> | 
| Chris Lattner | 020e1fc | 2004-05-23 21:07:27 +0000 | [diff] [blame] | 52 | </div> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 53 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 54 | <!--=========================================================================--> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 55 | <div class="doc_section"><a name="overview">Overview</a></div> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 56 | <!--=========================================================================--> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 57 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 58 | <div class="doc_text"> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 59 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 60 | <p>This document is the reference manual for the LLVM testing infrastructure. It documents | 
|  | 61 | the structure of the LLVM testing infrastructure, the tools needed to use it, | 
|  | 62 | and how to add and run tests.</p> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 63 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 64 | </div> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 65 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 66 | <!--=========================================================================--> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 67 | <div class="doc_section"><a name="requirements">Requirements</a></div> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 68 | <!--=========================================================================--> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 69 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 70 | <div class="doc_text"> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 71 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 72 | <p>In order to use the LLVM testing infrastructure, you will need all of the software | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 73 | required to build LLVM, plus the following:</p> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 74 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 75 | <dl> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 76 | <dt><a href="http://www.gnu.org/software/dejagnu/">DejaGNU</a></dt> | 
|  | 77 | <dd>The Feature and Regressions tests are organized and run by DejaGNU.</dd> | 
|  | 78 | <dt><a href="http://expect.nist.gov/">Expect</a></dt> | 
|  | 79 | <dd>Expect is required by DejaGNU.</dd> | 
| Tanya Lattner | 9a1b893 | 2004-12-08 17:35:31 +0000 | [diff] [blame] | 80 | <dt><a href="http://www.tcl.tk/software/tcltk/">tcl</a></dt> | 
|  | 81 | <dd>Tcl is required by DejaGNU. </dd> | 
| Misha Brukman | ed3dc43 | 2004-10-08 00:55:43 +0000 | [diff] [blame] | 82 | </dl> | 
| Jim Laskey | 27abf2b | 2006-03-27 18:41:06 +0000 | [diff] [blame] | 83 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 84 | </div> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 85 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 86 | <!--=========================================================================--> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 87 | <div class="doc_section"><a name="org">LLVM testing infrastructure organization</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 88 | <!--=========================================================================--> | 
|  | 89 |  | 
|  | 90 | <div class="doc_text"> | 
|  | 91 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 92 | <p>The LLVM testing infrastructure contains two major categories of tests: code | 
|  | 93 | fragments and whole programs. Code fragments are referred to as the "DejaGNU | 
|  | 94 | tests" and are in the <tt>llvm</tt> module in subversion under the | 
|  | 95 | <tt>llvm/test</tt> directory. The whole programs tests are referred to as the | 
|  | 96 | "Test suite" and are in the <tt>test-suite</tt> module in subversion. | 
|  | 97 | </p> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 98 |  | 
|  | 99 | </div> | 
|  | 100 |  | 
|  | 101 | <!-- _______________________________________________________________________ --> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 102 | <div class="doc_subsection"><a name="dejagnu">DejaGNU tests</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 103 | <!-- _______________________________________________________________________ --> | 
|  | 104 |  | 
|  | 105 | <div class="doc_text"> | 
|  | 106 |  | 
| Shantonu Sen | 89d5c41 | 2009-06-26 05:44:53 +0000 | [diff] [blame] | 107 | <p>Code fragments are small pieces of code that test a specific | 
|  | 108 | feature of LLVM or trigger a specific bug in LLVM.  They are usually | 
|  | 109 | written in LLVM assembly language, but can be written in other | 
|  | 110 | languages if the test targets a particular language front end (and the | 
|  | 111 | appropriate <tt>--with-llvmgcc</tt> options were used | 
|  | 112 | at <tt>configure</tt> time of the <tt>llvm</tt> module). These tests | 
|  | 113 | are driven by the DejaGNU testing framework, which is hidden behind a | 
|  | 114 | few simple makefiles.</p> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 115 |  | 
| Shantonu Sen | 89d5c41 | 2009-06-26 05:44:53 +0000 | [diff] [blame] | 116 | <p>These code fragments are not complete programs. The code generated | 
|  | 117 | from them is never executed to determine correct behavior.</p> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 118 |  | 
|  | 119 | <p>These code fragment tests are located in the <tt>llvm/test</tt> | 
|  | 120 | directory.</p> | 
|  | 121 |  | 
|  | 122 | <p>Typically when a bug is found in LLVM, a regression test containing | 
|  | 123 | just enough code to reproduce the problem should be written and placed | 
|  | 124 | somewhere underneath this directory.  In most cases, this will be a small | 
|  | 125 | piece of LLVM assembly language code, often distilled from an actual | 
|  | 126 | application or benchmark.</p> | 
|  | 127 |  | 
|  | 128 | </div> | 
|  | 129 |  | 
|  | 130 | <!-- _______________________________________________________________________ --> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 131 | <div class="doc_subsection"><a name="testsuite">Test suite</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 132 | <!-- _______________________________________________________________________ --> | 
|  | 133 |  | 
|  | 134 | <div class="doc_text"> | 
|  | 135 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 136 | <p>The test suite contains whole programs, which are pieces of | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 137 | code which can be compiled and linked into a stand-alone program that can be | 
|  | 138 | executed.  These programs are generally written in high level languages such as | 
|  | 139 | C or C++, but sometimes they are written straight in LLVM assembly.</p> | 
|  | 140 |  | 
|  | 141 | <p>These programs are compiled and then executed using several different | 
|  | 142 | methods (native compiler, LLVM C backend, LLVM JIT, LLVM native code generation, | 
|  | 143 | etc).  The output of these programs is compared to ensure that LLVM is compiling | 
|  | 144 | the program correctly.</p> | 
|  | 145 |  | 
|  | 146 | <p>In addition to compiling and executing programs, whole program tests serve as | 
|  | 147 | a way of benchmarking LLVM performance, both in terms of the efficiency of the | 
|  | 148 | programs generated as well as the speed with which LLVM compiles, optimizes, and | 
|  | 149 | generates code.</p> | 
|  | 150 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 151 | <p>The test-suite is located in the <tt>test-suite</tt> Subversion module.</p> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 152 |  | 
|  | 153 | </div> | 
|  | 154 |  | 
|  | 155 | <!--=========================================================================--> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 156 | <div class="doc_section"><a name="quick">Quick start</a></div> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 157 | <!--=========================================================================--> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 158 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 159 | <div class="doc_text"> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 160 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 161 | <p>The tests are located in two separate Subversion modules. The | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 162 | DejaGNU tests are in the main "llvm" module under the directory | 
|  | 163 | <tt>llvm/test</tt> (so you get these tests for free with the main llvm tree). | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 164 | The more comprehensive test suite that includes whole | 
|  | 165 | programs in C and C++ is in the <tt>test-suite</tt> module. This module should | 
|  | 166 | be checked out to the <tt>llvm/projects</tt> directory (don't use another name | 
|  | 167 | then the default "test-suite", for then the test suite will be run every time | 
|  | 168 | you run <tt>make</tt> in the main <tt>llvm</tt> directory). | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 169 | When you <tt>configure</tt> the <tt>llvm</tt> module, | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 170 | the <tt>test-suite</tt> directory will be automatically configured. | 
| Reid Spencer | c7f87f2 | 2007-07-09 08:04:31 +0000 | [diff] [blame] | 171 | Alternatively, you can configure the <tt>test-suite</tt> module manually.</p> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 172 |  | 
|  | 173 | <!-- _______________________________________________________________________ --> | 
|  | 174 | <div class="doc_subsection"><a name="quickdejagnu">DejaGNU tests</a></div> | 
|  | 175 | <!-- _______________________________________________________________________ --> | 
| Chris Lattner | 15f17ec | 2006-05-23 01:25:11 +0000 | [diff] [blame] | 176 | <p>To run all of the simple tests in LLVM using DejaGNU, use the master Makefile | 
|  | 177 | in the <tt>llvm/test</tt> directory:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 178 |  | 
|  | 179 | <div class="doc_code"> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 180 | <pre> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 181 | % gmake -C llvm/test | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 182 | </pre> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 183 | </div> | 
|  | 184 |  | 
|  | 185 | <p>or</p> | 
|  | 186 |  | 
|  | 187 | <div class="doc_code"> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 188 | <pre> | 
|  | 189 | % gmake check | 
|  | 190 | </pre> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 191 | </div> | 
| John Criswell | 61617f7 | 2005-05-13 20:25:49 +0000 | [diff] [blame] | 192 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 193 | <p>To run only a subdirectory of tests in <tt>llvm/test</tt> using DejaGNU (ie. | 
|  | 194 | Transforms), just set the TESTSUITE variable to the path of the | 
| John Criswell | 61617f7 | 2005-05-13 20:25:49 +0000 | [diff] [blame] | 195 | subdirectory (relative to <tt>llvm/test</tt>):</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 196 |  | 
|  | 197 | <div class="doc_code"> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 198 | <pre> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 199 | % gmake TESTSUITE=Transforms check | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 200 | </pre> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 201 | </div> | 
| Misha Brukman | 5da60ba | 2005-03-10 22:51:59 +0000 | [diff] [blame] | 202 |  | 
| John Criswell | 61617f7 | 2005-05-13 20:25:49 +0000 | [diff] [blame] | 203 | <p><b>Note: If you are running the tests with <tt>objdir != subdir</tt>, you | 
|  | 204 | must have run the complete testsuite before you can specify a | 
|  | 205 | subdirectory.</b></p> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 206 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 207 | <p>To run only a single test, set <tt>TESTONE</tt> to its path (relative to | 
|  | 208 | <tt>llvm/test</tt>) and make the <tt>check-one</tt> target:</p> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 209 |  | 
|  | 210 | <div class="doc_code"> | 
|  | 211 | <pre> | 
|  | 212 | % gmake TESTONE=Feature/basictest.ll check-one | 
|  | 213 | </pre> | 
|  | 214 | </div> | 
|  | 215 |  | 
| Nuno Lopes | ab6d607 | 2008-11-25 15:57:52 +0000 | [diff] [blame] | 216 | <p>To run the tests with Valgrind (Memcheck by default), just append | 
|  | 217 | <tt>VG=1</tt> to the commands above, e.g.:</p> | 
|  | 218 |  | 
|  | 219 | <div class="doc_code"> | 
|  | 220 | <pre> | 
|  | 221 | % gmake check VG=1 | 
|  | 222 | </pre> | 
|  | 223 | </div> | 
|  | 224 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 225 | <!-- _______________________________________________________________________ --> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 226 | <div class="doc_subsection"><a name="quicktestsuite">Test suite</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 227 | <!-- _______________________________________________________________________ --> | 
|  | 228 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 229 | <p>To run the comprehensive test suite (tests that compile and execute whole | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 230 | programs), first checkout and setup the <tt>test-suite</tt> module:</p> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 231 |  | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 232 | <div class="doc_code"> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 233 | <pre> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 234 | % cd llvm/projects | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 235 | % svn co http://llvm.org/svn/llvm-project/test-suite/trunk test-suite | 
| Tanya Lattner | 8460374 | 2007-11-28 05:13:45 +0000 | [diff] [blame] | 236 | % cd .. | 
|  | 237 | % ./configure --with-llvmgccdir=$LLVM_GCC_DIR | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 238 | </pre> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 239 | </div> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 240 |  | 
| Shantonu Sen | 89d5c41 | 2009-06-26 05:44:53 +0000 | [diff] [blame] | 241 | <p>where <tt>$LLVM_GCC_DIR</tt> is the directory where | 
|  | 242 | you <em>installed</em> llvm-gcc, not it's src or obj | 
|  | 243 | dir. The <tt>--with-llvmgccdir</tt> option assumes that | 
|  | 244 | the <tt>llvm-gcc-4.2</tt> module was configured with | 
|  | 245 | <tt>--program-prefix=llvm-</tt>, and therefore that the C and C++ | 
|  | 246 | compiler drivers are called <tt>llvm-gcc</tt> and <tt>llvm-g++</tt> | 
|  | 247 | respectively.  If this is not the case, | 
|  | 248 | use <tt>--with-llvmgcc</tt>/<tt>--with-llvmgxx</tt> to specify each | 
|  | 249 | executable's location.</p> | 
|  | 250 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 251 | <p>Then, run the entire test suite by running make in the <tt>test-suite</tt> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 252 | directory:</p> | 
|  | 253 |  | 
|  | 254 | <div class="doc_code"> | 
|  | 255 | <pre> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 256 | % cd projects/test-suite | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 257 | % gmake | 
|  | 258 | </pre> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 259 | </div> | 
|  | 260 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 261 | <p>Usually, running the "nightly" set of tests is a good idea, and you can also | 
|  | 262 | let it generate a report by running:</p> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 263 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 264 | <div class="doc_code"> | 
|  | 265 | <pre> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 266 | % cd projects/test-suite | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 267 | % gmake TEST=nightly report report.html | 
|  | 268 | </pre> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 269 | </div> | 
|  | 270 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 271 | <p>Any of the above commands can also be run in a subdirectory of | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 272 | <tt>projects/test-suite</tt> to run the specified test only on the programs in | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 273 | that subdirectory.</p> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 274 |  | 
|  | 275 | </div> | 
|  | 276 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 277 | <!--=========================================================================--> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 278 | <div class="doc_section"><a name="dgstructure">DejaGNU structure</a></div> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 279 | <!--=========================================================================--> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 280 | <div class="doc_text"> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 281 | <p>The LLVM DejaGNU tests are driven by DejaGNU together with GNU Make and are | 
|  | 282 | located in the <tt>llvm/test</tt> directory. | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 283 |  | 
| Reid Spencer | 26e1f92 | 2007-02-08 17:00:55 +0000 | [diff] [blame] | 284 | <p>This directory contains a large array of small tests | 
|  | 285 | that exercise various features of LLVM and to ensure that regressions do not | 
|  | 286 | occur. The directory is broken into several sub-directories, each focused on | 
| Bill Wendling | 6637c57 | 2007-09-22 09:20:07 +0000 | [diff] [blame] | 287 | a particular area of LLVM. A few of the important ones are:</p> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 288 |  | 
| Bill Wendling | 6637c57 | 2007-09-22 09:20:07 +0000 | [diff] [blame] | 289 | <ul> | 
| Reid Spencer | 26e1f92 | 2007-02-08 17:00:55 +0000 | [diff] [blame] | 290 | <li><tt>Analysis</tt>: checks Analysis passes.</li> | 
|  | 291 | <li><tt>Archive</tt>: checks the Archive library.</li> | 
|  | 292 | <li><tt>Assembler</tt>: checks Assembly reader/writer functionality.</li> | 
| Gabor Greif | a54634a | 2007-07-06 22:07:22 +0000 | [diff] [blame] | 293 | <li><tt>Bitcode</tt>: checks Bitcode reader/writer functionality.</li> | 
| Reid Spencer | 26e1f92 | 2007-02-08 17:00:55 +0000 | [diff] [blame] | 294 | <li><tt>CodeGen</tt>: checks code generation and each target.</li> | 
|  | 295 | <li><tt>Features</tt>: checks various features of the LLVM language.</li> | 
| Gabor Greif | a54634a | 2007-07-06 22:07:22 +0000 | [diff] [blame] | 296 | <li><tt>Linker</tt>: tests bitcode linking.</li> | 
| Reid Spencer | 26e1f92 | 2007-02-08 17:00:55 +0000 | [diff] [blame] | 297 | <li><tt>Transforms</tt>: tests each of the scalar, IPO, and utility | 
|  | 298 | transforms to ensure they make the right transformations.</li> | 
|  | 299 | <li><tt>Verifier</tt>: tests the IR verifier.</li> | 
| Bill Wendling | 6637c57 | 2007-09-22 09:20:07 +0000 | [diff] [blame] | 300 | </ul> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 301 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 302 | </div> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 303 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 304 | <!-- _______________________________________________________________________ --> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 305 | <div class="doc_subsection"><a name="dgcustom">Writing new DejaGNU tests</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 306 | <!-- _______________________________________________________________________ --> | 
|  | 307 | <div class="doc_text"> | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 308 | <p>The DejaGNU structure is very simple, but does require some information to | 
|  | 309 | be set. This information is gathered via <tt>configure</tt> and is written | 
|  | 310 | to a file, <tt>site.exp</tt> in <tt>llvm/test</tt>. The <tt>llvm/test</tt> | 
|  | 311 | Makefile does this work for you.</p> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 312 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 313 | <p>In order for DejaGNU to work, each directory of tests must have a | 
|  | 314 | <tt>dg.exp</tt> file. DejaGNU looks for this file to determine how to run the | 
|  | 315 | tests. This file is just a Tcl script and it can do anything you want, but | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 316 | we've standardized it for the LLVM regression tests. If you're adding a | 
|  | 317 | directory of tests, just copy <tt>dg.exp</tt> from another directory to get | 
|  | 318 | running. The standard <tt>dg.exp</tt> simply loads a Tcl | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 319 | library (<tt>test/lib/llvm.exp</tt>) and calls the <tt>llvm_runtests</tt> | 
|  | 320 | function defined in that library with a list of file names to run. The names | 
|  | 321 | are obtained by using Tcl's glob command.  Any directory that contains only | 
|  | 322 | directories does not need the <tt>dg.exp</tt> file.</p> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 323 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 324 | <p>The <tt>llvm-runtests</tt> function lookas at each file that is passed to | 
|  | 325 | it and gathers any lines together that match "RUN:". This are the "RUN" lines | 
|  | 326 | that specify how the test is to be run. So, each test script must contain | 
|  | 327 | RUN lines if it is to do anything. If there are no RUN lines, the | 
|  | 328 | <tt>llvm-runtests</tt> function will issue an error and the test will | 
|  | 329 | fail.</p> | 
| Misha Brukman | 5da60ba | 2005-03-10 22:51:59 +0000 | [diff] [blame] | 330 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 331 | <p>RUN lines are specified in the comments of the test program using the | 
|  | 332 | keyword <tt>RUN</tt> followed by a colon, and lastly the command (pipeline) | 
|  | 333 | to execute.  Together, these lines form the "script" that | 
|  | 334 | <tt>llvm-runtests</tt> executes to run the test case.  The syntax of the | 
|  | 335 | RUN lines is similar to a shell's syntax for pipelines including I/O | 
|  | 336 | redirection and variable substitution.  However, even though these lines | 
|  | 337 | may <i>look</i> like a shell script, they are not. RUN lines are interpreted | 
|  | 338 | directly by the Tcl <tt>exec</tt> command. They are never executed by a | 
|  | 339 | shell. Consequently the syntax differs from normal shell script syntax in a | 
|  | 340 | few ways.  You can specify as many RUN lines as needed.</p> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 341 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 342 | <p>Each RUN line is executed on its own, distinct from other lines unless | 
|  | 343 | its last character is <tt>\</tt>. This continuation character causes the RUN | 
|  | 344 | line to be concatenated with the next one. In this way you can build up long | 
|  | 345 | pipelines of commands without making huge line lengths. The lines ending in | 
|  | 346 | <tt>\</tt> are concatenated until a RUN line that doesn't end in <tt>\</tt> is | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 347 | found. This concatenated set of RUN lines then constitutes one execution. | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 348 | Tcl will substitute variables and arrange for the pipeline to be executed. If | 
|  | 349 | any process in the pipeline fails, the entire line (and test case) fails too. | 
|  | 350 | </p> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 351 |  | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 352 | <p> Below is an example of legal RUN lines in a <tt>.ll</tt> file:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 353 |  | 
|  | 354 | <div class="doc_code"> | 
|  | 355 | <pre> | 
|  | 356 | ; RUN: llvm-as < %s | llvm-dis > %t1 | 
|  | 357 | ; RUN: llvm-dis < %s.bc-13 > %t2 | 
|  | 358 | ; RUN: diff %t1 %t2 | 
|  | 359 | </pre> | 
|  | 360 | </div> | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 361 |  | 
| Reid Spencer | 530eef6 | 2007-04-14 23:27:06 +0000 | [diff] [blame] | 362 | <p>As with a Unix shell, the RUN: lines permit pipelines and I/O redirection | 
|  | 363 | to be used. However, the usage is slightly different than for Bash. To check | 
|  | 364 | what's legal, see the documentation for the | 
|  | 365 | <a href="http://www.tcl.tk/man/tcl8.5/TclCmd/exec.htm#M2">Tcl exec</a> | 
|  | 366 | command and the | 
|  | 367 | <a href="http://www.tcl.tk/man/tcl8.5/tutorial/Tcl26.html">tutorial</a>. | 
|  | 368 | The major differences are:</p> | 
|  | 369 | <ul> | 
|  | 370 | <li>You can't do <tt>2>&1</tt>. That will cause Tcl to write to a | 
|  | 371 | file named <tt>&1</tt>. Usually this is done to get stderr to go through | 
|  | 372 | a pipe. You can do that in tcl with <tt>|&</tt> so replace this idiom: | 
|  | 373 | <tt>... 2>&1 | grep</tt> with <tt>... |& grep</tt></li> | 
|  | 374 | <li>You can only redirect to a file, not to another descriptor and not from | 
|  | 375 | a here document.</li> | 
|  | 376 | <li>tcl supports redirecting to open files with the @ syntax but you | 
|  | 377 | shouldn't use that here.</li> | 
|  | 378 | </ul> | 
|  | 379 |  | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 380 | <p>There are some quoting rules that you must pay attention to when writing | 
|  | 381 | your RUN lines. In general nothing needs to be quoted. Tcl won't strip off any | 
|  | 382 | ' or " so they will get passed to the invoked program. For example:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 383 |  | 
|  | 384 | <div class="doc_code"> | 
|  | 385 | <pre> | 
|  | 386 | ... | grep 'find this string' | 
|  | 387 | </pre> | 
|  | 388 | </div> | 
|  | 389 |  | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 390 | <p>This will fail because the ' characters are passed to grep. This would | 
|  | 391 | instruction grep to look for <tt>'find</tt> in the files <tt>this</tt> and | 
|  | 392 | <tt>string'</tt>. To avoid this use curly braces to tell Tcl that it should | 
|  | 393 | treat everything enclosed as one value. So our example would become:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 394 |  | 
|  | 395 | <div class="doc_code"> | 
|  | 396 | <pre> | 
|  | 397 | ... | grep {find this string} | 
|  | 398 | </pre> | 
|  | 399 | </div> | 
|  | 400 |  | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 401 | <p>Additionally, the characters <tt>[</tt> and <tt>]</tt> are treated | 
|  | 402 | specially by Tcl. They tell Tcl to interpret the content as a command to | 
|  | 403 | execute. Since these characters are often used in regular expressions this can | 
|  | 404 | have disastrous results and cause the entire test run in a directory to fail. | 
|  | 405 | For example, a common idiom is to look for some basicblock number:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 406 |  | 
|  | 407 | <div class="doc_code"> | 
|  | 408 | <pre> | 
|  | 409 | ... | grep bb[2-8] | 
|  | 410 | </pre> | 
|  | 411 | </div> | 
|  | 412 |  | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 413 | <p>This, however, will cause Tcl to fail because its going to try to execute | 
|  | 414 | a program named "2-8". Instead, what you want is this:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 415 |  | 
|  | 416 | <div class="doc_code"> | 
|  | 417 | <pre> | 
|  | 418 | ... | grep {bb\[2-8\]} | 
|  | 419 | </pre> | 
|  | 420 | </div> | 
|  | 421 |  | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 422 | <p>Finally, if you need to pass the <tt>\</tt> character down to a program, | 
|  | 423 | then it must be doubled. This is another Tcl special character. So, suppose | 
|  | 424 | you had: | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 425 |  | 
|  | 426 | <div class="doc_code"> | 
|  | 427 | <pre> | 
|  | 428 | ... | grep 'i32\*' | 
|  | 429 | </pre> | 
|  | 430 | </div> | 
|  | 431 |  | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 432 | <p>This will fail to match what you want (a pointer to i32). First, the | 
|  | 433 | <tt>'</tt> do not get stripped off. Second, the <tt>\</tt> gets stripped off | 
|  | 434 | by Tcl so what grep sees is: <tt>'i32*'</tt>. That's not likely to match | 
|  | 435 | anything. To resolve this you must use <tt>\\</tt> and the <tt>{}</tt>, like | 
|  | 436 | this:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 437 |  | 
|  | 438 | <div class="doc_code"> | 
|  | 439 | <pre> | 
|  | 440 | ... | grep {i32\\*} | 
|  | 441 | </pre> | 
|  | 442 | </div> | 
| Reid Spencer | e296548 | 2007-04-15 08:01:04 +0000 | [diff] [blame] | 443 |  | 
| Shantonu Sen | 89d5c41 | 2009-06-26 05:44:53 +0000 | [diff] [blame] | 444 | <p>If your system includes GNU <tt>grep</tt>, make sure | 
|  | 445 | that <tt>GREP_OPTIONS</tt> is not set in your environment. Otherwise, | 
|  | 446 | you may get invalid results (both false positives and false | 
|  | 447 | negatives).</p> | 
|  | 448 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 449 | </div> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 450 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 451 | <!-- _______________________________________________________________________ --> | 
| Chris Lattner | 7e11b72 | 2009-08-15 15:40:48 +0000 | [diff] [blame] | 452 | <div class="doc_subsection"><a name="FileCheck">The FileCheck utility</a></div> | 
|  | 453 | <!-- _______________________________________________________________________ --> | 
|  | 454 |  | 
|  | 455 | <div class="doc_text"> | 
|  | 456 |  | 
|  | 457 | <p>A powerful feature of the RUN: lines is that it allows any arbitrary commands | 
|  | 458 | to be executed as part of the test harness.  While standard (portable) unix | 
|  | 459 | tools like 'grep' work fine on run lines, as you see above, there are a lot | 
| Chris Lattner | 3ee64e8 | 2009-08-15 16:51:06 +0000 | [diff] [blame] | 460 | of caveats due to interaction with Tcl syntax, and we want to make sure the | 
| Chris Lattner | 7e11b72 | 2009-08-15 15:40:48 +0000 | [diff] [blame] | 461 | run lines are portable to a wide range of systems.  Another major problem is | 
|  | 462 | that grep is not very good at checking to verify that the output of a tools | 
|  | 463 | contains a series of different output in a specific order.  The FileCheck | 
|  | 464 | tool was designed to help with these problems.</p> | 
|  | 465 |  | 
| Chris Lattner | 3ee64e8 | 2009-08-15 16:51:06 +0000 | [diff] [blame] | 466 | <p>FileCheck (whose basic command line arguments are described in <a | 
|  | 467 | href="http://llvm.org/cmds/FileCheck.html">the FileCheck man page</a> is | 
|  | 468 | designed to read a file to check from standard input, and the set of things | 
|  | 469 | to verify from a file specified as a command line argument.  A simple example | 
|  | 470 | of using FileCheck from a RUN line looks like this:</p> | 
|  | 471 |  | 
|  | 472 | <div class="doc_code"> | 
|  | 473 | <pre> | 
|  | 474 | ; RUN: llvm-as < %s | llc -march=x86-64 | <b>FileCheck %s</b> | 
|  | 475 | </pre> | 
|  | 476 | </div> | 
| Chris Lattner | 7e11b72 | 2009-08-15 15:40:48 +0000 | [diff] [blame] | 477 |  | 
| Chris Lattner | 3ee64e8 | 2009-08-15 16:51:06 +0000 | [diff] [blame] | 478 | <p>This syntax says to pipe the current file ("%s") into llvm-as, pipe that into | 
|  | 479 | llc, then pipe the output of llc into FileCheck.  This means that FileCheck will | 
|  | 480 | be verifying its standard input (the llc output) against the filename argument | 
|  | 481 | specified (the original .ll file specified by "%s").  To see how this works, | 
|  | 482 | lets look at the rest of the .ll file (after the RUN line):</p> | 
|  | 483 |  | 
|  | 484 | <div class="doc_code"> | 
|  | 485 | <pre> | 
|  | 486 | define void @sub1(i32* %p, i32 %v) { | 
|  | 487 | entry: | 
|  | 488 | ; <b>CHECK: sub1:</b> | 
|  | 489 | ; <b>CHECK: subl</b> | 
|  | 490 | %0 = tail call i32 @llvm.atomic.load.sub.i32.p0i32(i32* %p, i32 %v) | 
|  | 491 | ret void | 
|  | 492 | } | 
|  | 493 |  | 
|  | 494 | define void @inc4(i64* %p) { | 
|  | 495 | entry: | 
|  | 496 | ; <b>CHECK: inc4:</b> | 
|  | 497 | ; <b>CHECK: incq</b> | 
|  | 498 | %0 = tail call i64 @llvm.atomic.load.add.i64.p0i64(i64* %p, i64 1) | 
|  | 499 | ret void | 
|  | 500 | } | 
|  | 501 | </pre> | 
|  | 502 | </div> | 
|  | 503 |  | 
|  | 504 | <p>Here you can see some "CHECK:" lines specified in comments.  Now you can see | 
|  | 505 | how the file is piped into llvm-as, then llc, and the machine code output is | 
|  | 506 | what we are verifying.  FileCheck checks the machine code output to verify that | 
|  | 507 | it matches what the "CHECK:" lines specify.</p> | 
|  | 508 |  | 
|  | 509 | <p>The syntax of the CHECK: lines is very simple: they are fixed strings that | 
|  | 510 | must occur in order.  FileCheck defaults to ignoring horizontal whitespace | 
|  | 511 | differences (e.g. a space is allowed to match a tab) but otherwise, the contents | 
|  | 512 | of the CHECK: line is required to match some thing in the test file exactly.</p> | 
|  | 513 |  | 
|  | 514 | <p>One nice thing about FileCheck (compared to grep) is that it allows merging | 
|  | 515 | test cases together into logical groups.  For example, because the test above | 
|  | 516 | is checking for the "sub1:" and "inc4:" labels, it will not match unless there | 
|  | 517 | is a "subl" in between those labels.  If it existed somewhere else in the file, | 
|  | 518 | that would not count: "grep subl" matches if subl exists anywhere in the | 
|  | 519 | file.</p> | 
|  | 520 |  | 
| Chris Lattner | da108b4 | 2009-08-15 18:32:21 +0000 | [diff] [blame] | 521 | </div> | 
|  | 522 |  | 
|  | 523 | <!-- _______________________________________________________________________ --> | 
| Chris Lattner | 3ee64e8 | 2009-08-15 16:51:06 +0000 | [diff] [blame] | 524 | <div class="doc_subsubsection"><a | 
|  | 525 | name="FileCheck-check-prefix">The FileCheck -check-prefix option</a></div> | 
|  | 526 |  | 
| Chris Lattner | da108b4 | 2009-08-15 18:32:21 +0000 | [diff] [blame] | 527 | <div class="doc_text"> | 
|  | 528 |  | 
| Chris Lattner | 3ee64e8 | 2009-08-15 16:51:06 +0000 | [diff] [blame] | 529 | <p>The FileCheck -check-prefix option allows multiple test configurations to be | 
|  | 530 | driven from one .ll file.  This is useful in many circumstances, for example, | 
|  | 531 | testing different architectural variants with llc.  Here's a simple example:</p> | 
|  | 532 |  | 
| Chris Lattner | 3ee64e8 | 2009-08-15 16:51:06 +0000 | [diff] [blame] | 533 | <div class="doc_code"> | 
|  | 534 | <pre> | 
|  | 535 | ; RUN: llvm-as < %s | llc -mtriple=i686-apple-darwin9 -mattr=sse41 \ | 
|  | 536 | ; RUN:              | <b>FileCheck %s -check-prefix=X32</b> | 
|  | 537 | ; RUN: llvm-as < %s | llc -mtriple=x86_64-apple-darwin9 -mattr=sse41 \ | 
|  | 538 | ; RUN:              | <b>FileCheck %s -check-prefix=X64</b> | 
|  | 539 |  | 
|  | 540 | define <4 x i32> @pinsrd_1(i32 %s, <4 x i32> %tmp) nounwind { | 
|  | 541 | %tmp1 = insertelement <4 x i32> %tmp, i32 %s, i32 1 | 
|  | 542 | ret <4 x i32> %tmp1 | 
|  | 543 | ; <b>X32:</b> pinsrd_1: | 
|  | 544 | ; <b>X32:</b>    pinsrd $1, 4(%esp), %xmm0 | 
|  | 545 |  | 
|  | 546 | ; <b>X64:</b> pinsrd_1: | 
|  | 547 | ; <b>X64:</b>    pinsrd $1, %edi, %xmm0 | 
|  | 548 | } | 
|  | 549 | </pre> | 
|  | 550 | </div> | 
|  | 551 |  | 
|  | 552 | <p>In this case, we're testing that we get the expected code generation with | 
|  | 553 | both 32-bit and 64-bit code generation.</p> | 
|  | 554 |  | 
| Chris Lattner | da108b4 | 2009-08-15 18:32:21 +0000 | [diff] [blame] | 555 | </div> | 
|  | 556 |  | 
|  | 557 | <!-- _______________________________________________________________________ --> | 
|  | 558 | <div class="doc_subsubsection"><a | 
|  | 559 | name="FileCheck-CHECK-NEXT">The "CHECK-NEXT:" directive</a></div> | 
|  | 560 |  | 
|  | 561 | <div class="doc_text"> | 
|  | 562 |  | 
|  | 563 | <p>Sometimes you want to match lines and would like to verify that matches | 
|  | 564 | happen on exactly consequtive lines with no other lines in between them.  In | 
|  | 565 | this case, you can use CHECK: and CHECK-NEXT: directives to specify this.  If | 
|  | 566 | you specified a custom check prefix, just use "<PREFIX>-NEXT:".  For | 
|  | 567 | example, something like this works as you'd expect:</p> | 
|  | 568 |  | 
|  | 569 | <div class="doc_code"> | 
|  | 570 | <pre> | 
| Chris Lattner | 724af2c | 2009-08-15 18:33:10 +0000 | [diff] [blame] | 571 | define void @t2(<2 x double>* %r, <2 x double>* %A, double %B) { | 
| Chris Lattner | da108b4 | 2009-08-15 18:32:21 +0000 | [diff] [blame] | 572 | %tmp3 = load <2 x double>* %A, align 16 | 
|  | 573 | %tmp7 = insertelement <2 x double> undef, double %B, i32 0 | 
| Chris Lattner | 724af2c | 2009-08-15 18:33:10 +0000 | [diff] [blame] | 574 | %tmp9 = shufflevector <2 x double> %tmp3, | 
|  | 575 | <2 x double> %tmp7, | 
|  | 576 | <2 x i32> < i32 0, i32 2 > | 
| Chris Lattner | da108b4 | 2009-08-15 18:32:21 +0000 | [diff] [blame] | 577 | store <2 x double> %tmp9, <2 x double>* %r, align 16 | 
|  | 578 | ret void | 
|  | 579 |  | 
|  | 580 | ; <b>CHECK:</b> t2: | 
|  | 581 | ; <b>CHECK:</b> 	movl	8(%esp), %eax | 
|  | 582 | ; <b>CHECK-NEXT:</b> 	movapd	(%eax), %xmm0 | 
|  | 583 | ; <b>CHECK-NEXT:</b> 	movhpd	12(%esp), %xmm0 | 
|  | 584 | ; <b>CHECK-NEXT:</b> 	movl	4(%esp), %eax | 
|  | 585 | ; <b>CHECK-NEXT:</b> 	movapd	%xmm0, (%eax) | 
|  | 586 | ; <b>CHECK-NEXT:</b> 	ret | 
|  | 587 | } | 
|  | 588 | </pre> | 
|  | 589 | </div> | 
|  | 590 |  | 
|  | 591 | <p>CHECK-NEXT: directives reject the input unless there is exactly one newline | 
|  | 592 | between it an the previous directive.  A CHECK-NEXT cannot be the first | 
|  | 593 | directive in a file.</p> | 
| Chris Lattner | 7e11b72 | 2009-08-15 15:40:48 +0000 | [diff] [blame] | 594 |  | 
|  | 595 | </div> | 
|  | 596 |  | 
|  | 597 | <!-- _______________________________________________________________________ --> | 
| Chris Lattner | 236d2d5 | 2009-09-20 22:35:26 +0000 | [diff] [blame] | 598 | <div class="doc_subsubsection"><a | 
|  | 599 | name="FileCheck-CHECK-NOT">The "CHECK-NOT:" directive</a></div> | 
|  | 600 |  | 
|  | 601 | <div class="doc_text"> | 
|  | 602 |  | 
|  | 603 | <p>The CHECK-NOT: directive is used to verify that a string doesn't occur | 
| Chris Lattner | 05593db | 2009-09-20 22:45:18 +0000 | [diff] [blame] | 604 | between two matches (or the first match and the beginning of the file).  For | 
| Chris Lattner | 236d2d5 | 2009-09-20 22:35:26 +0000 | [diff] [blame] | 605 | example, to verify that a load is removed by a transformation, a test like this | 
|  | 606 | can be used:</p> | 
|  | 607 |  | 
|  | 608 | <div class="doc_code"> | 
|  | 609 | <pre> | 
|  | 610 | define i8 @coerce_offset0(i32 %V, i32* %P) { | 
|  | 611 | store i32 %V, i32* %P | 
|  | 612 |  | 
|  | 613 | %P2 = bitcast i32* %P to i8* | 
|  | 614 | %P3 = getelementptr i8* %P2, i32 2 | 
|  | 615 |  | 
|  | 616 | %A = load i8* %P3 | 
|  | 617 | ret i8 %A | 
|  | 618 | ; <b>CHECK:</b> @coerce_offset0 | 
|  | 619 | ; <b>CHECK-NOT:</b> load | 
|  | 620 | ; <b>CHECK:</b> ret i8 | 
|  | 621 | } | 
|  | 622 | </pre> | 
|  | 623 | </div> | 
|  | 624 |  | 
|  | 625 | </div> | 
|  | 626 |  | 
|  | 627 | <!-- _______________________________________________________________________ --> | 
| Chris Lattner | f08d2db | 2009-09-24 21:47:32 +0000 | [diff] [blame] | 628 | <div class="doc_subsubsection"><a | 
| Chris Lattner | 8879e06 | 2009-09-27 07:56:52 +0000 | [diff] [blame] | 629 | name="FileCheck-Matching">FileCheck Pattern Matching Syntax</a></div> | 
| Chris Lattner | f08d2db | 2009-09-24 21:47:32 +0000 | [diff] [blame] | 630 |  | 
|  | 631 | <div class="doc_text"> | 
|  | 632 |  | 
|  | 633 | <p>The CHECK: and CHECK-NOT: directives both take a pattern to match.  For most | 
|  | 634 | uses of FileCheck, fixed string matching is perfectly sufficient.  For some | 
|  | 635 | things, a more flexible form of matching is desired.  To support this, FileCheck | 
|  | 636 | allows you to specify regular expressions in matching strings, surrounded by | 
|  | 637 | double braces: <b>{{yourregex}}</b>.  Because we want to use fixed string | 
|  | 638 | matching for a majority of what we do, FileCheck has been designed to support | 
|  | 639 | mixing and matching fixed string matching with regular expressions.  This allows | 
|  | 640 | you to write things like this:</p> | 
|  | 641 |  | 
|  | 642 | <div class="doc_code"> | 
|  | 643 | <pre> | 
|  | 644 | ; CHECK: movhpd	<b>{{[0-9]+}}</b>(%esp), <b>{{%xmm[0-7]}}</b> | 
|  | 645 | </pre> | 
|  | 646 | </div> | 
|  | 647 |  | 
|  | 648 | <p>In this case, any offset from the ESP register will be allowed, and any xmm | 
|  | 649 | register will be allowed.</p> | 
|  | 650 |  | 
|  | 651 | <p>Because regular expressions are enclosed with double braces, they are | 
|  | 652 | visually distinct, and you don't need to use escape characters within the double | 
|  | 653 | braces like you would in C.  In the rare case that you want to match double | 
|  | 654 | braces explicitly from the input, you can use something ugly like | 
|  | 655 | <b>{{[{][{]}}</b> as your pattern.</p> | 
|  | 656 |  | 
|  | 657 | </div> | 
|  | 658 |  | 
| Chris Lattner | 8879e06 | 2009-09-27 07:56:52 +0000 | [diff] [blame] | 659 | <!-- _______________________________________________________________________ --> | 
|  | 660 | <div class="doc_subsubsection"><a | 
|  | 661 | name="FileCheck-Variables">FileCheck Variables</a></div> | 
| Chris Lattner | f08d2db | 2009-09-24 21:47:32 +0000 | [diff] [blame] | 662 |  | 
| Chris Lattner | 8879e06 | 2009-09-27 07:56:52 +0000 | [diff] [blame] | 663 | <div class="doc_text"> | 
|  | 664 |  | 
|  | 665 | <p>It is often useful to match a pattern and then verify that it occurs again | 
|  | 666 | later in the file.  For codegen tests, this can be useful to allow any register, | 
|  | 667 | but verify that that register is used consistently later.  To do this, FileCheck | 
|  | 668 | allows named variables to be defined and substituted into patterns.  Here is a | 
|  | 669 | simple example:</p> | 
|  | 670 |  | 
|  | 671 | <div class="doc_code"> | 
|  | 672 | <pre> | 
|  | 673 | ; CHECK: test5: | 
| Chris Lattner | 5e0c747 | 2009-09-27 08:01:44 +0000 | [diff] [blame^] | 674 | ; CHECK:    notw	<b>[[REGISTER:%[a-z]+]]</b> | 
|  | 675 | ; CHECK:    andw	{{.*}}<b>[[REGISTER]]</b> | 
| Chris Lattner | 8879e06 | 2009-09-27 07:56:52 +0000 | [diff] [blame] | 676 | </pre> | 
|  | 677 | </div> | 
|  | 678 |  | 
| Chris Lattner | 5e0c747 | 2009-09-27 08:01:44 +0000 | [diff] [blame^] | 679 | <p>The first check line matches a regex (<tt>%[a-z]+</tt>) and captures it into | 
|  | 680 | the variables "REGISTER".  The second line verifies that whatever is in REGISTER | 
|  | 681 | occurs later in the file after an "andw".  FileCheck variable references are | 
|  | 682 | always contained in <tt>[[ ]]</tt> pairs, are named, and their names can be | 
|  | 683 | formed with the regex "<tt>[a-zA-Z][a-zA-Z0-9]*</tt>".  If a colon follows the | 
|  | 684 | name, then it is a definition of the variable, if not, it is a use.</p> | 
| Chris Lattner | 8879e06 | 2009-09-27 07:56:52 +0000 | [diff] [blame] | 685 |  | 
|  | 686 | <p>FileCheck variables can be defined multiple times, and uses always get the | 
|  | 687 | latest value.  Note that variables are all read at the start of a "CHECK" line | 
|  | 688 | and are all defined at the end.  This means that if you have something like | 
|  | 689 | "<tt>CHECK: [[XYZ:.*]]x[[XYZ]]</tt>" that the check line will read the previous | 
|  | 690 | value of the XYZ variable and define a new one after the match is performed.  If | 
|  | 691 | you need to do something like this you can probably take advantage of the fact | 
|  | 692 | that FileCheck is not actually line-oriented when it matches, this allows you to | 
|  | 693 | define two separate CHECK lines that match on the same line. | 
|  | 694 | </p> | 
|  | 695 |  | 
|  | 696 |  | 
|  | 697 |  | 
|  | 698 | </div> | 
| Chris Lattner | f08d2db | 2009-09-24 21:47:32 +0000 | [diff] [blame] | 699 |  | 
|  | 700 | <!-- _______________________________________________________________________ --> | 
| Chris Lattner | 3ee64e8 | 2009-08-15 16:51:06 +0000 | [diff] [blame] | 701 | <div class="doc_subsection"><a name="dgvars">Variables and | 
|  | 702 | substitutions</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 703 | <!-- _______________________________________________________________________ --> | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 704 | <div class="doc_text"> | 
|  | 705 | <p>With a RUN line there are a number of substitutions that are permitted. In | 
|  | 706 | general, any Tcl variable that is available in the <tt>substitute</tt> | 
|  | 707 | function (in <tt>test/lib/llvm.exp</tt>) can be substituted into a RUN line. | 
|  | 708 | To make a substitution just write the variable's name preceded by a $. | 
|  | 709 | Additionally, for compatibility reasons with previous versions of the test | 
|  | 710 | library, certain names can be accessed with an alternate syntax: a % prefix. | 
|  | 711 | These alternates are deprecated and may go away in a future version. | 
|  | 712 | </p> | 
| Bill Wendling | 6637c57 | 2007-09-22 09:20:07 +0000 | [diff] [blame] | 713 | <p>Here are the available variable names. The alternate syntax is listed in | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 714 | parentheses.</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 715 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 716 | <dl style="margin-left: 25px"> | 
|  | 717 | <dt><b>$test</b> (%s)</dt> | 
|  | 718 | <dd>The full path to the test case's source. This is suitable for passing | 
|  | 719 | on the command line as the input to an llvm tool.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 720 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 721 | <dt><b>$srcdir</b></dt> | 
|  | 722 | <dd>The source directory from where the "<tt>make check</tt>" was run.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 723 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 724 | <dt><b>objdir</b></dt> | 
| Bill Wendling | 6637c57 | 2007-09-22 09:20:07 +0000 | [diff] [blame] | 725 | <dd>The object directory that corresponds to the <tt>$srcdir</tt>.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 726 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 727 | <dt><b>subdir</b></dt> | 
|  | 728 | <dd>A partial path from the <tt>test</tt> directory that contains the | 
|  | 729 | sub-directory that contains the test source being executed.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 730 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 731 | <dt><b>srcroot</b></dt> | 
|  | 732 | <dd>The root directory of the LLVM src tree.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 733 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 734 | <dt><b>objroot</b></dt> | 
|  | 735 | <dd>The root directory of the LLVM object tree. This could be the same | 
|  | 736 | as the srcroot.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 737 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 738 | <dt><b>path</b><dt> | 
|  | 739 | <dd>The path to the directory that contains the test case source.  This is | 
|  | 740 | for locating any supporting files that are not generated by the test, but | 
|  | 741 | used by the test.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 742 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 743 | <dt><b>tmp</b></dt> | 
|  | 744 | <dd>The path to a temporary file name that could be used for this test case. | 
|  | 745 | The file name won't conflict with other test cases. You can append to it if | 
|  | 746 | you need multiple temporaries. This is useful as the destination of some | 
|  | 747 | redirected output.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 748 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 749 | <dt><b>llvmlibsdir</b> (%llvmlibsdir)</dt> | 
|  | 750 | <dd>The directory where the LLVM libraries are located.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 751 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 752 | <dt><b>target_triplet</b> (%target_triplet)</dt> | 
|  | 753 | <dd>The target triplet that corresponds to the current host machine (the one | 
|  | 754 | running the test cases). This should probably be called "host".<dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 755 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 756 | <dt><b>llvmgcc</b> (%llvmgcc)</dt> | 
|  | 757 | <dd>The full path to the <tt>llvm-gcc</tt> executable as specified in the | 
|  | 758 | configured LLVM environment</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 759 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 760 | <dt><b>llvmgxx</b> (%llvmgxx)</dt> | 
|  | 761 | <dd>The full path to the <tt>llvm-gxx</tt> executable as specified in the | 
|  | 762 | configured LLVM environment</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 763 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 764 | <dt><b>llvmgcc_version</b> (%llvmgcc_version)</dt> | 
|  | 765 | <dd>The full version number of the <tt>llvm-gcc</tt> executable.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 766 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 767 | <dt><b>llvmgccmajvers</b> (%llvmgccmajvers)</dt> | 
|  | 768 | <dd>The major version number of the <tt>llvm-gcc</tt> executable.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 769 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 770 | <dt><b>gccpath</b></dt> | 
|  | 771 | <dd>The full path to the C compiler used to <i>build </i> LLVM. Note that | 
|  | 772 | this might not be gcc.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 773 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 774 | <dt><b>gxxpath</b></dt> | 
|  | 775 | <dd>The full path to the C++ compiler used to <i>build </i> LLVM. Note that | 
|  | 776 | this might not be g++.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 777 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 778 | <dt><b>compile_c</b> (%compile_c)</dt> | 
|  | 779 | <dd>The full command line used to compile LLVM C source  code. This has all | 
|  | 780 | the configured -I, -D and optimization options.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 781 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 782 | <dt><b>compile_cxx</b> (%compile_cxx)</dt> | 
|  | 783 | <dd>The full command used to compile LLVM C++ source  code. This has | 
|  | 784 | all the configured -I, -D and optimization options.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 785 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 786 | <dt><b>link</b> (%link)</dt> | 
|  | 787 | <dd>This full link command used to link LLVM executables. This has all the | 
|  | 788 | configured -I, -L and -l options.</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 789 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 790 | <dt><b>shlibext</b> (%shlibext)</dt> | 
|  | 791 | <dd>The suffix for the host platforms share library (dll) files. This | 
|  | 792 | includes the period as the first character.</dd> | 
|  | 793 | </dl> | 
|  | 794 | <p>To add more variables, two things need to be changed. First, add a line in | 
|  | 795 | the <tt>test/Makefile</tt> that creates the <tt>site.exp</tt> file. This will | 
|  | 796 | "set" the variable as a global in the site.exp file. Second, in the | 
|  | 797 | <tt>test/lib/llvm.exp</tt> file, in the substitute proc, add the variable name | 
|  | 798 | to the list of "global" declarations at the beginning of the proc. That's it, | 
|  | 799 | the variable can then be used in test scripts.</p> | 
|  | 800 | </div> | 
|  | 801 |  | 
|  | 802 | <!-- _______________________________________________________________________ --> | 
|  | 803 | <div class="doc_subsection"><a name="dgfeatures">Other Features</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 804 | <!-- _______________________________________________________________________ --> | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 805 | <div class="doc_text"> | 
|  | 806 | <p>To make RUN line writing easier, there are several shell scripts located | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 807 | in the <tt>llvm/test/Scripts</tt> directory. This directory is in the PATH | 
|  | 808 | when running tests, so you can just call these scripts using their name. For | 
|  | 809 | example:</p> | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 810 | <dl> | 
|  | 811 | <dt><b>ignore</b></dt> | 
|  | 812 | <dd>This script runs its arguments and then always returns 0. This is useful | 
|  | 813 | in cases where the test needs to cause a tool to generate an error (e.g. to | 
|  | 814 | check the error output). However, any program in a pipeline that returns a | 
|  | 815 | non-zero result will cause the test to fail. This script overcomes that | 
|  | 816 | issue and nicely documents that the test case is purposefully ignoring the | 
|  | 817 | result code of the tool</dd> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 818 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 819 | <dt><b>not</b></dt> | 
|  | 820 | <dd>This script runs its arguments and then inverts the result code from | 
|  | 821 | it. Zero result codes become 1. Non-zero result codes become 0. This is | 
|  | 822 | useful to invert the result of a grep. For example "not grep X" means | 
|  | 823 | succeed only if you don't find X in the input.</dd> | 
|  | 824 | </dl> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 825 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 826 | <p>Sometimes it is necessary to mark a test case as "expected fail" or XFAIL. | 
|  | 827 | You can easily mark a test as XFAIL just by including  <tt>XFAIL: </tt> on a | 
|  | 828 | line near the top of the file. This signals that the test case should succeed | 
|  | 829 | if the test fails. Such test cases are counted separately by DejaGnu. To | 
|  | 830 | specify an expected fail, use the XFAIL keyword in the comments of the test | 
|  | 831 | program followed by a colon and one or more regular expressions (separated by | 
|  | 832 | a comma). The regular expressions allow you to XFAIL the test conditionally | 
|  | 833 | by host platform. The regular expressions following the : are matched against | 
|  | 834 | the target triplet or llvmgcc version number for the host machine. If there is | 
|  | 835 | a match, the test is expected to fail. If not, the test is expected to | 
|  | 836 | succeed. To XFAIL everywhere just specify <tt>XFAIL: *</tt>. When matching | 
|  | 837 | the llvm-gcc version, you can specify the major (e.g. 3) or full version | 
|  | 838 | (i.e. 3.4) number. Here is an example of an <tt>XFAIL</tt> line:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 839 |  | 
|  | 840 | <div class="doc_code"> | 
|  | 841 | <pre> | 
|  | 842 | ; XFAIL: darwin,sun,llvmgcc4 | 
|  | 843 | </pre> | 
|  | 844 | </div> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 845 |  | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 846 | <p>To make the output more useful, the <tt>llvm_runtest</tt> function wil | 
|  | 847 | scan the lines of the test case for ones that contain a pattern that matches | 
|  | 848 | PR[0-9]+. This is the syntax for specifying a PR (Problem Report) number that | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 849 | is related to the test case. The number after "PR" specifies the LLVM bugzilla | 
| Reid Spencer | 9dcf4c2 | 2007-04-14 21:46:15 +0000 | [diff] [blame] | 850 | number. When a PR number is specified, it will be used in the pass/fail | 
|  | 851 | reporting. This is useful to quickly get some context when a test fails.</p> | 
|  | 852 |  | 
|  | 853 | <p>Finally, any line that contains "END." will cause the special | 
|  | 854 | interpretation of lines to terminate. This is generally done right after the | 
|  | 855 | last RUN: line. This has two side effects: (a) it prevents special | 
|  | 856 | interpretation of lines that are part of the test program, not the | 
|  | 857 | instructions to the test case, and (b) it speeds things up for really big test | 
|  | 858 | cases by avoiding interpretation of the remainder of the file.</p> | 
| Tanya Lattner | 4d69018 | 2004-12-06 02:11:52 +0000 | [diff] [blame] | 859 |  | 
|  | 860 | </div> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 861 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 862 | <!--=========================================================================--> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 863 | <div class="doc_section"><a name="testsuitestructure">Test suite | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 864 | Structure</a></div> | 
|  | 865 | <!--=========================================================================--> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 866 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 867 | <div class="doc_text"> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 868 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 869 | <p>The <tt>test-suite</tt> module contains a number of programs that can be compiled | 
|  | 870 | with LLVM and executed. These programs are compiled using the native compiler | 
|  | 871 | and various LLVM backends. The output from the program compiled with the | 
|  | 872 | native compiler is assumed correct; the results from the other programs are | 
|  | 873 | compared to the native program output and pass if they match.</p> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 874 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 875 | <p>When executing tests, it is usually a good idea to start out with a subset of | 
|  | 876 | the available tests or programs. This makes test run times smaller at first and | 
|  | 877 | later on this is useful to investigate individual test failures. To run some | 
|  | 878 | test only on a subset of programs, simply change directory to the programs you | 
|  | 879 | want tested and run <tt>gmake</tt> there. Alternatively, you can run a different | 
|  | 880 | test using the <tt>TEST</tt> variable to change what tests or run on the | 
|  | 881 | selected programs (see below for more info).</p> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 882 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 883 | <p>In addition for testing correctness, the <tt>llvm-test</tt> directory also | 
|  | 884 | performs timing tests of various LLVM optimizations.  It also records | 
|  | 885 | compilation times for the compilers and the JIT.  This information can be | 
|  | 886 | used to compare the effectiveness of LLVM's optimizations and code | 
|  | 887 | generation.</p> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 888 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 889 | <p><tt>llvm-test</tt> tests are divided into three types of tests: MultiSource, | 
|  | 890 | SingleSource, and External.</p> | 
| Reid Spencer | cce6755 | 2004-12-08 16:52:51 +0000 | [diff] [blame] | 891 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 892 | <ul> | 
|  | 893 | <li><tt>llvm-test/SingleSource</tt> | 
|  | 894 | <p>The SingleSource directory contains test programs that are only a single | 
|  | 895 | source file in size.  These are usually small benchmark programs or small | 
|  | 896 | programs that calculate a particular value.  Several such programs are grouped | 
|  | 897 | together in each directory.</p></li> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 898 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 899 | <li><tt>llvm-test/MultiSource</tt> | 
|  | 900 | <p>The MultiSource directory contains subdirectories which contain entire | 
|  | 901 | programs with multiple source files.  Large benchmarks and whole applications | 
|  | 902 | go here.</p></li> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 903 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 904 | <li><tt>llvm-test/External</tt> | 
|  | 905 | <p>The External directory contains Makefiles for building code that is external | 
|  | 906 | to (i.e., not distributed with) LLVM.  The most prominent members of this | 
|  | 907 | directory are the SPEC 95 and SPEC 2000 benchmark suites. The <tt>External</tt> | 
| Stuart Hastings | 6d43769 | 2009-05-21 20:23:59 +0000 | [diff] [blame] | 908 | directory does not contain these actual tests, but only the Makefiles that know | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 909 | how to properly compile these programs from somewhere else. The presence and | 
|  | 910 | location of these external programs is configured by the llvm-test | 
|  | 911 | <tt>configure</tt> script.</p></li> | 
|  | 912 | </ul> | 
|  | 913 |  | 
|  | 914 | <p>Each tree is then subdivided into several categories, including applications, | 
|  | 915 | benchmarks, regression tests, code that is strange grammatically, etc.  These | 
|  | 916 | organizations should be relatively self explanatory.</p> | 
|  | 917 |  | 
|  | 918 | <p>Some tests are known to fail.  Some are bugs that we have not fixed yet; | 
|  | 919 | others are features that we haven't added yet (or may never add).  In DejaGNU, | 
|  | 920 | the result for such tests will be XFAIL (eXpected FAILure).  In this way, you | 
|  | 921 | can tell the difference between an expected and unexpected failure.</p> | 
|  | 922 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 923 | <p>The tests in the test suite have no such feature at this time. If the | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 924 | test passes, only warnings and other miscellaneous output will be generated.  If | 
|  | 925 | a test fails, a large <program> FAILED message will be displayed.  This | 
|  | 926 | will help you separate benign warnings from actual test failures.</p> | 
|  | 927 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 928 | </div> | 
|  | 929 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 930 | <!--=========================================================================--> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 931 | <div class="doc_section"><a name="testsuiterun">Running the test suite</a></div> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 932 | <!--=========================================================================--> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 933 |  | 
|  | 934 | <div class="doc_text"> | 
|  | 935 |  | 
|  | 936 | <p>First, all tests are executed within the LLVM object directory tree.  They | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 937 | <i>are not</i> executed inside of the LLVM source tree. This is because the | 
| John Mosby | 169927e | 2009-03-30 18:56:53 +0000 | [diff] [blame] | 938 | test suite creates temporary files during execution.</p> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 939 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 940 | <p>To run the test suite, you need to use the following steps:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 941 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 942 | <ol> | 
| John Mosby | b92a76f | 2009-03-30 04:37:51 +0000 | [diff] [blame] | 943 | <li><tt>cd</tt> into the <tt>llvm/projects</tt> directory in your source tree. | 
|  | 944 | </li> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 945 |  | 
|  | 946 | <li><p>Check out the <tt>test-suite</tt> module with:</p> | 
|  | 947 |  | 
|  | 948 | <div class="doc_code"> | 
|  | 949 | <pre> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 950 | % svn co http://llvm.org/svn/llvm-project/test-suite/trunk test-suite | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 951 | </pre> | 
|  | 952 | </div> | 
| Stuart Hastings | 6d43769 | 2009-05-21 20:23:59 +0000 | [diff] [blame] | 953 | <p>This will get the test suite into <tt>llvm/projects/test-suite</tt>.</p> | 
| John Mosby | b92a76f | 2009-03-30 04:37:51 +0000 | [diff] [blame] | 954 | </li> | 
| Stuart Hastings | 6d43769 | 2009-05-21 20:23:59 +0000 | [diff] [blame] | 955 | <li><p>Configure and build <tt>llvm</tt>.</p></li> | 
|  | 956 | <li><p>Configure and build <tt>llvm-gcc</tt>.</p></li> | 
|  | 957 | <li><p>Install <tt>llvm-gcc</tt> somewhere.</p></li> | 
|  | 958 | <li><p><em>Re-configure</em> <tt>llvm</tt> from the top level of | 
|  | 959 | each build tree (LLVM object directory tree) in which you want | 
|  | 960 | to run the test suite, just as you do before building LLVM.</p> | 
|  | 961 | <p>During the <em>re-configuration</em>, you must either: (1) | 
|  | 962 | have <tt>llvm-gcc</tt> you just built in your path, or (2) | 
|  | 963 | specify the directory where your just-built <tt>llvm-gcc</tt> is | 
|  | 964 | installed using <tt>--with-llvmgccdir=$LLVM_GCC_DIR</tt>.</p> | 
|  | 965 | <p>You must also tell the configure machinery that the test suite | 
|  | 966 | is available so it can be configured for your build tree:</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 967 | <div class="doc_code"> | 
|  | 968 | <pre> | 
| John Mosby | b92a76f | 2009-03-30 04:37:51 +0000 | [diff] [blame] | 969 | % cd $LLVM_OBJ_ROOT ; $LLVM_SRC_ROOT/configure [--with-llvmgccdir=$LLVM_GCC_DIR] | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 970 | </pre> | 
|  | 971 | </div> | 
| John Mosby | b92a76f | 2009-03-30 04:37:51 +0000 | [diff] [blame] | 972 | <p>[Remember that <tt>$LLVM_GCC_DIR</tt> is the directory where you | 
|  | 973 | <em>installed</em> llvm-gcc, not its src or obj directory.]</p> | 
| Matthijs Kooijman | 3f95ba0 | 2008-05-20 10:28:55 +0000 | [diff] [blame] | 974 | </li> | 
|  | 975 |  | 
| John Mosby | b92a76f | 2009-03-30 04:37:51 +0000 | [diff] [blame] | 976 | <li><p>You can now run the test suite from your build tree as follows:</p> | 
|  | 977 | <div class="doc_code"> | 
|  | 978 | <pre> | 
|  | 979 | % cd $LLVM_OBJ_ROOT/projects/test-suite | 
|  | 980 | % make | 
|  | 981 | </pre> | 
|  | 982 | </div> | 
|  | 983 | </li> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 984 | </ol> | 
|  | 985 | <p>Note that the second and third steps only need to be done once. After you | 
|  | 986 | have the suite checked out and configured, you don't need to do it again (unless | 
| Matthijs Kooijman | 3f95ba0 | 2008-05-20 10:28:55 +0000 | [diff] [blame] | 987 | the test code or configure script changes).</p> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 988 |  | 
| Shantonu Sen | 89d5c41 | 2009-06-26 05:44:53 +0000 | [diff] [blame] | 989 | </div> | 
|  | 990 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 991 | <!-- _______________________________________________________________________ --> | 
|  | 992 | <div class="doc_subsection"> | 
| Stuart Hastings | 6d43769 | 2009-05-21 20:23:59 +0000 | [diff] [blame] | 993 | <a name="testsuiteexternal">Configuring External Tests</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 994 | <!-- _______________________________________________________________________ --> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 995 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 996 | <div class="doc_text"> | 
| Stuart Hastings | 6d43769 | 2009-05-21 20:23:59 +0000 | [diff] [blame] | 997 | <p>In order to run the External tests in the <tt>test-suite</tt> | 
|  | 998 | module, you must specify <i>--with-externals</i>.  This | 
|  | 999 | must be done during the <em>re-configuration</em> step (see above), | 
|  | 1000 | and the <tt>llvm</tt> re-configuration must recognize the | 
|  | 1001 | previously-built <tt>llvm-gcc</tt>.  If any of these is missing or | 
|  | 1002 | neglected, the External tests won't work.</p> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1003 | <dl> | 
| Dale Johannesen | 40e3b20 | 2008-12-10 01:58:32 +0000 | [diff] [blame] | 1004 | <dt><i>--with-externals</i></dt> | 
|  | 1005 | <dt><i>--with-externals=<<tt>directory</tt>></i></dt> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1006 | </dl> | 
| Dale Johannesen | 40e3b20 | 2008-12-10 01:58:32 +0000 | [diff] [blame] | 1007 | This tells LLVM where to find any external tests.  They are expected to be | 
|  | 1008 | in specifically named subdirectories of <<tt>directory</tt>>. | 
|  | 1009 | If <tt>directory</tt> is left unspecified, | 
|  | 1010 | <tt>configure</tt> uses the default value | 
|  | 1011 | <tt>/home/vadve/shared/benchmarks/speccpu2000/benchspec</tt>. | 
|  | 1012 | Subdirectory names known to LLVM include: | 
|  | 1013 | <dl> | 
|  | 1014 | <dt>spec95</dt> | 
|  | 1015 | <dt>speccpu2000</dt> | 
|  | 1016 | <dt>speccpu2006</dt> | 
|  | 1017 | <dt>povray31</dt> | 
|  | 1018 | </dl> | 
|  | 1019 | Others are added from time to time, and can be determined from | 
|  | 1020 | <tt>configure</tt>. | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 1021 | </div> | 
|  | 1022 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1023 | <!-- _______________________________________________________________________ --> | 
|  | 1024 | <div class="doc_subsection"> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1025 | <a name="testsuitetests">Running different tests</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1026 | <!-- _______________________________________________________________________ --> | 
|  | 1027 | <div class="doc_text"> | 
| Stuart Hastings | 6d43769 | 2009-05-21 20:23:59 +0000 | [diff] [blame] | 1028 | <p>In addition to the regular "whole program" tests, the <tt>test-suite</tt> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1029 | module also provides a mechanism for compiling the programs in different ways. | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1030 | If the variable TEST is defined on the <tt>gmake</tt> command line, the test system will | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1031 | include a Makefile named <tt>TEST.<value of TEST variable>.Makefile</tt>. | 
|  | 1032 | This Makefile can modify build rules to yield different results.</p> | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 1033 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1034 | <p>For example, the LLVM nightly tester uses <tt>TEST.nightly.Makefile</tt> to | 
|  | 1035 | create the nightly test reports.  To run the nightly tests, run <tt>gmake | 
|  | 1036 | TEST=nightly</tt>.</p> | 
|  | 1037 |  | 
|  | 1038 | <p>There are several TEST Makefiles available in the tree.  Some of them are | 
|  | 1039 | designed for internal LLVM research and will not work outside of the LLVM | 
|  | 1040 | research group.  They may still be valuable, however, as a guide to writing your | 
|  | 1041 | own TEST Makefile for any optimization or analysis passes that you develop with | 
|  | 1042 | LLVM.</p> | 
|  | 1043 |  | 
| Bill Wendling | 6275c23 | 2007-09-22 09:16:44 +0000 | [diff] [blame] | 1044 | </div> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 1045 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1046 | <!-- _______________________________________________________________________ --> | 
|  | 1047 | <div class="doc_subsection"> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1048 | <a name="testsuiteoutput">Generating test output</a></div> | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1049 | <!-- _______________________________________________________________________ --> | 
|  | 1050 | <div class="doc_text"> | 
|  | 1051 | <p>There are a number of ways to run the tests and generate output. The most | 
|  | 1052 | simple one is simply running <tt>gmake</tt> with no arguments. This will | 
|  | 1053 | compile and run all programs in the tree using a number of different methods | 
|  | 1054 | and compare results. Any failures are reported in the output, but are likely | 
|  | 1055 | drowned in the other output. Passes are not reported explicitely.</p> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 1056 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1057 | <p>Somewhat better is running <tt>gmake TEST=sometest test</tt>, which runs | 
|  | 1058 | the specified test and usually adds per-program summaries to the output | 
|  | 1059 | (depending on which sometest you use). For example, the <tt>nightly</tt> test | 
|  | 1060 | explicitely outputs TEST-PASS or TEST-FAIL for every test after each program. | 
|  | 1061 | Though these lines are still drowned in the output, it's easy to grep the | 
|  | 1062 | output logs in the Output directories.</p> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 1063 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1064 | <p>Even better are the <tt>report</tt> and <tt>report.format</tt> targets | 
|  | 1065 | (where <tt>format</tt> is one of <tt>html</tt>, <tt>csv</tt>, <tt>text</tt> or | 
|  | 1066 | <tt>graphs</tt>). The exact contents of the report are dependent on which | 
|  | 1067 | <tt>TEST</tt> you are running, but the text results are always shown at the | 
|  | 1068 | end of the run and the results are always stored in the | 
|  | 1069 | <tt>report.<type>.format</tt> file (when running with | 
|  | 1070 | <tt>TEST=<type></tt>). | 
| Chris Lattner | c4f2252 | 2004-06-24 20:53:09 +0000 | [diff] [blame] | 1071 |  | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1072 | The <tt>report</tt> also generate a file called | 
|  | 1073 | <tt>report.<type>.raw.out</tt> containing the output of the entire test | 
|  | 1074 | run. | 
| Chris Lattner | c4f2252 | 2004-06-24 20:53:09 +0000 | [diff] [blame] | 1075 | </div> | 
|  | 1076 |  | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 1077 | <!-- _______________________________________________________________________ --> | 
|  | 1078 | <div class="doc_subsection"> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1079 | <a name="testsuitecustom">Writing custom tests for the test suite</a></div> | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 1080 | <!-- _______________________________________________________________________ --> | 
|  | 1081 |  | 
|  | 1082 | <div class="doc_text"> | 
|  | 1083 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1084 | <p>Assuming you can run the test suite, (e.g. "<tt>gmake TEST=nightly report</tt>" | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 1085 | should work), it is really easy to run optimizations or code generator | 
|  | 1086 | components against every program in the tree, collecting statistics or running | 
|  | 1087 | custom checks for correctness.  At base, this is how the nightly tester works, | 
|  | 1088 | it's just one example of a general framework.</p> | 
|  | 1089 |  | 
|  | 1090 | <p>Lets say that you have an LLVM optimization pass, and you want to see how | 
|  | 1091 | many times it triggers.  First thing you should do is add an LLVM | 
|  | 1092 | <a href="ProgrammersManual.html#Statistic">statistic</a> to your pass, which | 
|  | 1093 | will tally counts of things you care about.</p> | 
|  | 1094 |  | 
|  | 1095 | <p>Following this, you can set up a test and a report that collects these and | 
|  | 1096 | formats them for easy viewing.  This consists of two files, an | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1097 | "<tt>test-suite/TEST.XXX.Makefile</tt>" fragment (where XXX is the name of your | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 1098 | test) and an "<tt>llvm-test/TEST.XXX.report</tt>" file that indicates how to | 
|  | 1099 | format the output into a table.  There are many example reports of various | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1100 | levels of sophistication included with the test suite, and the framework is very | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 1101 | general.</p> | 
|  | 1102 |  | 
|  | 1103 | <p>If you are interested in testing an optimization pass, check out the | 
|  | 1104 | "libcalls" test as an example.  It can be run like this:<p> | 
|  | 1105 |  | 
|  | 1106 | <div class="doc_code"> | 
|  | 1107 | <pre> | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1108 | % cd llvm/projects/test-suite/MultiSource/Benchmarks  # or some other level | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 1109 | % make TEST=libcalls report | 
|  | 1110 | </pre> | 
|  | 1111 | </div> | 
|  | 1112 |  | 
|  | 1113 | <p>This will do a bunch of stuff, then eventually print a table like this:</p> | 
|  | 1114 |  | 
|  | 1115 | <div class="doc_code"> | 
|  | 1116 | <pre> | 
|  | 1117 | Name                                  | total | #exit | | 
|  | 1118 | ... | 
|  | 1119 | FreeBench/analyzer/analyzer           | 51    | 6     | | 
|  | 1120 | FreeBench/fourinarow/fourinarow       | 1     | 1     | | 
|  | 1121 | FreeBench/neural/neural               | 19    | 9     | | 
|  | 1122 | FreeBench/pifft/pifft                 | 5     | 3     | | 
|  | 1123 | MallocBench/cfrac/cfrac               | 1     | *     | | 
|  | 1124 | MallocBench/espresso/espresso         | 52    | 12    | | 
|  | 1125 | MallocBench/gs/gs                     | 4     | *     | | 
|  | 1126 | Prolangs-C/TimberWolfMC/timberwolfmc  | 302   | *     | | 
|  | 1127 | Prolangs-C/agrep/agrep                | 33    | 12    | | 
|  | 1128 | Prolangs-C/allroots/allroots          | *     | *     | | 
|  | 1129 | Prolangs-C/assembler/assembler        | 47    | *     | | 
|  | 1130 | Prolangs-C/bison/mybison              | 74    | *     | | 
|  | 1131 | ... | 
|  | 1132 | </pre> | 
|  | 1133 | </div> | 
|  | 1134 |  | 
|  | 1135 | <p>This basically is grepping the -stats output and displaying it in a table. | 
|  | 1136 | You can also use the "TEST=libcalls report.html" target to get the table in HTML | 
|  | 1137 | form, similarly for report.csv and report.tex.</p> | 
|  | 1138 |  | 
| Matthijs Kooijman | 8fd2841 | 2008-06-24 12:58:31 +0000 | [diff] [blame] | 1139 | <p>The source for this is in test-suite/TEST.libcalls.*.  The format is pretty | 
| Chris Lattner | 17d145e | 2006-05-23 01:40:20 +0000 | [diff] [blame] | 1140 | simple: the Makefile indicates how to run the test (in this case, | 
|  | 1141 | "<tt>opt -simplify-libcalls -stats</tt>"), and the report contains one line for | 
|  | 1142 | each column of the output.  The first value is the header for the column and the | 
|  | 1143 | second is the regex to grep the output of the command for.  There are lots of | 
|  | 1144 | example reports that can do fancy stuff.</p> | 
|  | 1145 |  | 
|  | 1146 | </div> | 
|  | 1147 |  | 
|  | 1148 |  | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 1149 | <!--=========================================================================--> | 
| Chris Lattner | c4f2252 | 2004-06-24 20:53:09 +0000 | [diff] [blame] | 1150 | <div class="doc_section"><a name="nightly">Running the nightly tester</a></div> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 1151 | <!--=========================================================================--> | 
| Chris Lattner | c4f2252 | 2004-06-24 20:53:09 +0000 | [diff] [blame] | 1152 |  | 
|  | 1153 | <div class="doc_text"> | 
|  | 1154 |  | 
|  | 1155 | <p> | 
| Patrick Jenkins | 04ed142 | 2006-08-11 23:27:02 +0000 | [diff] [blame] | 1156 | The <a href="http://llvm.org/nightlytest/">LLVM Nightly Testers</a> | 
| Chris Lattner | c4f2252 | 2004-06-24 20:53:09 +0000 | [diff] [blame] | 1157 | automatically check out an LLVM tree, build it, run the "nightly" | 
| Matthijs Kooijman | e7d45b1 | 2008-05-23 11:45:18 +0000 | [diff] [blame] | 1158 | program test (described above), run all of the DejaGNU tests, | 
| Patrick Jenkins | 04ed142 | 2006-08-11 23:27:02 +0000 | [diff] [blame] | 1159 | delete the checked out tree, and then submit the results to | 
|  | 1160 | <a href="http://llvm.org/nightlytest/">http://llvm.org/nightlytest/</a>. | 
|  | 1161 | After test results are submitted to | 
|  | 1162 | <a href="http://llvm.org/nightlytest/">http://llvm.org/nightlytest/</a>, | 
|  | 1163 | they are processed and displayed on the tests page. An email to | 
|  | 1164 | <a href="http://lists.cs.uiuc.edu/pipermail/llvm-testresults/"> | 
|  | 1165 | llvm-testresults@cs.uiuc.edu</a> summarizing the results is also generated. | 
|  | 1166 | This testing scheme is designed to ensure that programs don't break as well | 
|  | 1167 | as keep track of LLVM's progress over time.</p> | 
| Chris Lattner | c4f2252 | 2004-06-24 20:53:09 +0000 | [diff] [blame] | 1168 |  | 
| Patrick Jenkins | 04ed142 | 2006-08-11 23:27:02 +0000 | [diff] [blame] | 1169 | <p>If you'd like to set up an instance of the nightly tester to run on your | 
|  | 1170 | machine, take a look at the comments at the top of the | 
|  | 1171 | <tt>utils/NewNightlyTest.pl</tt> file. If you decide to set up a nightly tester | 
|  | 1172 | please choose a unique nickname and invoke <tt>utils/NewNightlyTest.pl</tt> | 
| Reid Spencer | c7f87f2 | 2007-07-09 08:04:31 +0000 | [diff] [blame] | 1173 | with the "-nickname [yournickname]" command line option. | 
| Chris Lattner | c4f2252 | 2004-06-24 20:53:09 +0000 | [diff] [blame] | 1174 |  | 
| Reid Spencer | c7f87f2 | 2007-07-09 08:04:31 +0000 | [diff] [blame] | 1175 | <p>You can create a shell script to encapsulate the running of the script. | 
| Misha Brukman | 5da60ba | 2005-03-10 22:51:59 +0000 | [diff] [blame] | 1176 | The optimized x86 Linux nightly test is run from just such a script:</p> | 
|  | 1177 |  | 
|  | 1178 | <div class="doc_code"> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 1179 | <pre> | 
|  | 1180 | #!/bin/bash | 
|  | 1181 | BASE=/proj/work/llvm/nightlytest | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 1182 | export BUILDDIR=$BASE/build | 
|  | 1183 | export WEBDIR=$BASE/testresults | 
|  | 1184 | export LLVMGCCDIR=/proj/work/llvm/cfrontend/install | 
|  | 1185 | export PATH=/proj/install/bin:$LLVMGCCDIR/bin:$PATH | 
|  | 1186 | export LD_LIBRARY_PATH=/proj/install/lib | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 1187 | cd $BASE | 
| Patrick Jenkins | 04ed142 | 2006-08-11 23:27:02 +0000 | [diff] [blame] | 1188 | cp /proj/work/llvm/llvm/utils/NewNightlyTest.pl . | 
|  | 1189 | nice ./NewNightlyTest.pl -nice -release -verbose -parallel -enable-linscan \ | 
| Reid Spencer | c7f87f2 | 2007-07-09 08:04:31 +0000 | [diff] [blame] | 1190 | -nickname NightlyTester -noexternals > output.log 2>&1 | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 1191 | </pre> | 
| Misha Brukman | 5da60ba | 2005-03-10 22:51:59 +0000 | [diff] [blame] | 1192 | </div> | 
| Reid Spencer | ae21b0b | 2004-09-05 20:07:26 +0000 | [diff] [blame] | 1193 |  | 
| Patrick Jenkins | 04ed142 | 2006-08-11 23:27:02 +0000 | [diff] [blame] | 1194 | <p>It is also possible to specify the the location your nightly test results | 
|  | 1195 | are submitted. You can do this by passing the command line option | 
|  | 1196 | "-submit-server [server_address]" and "-submit-script [script_on_server]" to | 
|  | 1197 | <tt>utils/NewNightlyTest.pl</tt>. For example, to submit to the llvm.org | 
|  | 1198 | nightly test results page, you would invoke the nightly test script with | 
|  | 1199 | "-submit-server llvm.org -submit-script /nightlytest/NightlyTestAccept.cgi". | 
|  | 1200 | If these options are not specified, the nightly test script sends the results | 
|  | 1201 | to the llvm.org nightly test results page.</p> | 
|  | 1202 |  | 
|  | 1203 | <p>Take a look at the <tt>NewNightlyTest.pl</tt> file to see what all of the | 
|  | 1204 | flags and strings do.  If you start running the nightly tests, please let us | 
|  | 1205 | know. Thanks!</p> | 
| Misha Brukman | 5da60ba | 2005-03-10 22:51:59 +0000 | [diff] [blame] | 1206 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 1207 | </div> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 1208 |  | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 1209 | <!-- *********************************************************************** --> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 1210 |  | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 1211 | <hr> | 
|  | 1212 | <address> | 
|  | 1213 | <a href="http://jigsaw.w3.org/css-validator/check/referer"><img | 
| Misha Brukman | 86242e1 | 2008-12-11 17:34:48 +0000 | [diff] [blame] | 1214 | src="http://jigsaw.w3.org/css-validator/images/vcss-blue" alt="Valid CSS"></a> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 1215 | <a href="http://validator.w3.org/check/referer"><img | 
| Misha Brukman | 86242e1 | 2008-12-11 17:34:48 +0000 | [diff] [blame] | 1216 | src="http://www.w3.org/Icons/valid-html401-blue" alt="Valid HTML 4.01"></a> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 1217 |  | 
| John Criswell | 417cb0a | 2005-05-13 19:48:07 +0000 | [diff] [blame] | 1218 | John T. Criswell, Reid Spencer, and Tanya Lattner<br> | 
| Matthijs Kooijman | 3f95ba0 | 2008-05-20 10:28:55 +0000 | [diff] [blame] | 1219 | <a href="http://llvm.org">The LLVM Compiler Infrastructure</a><br> | 
| Misha Brukman | 773d6f6 | 2004-03-01 18:21:04 +0000 | [diff] [blame] | 1220 | Last modified: $Date$ | 
|  | 1221 | </address> | 
| Brian Gaeke | 739811d | 2003-10-23 18:10:28 +0000 | [diff] [blame] | 1222 | </body> | 
| John Criswell | e90fc1f | 2003-10-10 18:42:49 +0000 | [diff] [blame] | 1223 | </html> |