README: Add more comment.
2001-01-28 Gabriel Dos Reis <gdr@codesourcery.com> * testsuite/README: Add more comment. * testsuite/lib/libstdc++.exp: Tweak comment. From-SVN: r39321
This commit is contained in:
parent
64b9f19994
commit
4870f47246
@ -1,3 +1,8 @@
|
|||||||
|
2001-01-28 Gabriel Dos Reis <gdr@codesourcery.com>
|
||||||
|
|
||||||
|
* testsuite/README: Add more comment.
|
||||||
|
* testsuite/lib/libstdc++.exp: Tweak comment.
|
||||||
|
|
||||||
2001-01-26 Benjamin Kosnik <bkoz@kredhat.com>
|
2001-01-26 Benjamin Kosnik <bkoz@kredhat.com>
|
||||||
|
|
||||||
* libsupc++/pure.cc (writestr): Just use cstdio and std::fputs.
|
* libsupc++/pure.cc (writestr): Just use cstdio and std::fputs.
|
||||||
|
@ -3,8 +3,8 @@ use the new style DejaGnu framework. Eventually, we'll abandon
|
|||||||
../mkcheck.in in favor of this new testsuite framework.
|
../mkcheck.in in favor of this new testsuite framework.
|
||||||
|
|
||||||
Basically, a testcase contains dg-keywords (see dg.exp) indicating
|
Basically, a testcase contains dg-keywords (see dg.exp) indicating
|
||||||
what to do and what kind of behaviour are to be expected. New
|
what to do and what kinds of behaviour are to be expected. New
|
||||||
testsuite should be written with the new style DejaGnu framework in mind.
|
testcases should be written with the new style DejaGnu framework in mind.
|
||||||
|
|
||||||
The V3 testing framework supports additional keywords for the purpose
|
The V3 testing framework supports additional keywords for the purpose
|
||||||
of easing the job of writing testcases. All V3-keywords are of the
|
of easing the job of writing testcases. All V3-keywords are of the
|
||||||
@ -21,5 +21,9 @@ form @xxx@. Currently supported keywords include:
|
|||||||
// @require@ %-*.tst %-*.txt
|
// @require@ %-*.tst %-*.txt
|
||||||
|
|
||||||
@diff@ <first-list> <second-list>
|
@diff@ <first-list> <second-list>
|
||||||
|
After the testcase compiles and ran successfully, diff
|
||||||
|
<first-list> against <second-list>, these lists should have the
|
||||||
|
same length. The test fails if diff returns non-zero a pair of
|
||||||
|
files.
|
||||||
|
|
||||||
-- Gaby
|
-- Gaby
|
||||||
|
@ -19,22 +19,26 @@
|
|||||||
#
|
#
|
||||||
# This file is contributed by Gabriel Dos Reis <gdr@codesourcery.com>
|
# This file is contributed by Gabriel Dos Reis <gdr@codesourcery.com>
|
||||||
|
|
||||||
## This file contains support routines for dg.exp-based testsuite
|
## This file contains support routines for dg.exp based testsuite
|
||||||
## framework.
|
## framework.
|
||||||
|
|
||||||
## The global associative array lib_env contains the totality
|
## The global associative array lib_env contains the totality
|
||||||
## of options necessary to run testcases; the meanings of which are
|
## of options necessary to run testcases; the meanings of which are
|
||||||
## as follows:
|
## as follows:
|
||||||
## lib_env(CXX): The compiler used to run testcases
|
## lib_env(CXX) The compiler used to run testcases.
|
||||||
## lib_env(CXXFLAGS): Special flags passed to the compiler
|
## lib_env(CXXFLAGS) Special flags passed to the compiler.
|
||||||
## lib_env(INCLUDES):
|
## lib_env(INCLUDES) Includes options to pass to the compiler.
|
||||||
## lib_env(LDFLAGS): Additional library flags
|
## lib_env(LDFLAGS) Additional library flags.
|
||||||
## lib_env(LIBTOOL):
|
## lib_env(LIBTOOL) Path to the `libtool' script.
|
||||||
## lib_env(SRC_DIR):
|
## lib_env(SRC_DIR) Where V3 master source lives.
|
||||||
## lib_env(BUILD_DIR):
|
## lib_env(BUILD_DIR) Where V3 is built.
|
||||||
## lib_env(static):
|
## lib_env(static) Flags to pass to the linker to build a
|
||||||
## lib_env(shared):
|
## statically linked executable.
|
||||||
## lib_env(testcase_options):
|
## lib_env(shared) Flags to pass to the linker to build a
|
||||||
|
## dynamically linked executable.
|
||||||
|
## lib_env(testcase_options) Options specified by current testcase.
|
||||||
|
## These are specified through the @xxx@-keywords.
|
||||||
|
|
||||||
|
|
||||||
load_lib dg.exp
|
load_lib dg.exp
|
||||||
|
|
||||||
@ -55,8 +59,7 @@ proc libstdc++-dg-init { args } {
|
|||||||
# Set proper environment variables for the framework.
|
# Set proper environment variables for the framework.
|
||||||
libstdc++-setup-flags ${src-dir} ${build-dir}
|
libstdc++-setup-flags ${src-dir} ${build-dir}
|
||||||
|
|
||||||
# mkcheck.in used to output these information. Maybe we should
|
# mkcheck.in used to output these information.
|
||||||
# abandon that practice.
|
|
||||||
set output [remote_exec host $lib_env(CXX) -v]
|
set output [remote_exec host $lib_env(CXX) -v]
|
||||||
if { [lindex $output 0] == 0 } {
|
if { [lindex $output 0] == 0 } {
|
||||||
set output [lindex $output 1]
|
set output [lindex $output 1]
|
||||||
@ -69,14 +72,17 @@ proc libstdc++-dg-init { args } {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
## dg.exp callback. Called from dg-test to run PROGRAM images.
|
## dg.exp callback. Called from dg-test to run PROGRAM.
|
||||||
|
##
|
||||||
|
## This is the heart of the framework. For the time being, it is
|
||||||
|
## pretty much baroque, but it will improve as time goes.
|
||||||
proc libstdc++_load { prog } {
|
proc libstdc++_load { prog } {
|
||||||
global lib_env
|
global lib_env
|
||||||
set opts $lib_env(testcase_options)
|
set opts $lib_env(testcase_options)
|
||||||
set results [remote_load target $lib_env(LIBTOOL) "--mode=execute $prog"]
|
set results [remote_load target $lib_env(LIBTOOL) "--mode=execute $prog"]
|
||||||
|
|
||||||
if { [lindex $results 0] == "pass" && [info exists opts(diff)] } {
|
if { [lindex $results 0] == "pass" && [info exists opts(diff)] } {
|
||||||
# FIXME: We should first test for any mentioned output file here
|
# FIXME: We should first test for any mentioned @output@ file here
|
||||||
# before taking any other action.
|
# before taking any other action.
|
||||||
|
|
||||||
set firsts [glob -nocomplain [lindex $opts(diff) 0]]
|
set firsts [glob -nocomplain [lindex $opts(diff) 0]]
|
||||||
@ -84,7 +90,7 @@ proc libstdc++_load { prog } {
|
|||||||
foreach f $firsts s $seconds {
|
foreach f $firsts s $seconds {
|
||||||
if { [diff $f $s] == 0 } {
|
if { [diff $f $s] == 0 } {
|
||||||
# FIXME: Well we should report a message. But for the time
|
# FIXME: Well we should report a message. But for the time
|
||||||
# being, just pretend, there is nothing much to say.
|
# being, just pretend there is nothing much to say.
|
||||||
# Yes, that is silly, I know. But we need, first, to
|
# Yes, that is silly, I know. But we need, first, to
|
||||||
# to have a working framework.
|
# to have a working framework.
|
||||||
break
|
break
|
||||||
@ -129,20 +135,20 @@ proc libstdc++_runtest { testdirs } {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
# Make the appropriate test-dirs with accompaning .libs/
|
# Make the appropriate test-dirs with related .libs/ subdir
|
||||||
# to keep libtool happy.
|
# to keep libtool happy.
|
||||||
set td "$outdir/[dg-trim-dirname $srcdir $d]"
|
set td "$outdir/[dg-trim-dirname $srcdir $d]"
|
||||||
maybe-make-directory $td
|
maybe-make-directory $td
|
||||||
maybe-make-directory $td/.libs
|
maybe-make-directory $td/.libs
|
||||||
cd $td;
|
|
||||||
|
|
||||||
|
cd $td;
|
||||||
foreach testfile $testfiles {
|
foreach testfile $testfiles {
|
||||||
# We're not supposed to test this file, just skip it.
|
# If we're not supposed to test this file, just skip it.
|
||||||
if ![runtest_file_p $runtests $testfile] {
|
if ![runtest_file_p $runtests $testfile] {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
verbose "Testing [dg-trim-dirname $srcdir $testfile]"
|
# verbose "Testing [dg-trim-dirname $srcdir $testfile]"
|
||||||
libstdc++_do_test $testfile static
|
libstdc++_do_test $testfile static
|
||||||
libstdc++_do_test $testfile shared
|
libstdc++_do_test $testfile shared
|
||||||
}
|
}
|
||||||
@ -155,10 +161,8 @@ proc libstdc++_runtest { testdirs } {
|
|||||||
##
|
##
|
||||||
## TESTCASE is the file-name of the program to test;
|
## TESTCASE is the file-name of the program to test;
|
||||||
## COMPILE_TYPE is the kind of compilation to apply to TESTCASE;
|
## COMPILE_TYPE is the kind of compilation to apply to TESTCASE;
|
||||||
## current compilation kinds are: preprocessing(preprocess),
|
## current compilation kinds are: preprocess, compile,
|
||||||
## compiling-only-no-assembling-nor-linking(compile),
|
## assemble, link, run.
|
||||||
## compiling-and-assmbling-no-linking(assemble),
|
|
||||||
## linking-no-running(link), running(run).
|
|
||||||
proc libstdc++-dg-test { testfile compile_type additional-options } {
|
proc libstdc++-dg-test { testfile compile_type additional-options } {
|
||||||
global srcdir; global outdir
|
global srcdir; global outdir
|
||||||
global lib_env
|
global lib_env
|
||||||
@ -167,7 +171,7 @@ proc libstdc++-dg-test { testfile compile_type additional-options } {
|
|||||||
# Prepare for compilation output
|
# Prepare for compilation output
|
||||||
set comp_output ""
|
set comp_output ""
|
||||||
|
|
||||||
# By default, we want to use libtool to run tests.
|
# By default, we want to use libtool to compile and run tests.
|
||||||
set lt $lib_env(LIBTOOL)
|
set lt $lib_env(LIBTOOL)
|
||||||
set lt_args "--tag=CXX"
|
set lt_args "--tag=CXX"
|
||||||
|
|
||||||
@ -188,7 +192,7 @@ proc libstdc++-dg-test { testfile compile_type additional-options } {
|
|||||||
"run" -
|
"run" -
|
||||||
"link" {
|
"link" {
|
||||||
# If we're asked to run a testcase, then just do a `link'.
|
# If we're asked to run a testcase, then just do a `link'.
|
||||||
# The framework will load the program image latter through
|
# Later, the framework will load the program image through
|
||||||
# libstdc++_load callback.
|
# libstdc++_load callback.
|
||||||
if { $which_library == "static" } {
|
if { $which_library == "static" } {
|
||||||
append output_file ".st-exe"
|
append output_file ".st-exe"
|
||||||
@ -240,8 +244,7 @@ proc libstdc++-setup-flags {src-dir build-dir} {
|
|||||||
set lib_env(FLAGS) "$lib_env(CXX) -B$lib_env(BUILD_DIR)/ \
|
set lib_env(FLAGS) "$lib_env(CXX) -B$lib_env(BUILD_DIR)/ \
|
||||||
$lib_env(INCLUDES) $lib_env(CXXFLAGS)"
|
$lib_env(INCLUDES) $lib_env(CXXFLAGS)"
|
||||||
} else {
|
} else {
|
||||||
warning "$output"
|
perror "$output"
|
||||||
exit $status
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -253,6 +256,7 @@ proc maybe-make-directory {dir} {
|
|||||||
|
|
||||||
proc libstdc++_do_test { testfile lib } {
|
proc libstdc++_do_test { testfile lib } {
|
||||||
global which_library; set which_library $lib
|
global which_library; set which_library $lib
|
||||||
|
## Is it planed to handle -keep-output throught @xxx@-option
|
||||||
dg-test -keep-output $testfile "" ""
|
dg-test -keep-output $testfile "" ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user