1 <?xml version=
"1.0" encoding=
"ISO-8859-1"?>
3 PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
4 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
6 <html xmlns=
"http://www.w3.org/1999/xhtml" xml:
lang=
"en" lang=
"en">
8 <meta name=
"AUTHOR" content=
"bkoz@gcc.gnu.org (Benjamin Kosnik)" />
9 <meta name=
"KEYWORDS" content=
"c++, libstdc++, test, regression, g++" />
10 <meta name=
"DESCRIPTION" content=
"README for the GNU libstdc++ effort." />
11 <meta name=
"GENERATOR" content=
"vi and eight fingers" />
12 <title>libstdc++-v3 Testing Instructions
</title>
13 <link rel=
"StyleSheet" href=
"lib3styles.css" />
17 <h1 class=
"centered"><a name=
"top">Testing Details
</a></h1>
19 <p class=
"fineprint"><em>
20 The latest version of this document is always available at
21 <a href=
"http://gcc.gnu.org/onlinedocs/libstdc++/test.html">
22 http://gcc.gnu.org/onlinedocs/libstdc++/test.html
</a>.
26 To the
<a href=
"http://gcc.gnu.org/libstdc++/">libstdc++-v3 homepage
</a>.
29 <!-- ####################################################### -->
33 <li><a href=
"#org">Testsuite organization and naming conventions
</a></li>
34 <li><a href=
"#util">Utilities: abicheck and libv3test
</a></li>
35 <li><a href=
"#new">How to write a new test case
</a></li>
36 <li><a href=
"#check">Options for running the tests
</a></li>
37 <li><a href=
"#debug">Running debug-mode tests
</a></li>
38 <li><a href=
"#future">Future
</a></li>
39 <li><a href=
"#internals">DejaGNU internals
</a></li>
44 <!-- ####################################################### -->
46 <h2><a name=
"org">Testsuite organization and naming conventions
</a></h2>
48 The directory
<em>libsrcdir/testsuite
</em> contains the
49 individual test cases organized in sub-directories corresponding
50 to chapters of the C++ standard (detailed below), the dejagnu
51 test harness support files, and sources to various testsuite
52 utilities that are packaged in a separate testing library.
55 <p> All test cases for functionality required by the runtime
56 components of the C++ standard (ISO
14882) are files within the
57 following directories.
74 In addition, the following directories include test files:
78 tr1 Tests for components as described by the Technical Report on Standard Library Extensions (TR1).
79 backward Tests for backwards compatibility and deprecated features.
80 demangle Tests for __cxa_demangle, the IA
64 C++ ABI demangler
81 ext Tests for extensions.
82 performance Tests for performance analysis, and performance regressions.
83 thread Tests for threads.
87 Some directories don't have test files, but instead contain
88 auxiliary information (
<a href=
"#internals">more information
</a>):
92 config Files for the dejagnu test harness.
93 lib Files for the dejagnu test harness.
94 libstdc++* Files for the dejagnu test harness.
95 data Sample text files for testing input and output.
99 Within a directory that includes test files, there may be
100 additional subdirectories, or files. Originally, test cases
101 were appended to one file that represented a particular section
102 of the chapter under test, and was named accordingly. For
103 instance, to test items related to
<code> 21.3.6.1 -
104 basic_string::find [lib.string::find]
</code> in the standard,
105 the following was used:
111 However, that practice soon became a liability as the test cases
112 became huge and unwieldy, and testing new or extended
113 functionality (like wide characters or named locales) became
114 frustrating, leading to aggressive pruning of test cases on some
115 platforms that covered up implementation errors. Now, the test
116 suite has a policy of one file, one test case, which solves the
117 above issues and gives finer grained results and more manageable
118 error debugging. As an example, the test case quoted above
122 21_strings/basic_string/find/char/
1.cc
123 21_strings/basic_string/find/char/
2.cc
124 21_strings/basic_string/find/char/
3.cc
125 21_strings/basic_string/find/wchar_t/
1.cc
126 21_strings/basic_string/find/wchar_t/
2.cc
127 21_strings/basic_string/find/wchar_t/
3.cc
131 All new tests should be written with the policy of one test
132 case, one file in mind.
136 In addition, there are some special names and suffixes that are
137 used within the testsuite to designate particular kinds of
145 This test case expects some kind of interactive input in order
146 to finish or pass. At the moment, the interactive tests are not
147 run by default. Instead, they are run by hand, like:
150 g++
27_io/objects/char/
3_xin.cc
151 cat
27_io/objects/char/
3_xin.in | a.out
157 This file contains the expected input for the corresponding
<em>
158 _xin.cc
</em> test case.
164 This test case is expected to fail: it's a negative test. At the
165 moment, these are almost always compile time errors.
171 This can either be a directory name or part of a longer file
172 name, and indicates that this file, or the files within this
173 directory are testing the
<code>char
</code> instantiation of a
180 This can either be a directory name or part of a longer file
181 name, and indicates that this file, or the files within this
182 directory are testing the
<code>wchar_t
</code> instantiation of
183 a template. Some hosts do not support
<code>wchar_t
</code>
184 functionality, so for these targets, all of these tests will not
191 This can either be a directory name or part of a longer file
192 name, and indicates that this file, or the files within this
193 directory are testing situations where multiple threads are
200 This can either be an enclosing directory name or part of a
201 specific file name. This indicates a test that is used to
202 analyze runtime performance, for performance regression testing,
203 or for other optimization related analysis. At the moment, these
204 test cases are not run by default.
210 <h2><a name=
"util">Utilities: abi_check and libv3test
</a></h2>
212 The testsuite directory also contains some files that implement
213 functionality that is intended to make writing test cases easier,
214 or to avoid duplication, or to provide error checking in a way that
215 is consistent across platforms and test harnesses. A stand-alone
216 executable, called
<em>abi_check
</em>, and a static library called
217 <em>libv3test
</em> are constructed. Both of these items are not
218 installed, and only used during testing.
222 These files include the following functionality:
227 <em>testsuite_abi.h
</em>,
228 <em>testsuite_abi.cc
</em>,
229 <em>testsuite_abi_check.cc
</em>
231 Creates the executable
<em>abi_check
</em>.
232 Used to check correctness of symbol versioning, visibility of
233 exported symbols, and compatibility on symbols in the shared
234 library, for hosts that support this feature. More information
235 can be found in the ABI documentation
<a href=
"abi.html"> here
</a>
239 <em>testsuite_allocator.h
</em>,
240 <em>testsuite_allocator.cc
</em>
242 Contains specialized allocators that keep track of construction
243 and destruction. Also, support for overriding global new and
244 delete operators, including verification that new and delete
245 are called during execution, and that allocation over max_size
250 <em>testsuite_character.h
</em>
252 Contains
<code>std::char_traits
</code> and
253 <code>std::codecvt
</code> specializations for a user-defined
258 <em>testsuite_hooks.h
</em>,
259 <em>testsuite_hooks.cc
</em>
261 A large number of utilities, including:
265 <li>set_memory_limits
</li>
266 <li>verify_demangle
</li>
267 <li>run_tests_wrapped_locale
</li>
268 <li>run_tests_wrapped_env
</li>
269 <li>try_named_locale
</li>
271 <li>func_callback
</li>
273 <li>copy_tracker
</li>
274 <li>copy_constructor
</li>
275 <li>assignment_operator
</li>
277 <li>pod_char, pod_int and associated char_traits specializations
</li>
282 <em>testsuite_io.h
</em>
284 Error, exception, and constraint checking for
285 <code>std::streambuf, std::basic_stringbuf, std::basic_filebuf
</code>.
289 <em>testsuite_iterators.h
</em>
291 Wrappers for various iterators.
295 <em>testsuite_performance.h
</em>
297 A number of class abstractions for performance counters, and
298 reporting functions including:
301 <li>time_counter
</li>
302 <li>resource_counter
</li>
303 <li>report_performance
</li>
310 <h2><a name=
"new">How to write a new test case
</a></h2>
313 The first step in making a new test case is to choose the correct
314 directory and file name, given the organization as previously
319 All files are copyright the FSF, and GPL'd: this is very
320 important. The first copyright year should correspond to the date
321 the file was checked in to CVS.
325 As per the dejagnu instructions, always return
0 from main to
330 A bunch of utility functions and classes have already been
331 abstracted out into the testsuite utility library,
<code>
332 libv3test
</code>. To use this functionality, just include the
333 appropriate header file: the library will automatically be linked
334 in as part of the testsuite run.
338 For a test that needs to take advantage of the dejagnu test
339 harness, what follows below is a list of special keyword that
340 harness uses. Basically, a test case contains dg-keywords (see
341 dg.exp) indicating what to do and what kinds of behavior are to be
342 expected. New test cases should be written with the new style
343 DejaGnu framework in mind.
347 To ease transition, here is the list of dg-keyword documentation
352 # The currently supported options are:
357 # dg-options
"options ..." [{ target selector }]
358 # specify special options to pass to the tool (eg: compiler)
360 # dg-do do-what-keyword [{ target/xfail selector }]
361 # `do-what-keyword' is tool specific and is passed unchanged to
362 # ${tool}-dg-test. An example is gcc where `keyword' can be any of:
363 # preprocess|compile|assemble|link|run
364 # and will do one of: produce a .i, produce a .s, produce a .o,
365 # produce an a.out, or produce an a.out and run it (the default is
368 # dg-error regexp comment [{ target/xfail selector } [{.|
0|linenum}]]
369 # indicate an error message
<regexp
> is expected on this line
370 # (the test fails if it doesn't occur)
371 # Linenum=
0 for general tool messages (eg: -V arg missing).
372 #
"." means the current line.
374 # dg-warning regexp comment [{ target/xfail selector } [{.|
0|linenum}]]
375 # indicate a warning message
<regexp
> is expected on this line
376 # (the test fails if it doesn't occur)
378 # dg-bogus regexp comment [{ target/xfail selector } [{.|
0|linenum}]]
379 # indicate a bogus error message
<regexp
> use to occur here
380 # (the test fails if it does occur)
382 # dg-build regexp comment [{ target/xfail selector }]
383 # indicate the build use to fail for some reason
384 # (errors covered here include bad assembler generated, tool crashes,
386 # (the test fails if it does occur)
388 # dg-excess-errors comment [{ target/xfail selector }]
389 # indicate excess errors are expected (any line)
390 # (this should only be used sparingly and temporarily)
392 # dg-output regexp [{ target selector }]
393 # indicate the expected output of the program is
<regexp
>
394 # (there may be multiple occurrences of this, they are concatenated)
396 # dg-final { tcl code }
397 # add some tcl code to be run at the end
398 # (there may be multiple occurrences of this, they are concatenated)
399 # (unbalanced braces must be \-escaped)
401 #
"{ target selector }" is a list of expressions that determine whether the
402 # test succeeds or fails for a particular target, or in some cases whether the
403 # option applies for a particular target. If the case of `dg-do' it specifies
404 # whether the test case is even attempted on the specified target.
406 # The target selector is always optional. The format is one of:
408 # { xfail *-*-* ... } - the test is expected to fail for the given targets
409 # { target *-*-* ... } - the option only applies to the given targets
411 # At least one target must be specified, use *-*-* for
"all targets".
412 # At present it is not possible to specify both `xfail' and `target'.
413 #
"native" may be used in place of
"*-*-*".
415 Example
1: Testing compilation only
418 Example
2: Testing for expected warnings on line
36, which all targets fail
419 // { dg-warning
"string literals" "" { xfail *-*-* }
36
421 Example
3: Testing for expected warnings on line
36
422 // { dg-warning
"string literals" "" { target *-*-* }
36
424 Example
4: Testing for compilation errors on line
41
426 // { dg-error
"no match for" "" { target *-*-* }
41 }
428 Example
5: Testing with special command line settings, or without the
429 use of pre-compiled headers, in particular the stdc++.h.gch file. Any
430 options here will override the DEFAULT_CXXFLAGS and PCH_CXXFLAGS set
431 up in the normal.exp file.
432 // { dg-options
"-O0" { target *-*-* } }
436 More examples can be found in the libstdc++-v3/testsuite/*/*.cc files.
440 <h2><a name=
"check">Options for running the tests
</a></h2>
442 <p> There are several options for running tests, including testing
443 the regression tests, testing a subset of the regression tests,
444 testing the performance tests, testing just compilation, testing
445 installed tools, etc. In addition, there is a special rule for
446 checking the exported symbols of the shared library.
449 <p>You can check the status of the build without installing it
450 using the dejagnu harness, much like the rest of the gcc tools.
</p>
451 <pre> make check
</pre>
452 <p>in the
<em>libbuilddir
</em> directory.
</p>
454 <pre> make check-target-libstdc++-v3
</pre>
455 <p>in the
<em>gccbuilddir
</em> directory.
</p>
458 These commands are functionally equivalent and will create a
459 'testsuite' directory underneath
<em>libbuilddir
</em> containing
460 the results of the tests. Two results files will be generated:
461 <em> libstdc++.sum
</em>, which is a PASS/FAIL summary for each
462 test, and
<em>libstdc++.log
</em> which is a log of the exact
463 command line passed to the compiler, the compiler output, and
464 the executable output (if any).
469 To debug the dejagnu test harness during runs, try invoking with a
470 specific argument to the variable RUNTESTFLAGS, as below.
474 make check-target-libstdc++-v3
RUNTESTFLAGS=
"-v"
478 make check-target-libstdc++-v3
RUNTESTFLAGS=
"-v -v"
481 <p> To run a subset of the library tests, try using a command like the
482 following from the
<em>libbuilddir/testsuite
</em> directory:
485 runtest --tool libstdc++ normal.
exp=
"`find $srcdir/17_intro -name *.cc`"
490 There are two ways to run on a simulator: set up DEJAGNU to point to a
491 specially crafted site.exp, or pass down --target_board flags.
493 Example flags to pass down for various embedded builds are as follows:
495 --target=powerpc-eabism (libgloss/sim)
496 make check-target-libstdc++-v3
RUNTESTFLAGS=
"--target_board=powerpc-sim"
498 --target=calmrisc32 (libgloss/sid)
499 make check-target-libstdc++-v3
RUNTESTFLAGS=
"--target_board=calmrisc32-sid"
501 --target=xscale-elf (newlib/sim)
502 make check-target-libstdc++-v3
RUNTESTFLAGS=
"--target_board=arm-sim"
505 <p> Also, here is an example of how to run the libstdc++ testsuite for a
506 multilibed build directory with different ABI settings:
509 make check-target-libstdc++-v3 RUNTESTFLAGS='--target_board \
"unix{-mabi=32,,-mabi=64}\"'
513 You can run the tests with a compiler and library that have already
514 been installed. Make sure that the compiler (e.g.,
<code>g++
</code>)
515 is in your
<code>PATH
</code>. If you are using shared libraries, then
516 you must also ensure that the directory containing the shared version
517 of libstdc++ is in your
<code>LD_LIBRARY_PATH
</code>, or equivalent.
518 If your GCC source tree is at
<code>/path/to/gcc
</code>, then you can
519 run the tests as follows:
521 runtest --tool libstdc++ --srcdir=/path/to/gcc/libstdc++-v3/testsuite
523 The testsuite will create a number of files in the directory in which you
524 run this command,. Some of those files might use the same name as
525 files created by other testsuites (like the ones for GCC and G++), so
526 you should not try to run all the testsuites in parallel from the same
530 <p> In addition, there are some testing options that are mostly of
531 interest to library maintainers and system integrators. As such,
532 these tests may not work on all cpu and host combinations, and may need to
533 be executed in the
<em>libbuilddir/testsuite
</em> directory. These options
534 include, but are not necessarily limited to, the following:
538 make testsuite_files
</pre>
540 Five files are generated that determine what test files
541 are run. These files are:
545 <em>testsuite_files
</em>
546 <p> This is a list of all the test cases that will be run. Each
547 test case is on a separate line, given with an absolute path
548 from the
<em>libsrcdir/testsuite
</em> directory.
553 <em>testsuite_files_interactive
</em>
554 <p> This is a list of all the interactive test cases, using the
555 same format as the file list above. These tests are not run by default.
560 <em>testsuite_files_performance
</em>
561 <p> This is a list of all the performance test cases, using the
562 same format as the file list above. These tests are not run by default.
567 <em>testsuite_thread
</em>
568 <p> This file indicates that the host system can run tests which
569 incolved multiple threads.
574 <em>testsuite_wchar_t
</em>
575 <p> This file indicates that the host system can run the wchar_t
576 tests, and corresponds to the macro definition
<code>
577 _GLIBCXX_USE_WCHAR_T
</code> in the file c++config.h.
584 <p>The library ABI can be tested. This involves testing the shared
585 library against an ABI-defining previous version of symbol exports.
</p>
588 make check-compile
</pre>
589 <p>This rule compiles, but does not link or execute, the
590 <em>testsuite_files
</em> test cases and displays the output on stdout.
</p>
593 make check-performance
</pre>
594 <p>This rule runs through the
<em>testsuite_files_performance
</em>
595 test cases and collects information for performance analysis and
596 can be used to spot performance regressions. Various timing
597 information is collected, as well as number of hard page faults,
598 and memory used. This is not run by default, and the implementation
603 We are interested in any strange failures of the
604 testsuite; please see
<a href=
"faq/index.html#2_4">FAQ
2.4</a>
605 for which files to examine.
609 <h2><a name=
"debug">Running debug-mode tests
</a></h2>
610 <p>To run the libstdc++ test suite under the
<a
611 href=
"debug.html#safe">debug mode
</a>,
612 edit
<code>libstdc++/scripts/testsuite_flags
</code> to add the
613 compile-time flag
<code>-D_GLIBCXX_DEBUG
</code> to the result
614 printed by the
<code>--build-cxx
</code> option. Additionally, add
615 the
<code>-D_GLIBCXX_DEBUG_PEDANTIC
</code> flag to turn on pedantic
616 checking. The libstdc++ test suite should produce precisely the same
617 results under debug mode that it does under release mode: any
618 deviation indicates an error in either the library or the test
622 <h2><a name=
"future">Future
</a></h2>
625 Shared runs need to be implemented, for targets that support shared libraries.
629 Diffing of expected output to standard streams needs to be finished off.
633 The V3 testing framework supports, or will eventually support,
634 additional keywords for the purpose of easing the job of writing
635 test cases. All V3-keywords are of the form
<code>@xxx@
</code>.
636 Currently plans for supported keywords include:
640 <dt> <code> @require@
<files
> </code> </dt>
643 The existence of
<files
> is essential for the test to complete
644 successfully. For example, a test case foo.C using bar.baz as
648 // @require@ bar.baz
</pre>
650 The special variable % stands for the rootname, e.g. the
651 file-name without its `.C' extension. Example of use (taken
652 verbatim from
27_io/filebuf.cc)
655 // @require@ %-*.tst %-*.txt
</pre>
657 <dt> <code> @diff@
<first-list
> <second-list
> </code> </dt>
660 After the test case compiles and ran successfully, diff
661 <first-list
> against
<second-list
>, these lists should
662 have the same length. The test fails if diff returns non-zero a
669 <h2><a name=
"internals">DejaGNU internals
</a></h2>
671 <p>This is information for those looking at making changes to the testsuite
672 structure, and/or needing to trace dejagnu's actions with --verbose. This
673 will not be useful to people who are
"merely" adding new tests to the existing
677 <p>The first key point when working with dejagnu is the idea of a
"tool".
678 Files, directories, and functions are all implicitly used when they are
679 named after the tool in use. Here, the tool will always be
"libstdc++".
682 <p>The
<code>lib
</code> subdir contains support routines. The
683 <code>lib/libstdc++.exp
</code> file (
"support library") is loaded
684 automagically, and must explicitly load the others. For example, files can
685 be copied from the core compiler's support directory into
<code>lib
</code>.
688 <p>Some routines in
<code>lib/libstdc++.exp
</code> are callbacks, some are
689 our own. Callbacks must be prefixed with the name of the tool. To easily
690 distinguish the others, by convention our own routines are named
"v3-*".
693 <p>The next key point when working with dejagnu is
"test files". Any
694 directory whose name starts with the tool name will be searched for test files.
695 (We have only one.) In those directories, any
<code>.exp
</code> file is
696 considered a test file, and will be run in turn. Our main test file is called
697 <code>normal.exp
</code>; it runs all the tests in testsuite_files using the
698 callbacks loaded from the support library.
701 <p>The
<code>config
</code> directory is searched for any particular
"target
702 board" information unique to this library. This is currently unused and sets
703 only default variables.
707 <!-- ####################################################### -->
710 <p class=
"fineprint"><em>
711 See
<a href=
"17_intro/license.html">license.html
</a> for copying conditions.
712 Comments and suggestions are welcome, and may be sent to
713 <a href=
"mailto:libstdc++@gcc.gnu.org">the libstdc++ mailing list
</a>.