2007-01-12 02:33:09 +00:00
#!/usr/bin/perl
# Bootstrap Samba and run a number of tests against it.
2010-09-23 15:14:57 -07:00
# Copyright (C) 2005-2010 Jelmer Vernooij <jelmer@samba.org>
2009-02-04 11:20:14 +01:00
# Copyright (C) 2007-2009 Stefan Metzmacher <metze@samba.org>
2009-03-25 15:40:39 +01:00
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
2007-03-05 21:28:55 +00:00
2007-01-12 02:33:09 +00:00
use strict ;
use FindBin qw( $RealBin $Script ) ;
use File::Spec ;
2010-04-10 22:20:12 +02:00
use File::Temp qw( tempfile ) ;
2007-01-13 16:08:58 +00:00
use Getopt::Long ;
2007-01-12 02:33:09 +00:00
use POSIX ;
2007-04-17 13:06:00 +00:00
use Cwd qw( abs_path ) ;
2007-03-05 21:28:55 +00:00
use lib "$RealBin" ;
2010-09-14 00:22:55 +02:00
use Subunit ;
2007-03-05 21:28:55 +00:00
use SocketWrapper ;
2007-01-12 02:33:09 +00:00
2010-09-13 23:22:35 +02:00
eval {
require Time::HiRes ;
2010-10-18 20:21:12 +04:00
Time::HiRes - > import ( "time" ) ;
2010-09-13 23:22:35 +02:00
} ;
2010-10-18 20:21:12 +04:00
if ( $@ ) {
print "You don't have Time::Hires installed !\n" ;
2010-09-13 23:22:35 +02:00
}
2007-03-05 21:28:55 +00:00
my $ opt_help = 0 ;
2011-10-26 15:21:11 +11:00
my $ opt_target = "samba" ;
2007-03-05 21:28:55 +00:00
my $ opt_quick = 0 ;
my $ opt_socket_wrapper = 0 ;
my $ opt_socket_wrapper_pcap = undef ;
2007-04-18 00:12:39 +00:00
my $ opt_socket_wrapper_keep_pcap = undef ;
2012-10-26 15:53:57 -08:00
my $ opt_random_order = 0 ;
2007-03-05 21:28:55 +00:00
my $ opt_one = 0 ;
2007-10-25 22:20:52 +02:00
my @ opt_exclude = ( ) ;
my @ opt_include = ( ) ;
2007-03-07 02:11:40 +00:00
my $ opt_testenv = 0 ;
2010-12-09 14:46:09 +01:00
my $ opt_list = 0 ;
2007-04-17 00:30:01 +00:00
my $ ldap = undef ;
2007-04-10 20:19:31 +00:00
my $ opt_resetup_env = undef ;
2011-04-15 12:27:30 +10:00
my $ opt_binary_mapping = "" ;
2010-04-08 16:16:15 +02:00
my $ opt_load_list = undef ;
2007-10-25 22:20:52 +02:00
my @ testlists = ( ) ;
2007-01-12 02:33:09 +00:00
2007-03-05 21:28:55 +00:00
my $ srcdir = "." ;
2011-04-15 12:41:22 +10:00
my $ bindir = "./bin" ;
2007-04-17 13:06:00 +00:00
my $ prefix = "./st" ;
2007-03-05 21:28:55 +00:00
2007-10-25 22:20:52 +02:00
my @ includes = ( ) ;
my @ excludes = ( ) ;
2007-03-05 21:28:55 +00:00
2010-09-28 07:40:27 +02:00
sub pipe_handler {
my $ sig = shift @ _ ;
print STDERR "Exiting early because of SIGPIPE.\n" ;
exit ( 1 ) ;
}
$ SIG { PIPE } = \ & pipe_handler ;
2007-09-02 00:24:38 +00:00
sub find_in_list ($$)
2007-01-12 02:33:09 +00:00
{
2007-09-02 00:24:38 +00:00
my ( $ list , $ fullname ) = @ _ ;
2007-01-12 02:33:09 +00:00
2007-09-02 00:24:38 +00:00
foreach ( @$ list ) {
if ( $ fullname =~ /$$_[0]/ ) {
return ( $$ _ [ 1 ] ) if ( $$ _ [ 1 ] ) ;
2009-06-05 16:10:12 +02:00
return "" ;
2007-09-02 00:24:38 +00:00
}
2007-04-18 14:18:33 +00:00
}
2007-01-12 02:33:09 +00:00
2007-09-02 00:24:38 +00:00
return undef ;
2007-03-05 21:28:55 +00:00
}
2007-09-02 00:24:38 +00:00
sub skip ($)
{
my ( $ name ) = @ _ ;
2007-10-25 22:20:52 +02:00
2007-10-31 14:48:48 +01:00
return find_in_list ( \ @ excludes , $ name ) ;
2007-03-05 22:24:21 +00:00
}
2007-04-18 14:02:26 +00:00
sub getlog_env ($) ;
2007-12-20 17:07:21 +01:00
sub setup_pcap ($)
2007-04-19 08:04:35 +00:00
{
2008-02-21 15:54:31 +01:00
my ( $ name ) = @ _ ;
2007-04-19 08:04:35 +00:00
return unless ( $ opt_socket_wrapper_pcap ) ;
return unless defined ( $ ENV { SOCKET_WRAPPER_PCAP_DIR } ) ;
2007-12-20 15:54:05 +01:00
my $ fname = $ name ;
2007-04-19 08:04:35 +00:00
$ fname =~ s%[^abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789\-]%_%g ;
2007-12-20 17:07:21 +01:00
my $ pcap_file = "$ENV{SOCKET_WRAPPER_PCAP_DIR}/$fname.pcap" ;
2007-04-19 08:04:35 +00:00
2007-12-20 17:07:21 +01:00
SocketWrapper:: setup_pcap ( $ pcap_file ) ;
return $ pcap_file ;
2007-04-19 08:04:35 +00:00
}
2009-06-04 13:49:11 +02:00
sub cleanup_pcap ($$)
2007-04-19 08:04:35 +00:00
{
2009-06-04 13:49:11 +02:00
my ( $ pcap_file , $ exitcode ) = @ _ ;
2007-04-19 08:04:35 +00:00
return unless ( $ opt_socket_wrapper_pcap ) ;
return if ( $ opt_socket_wrapper_keep_pcap ) ;
2009-06-04 13:49:11 +02:00
return unless ( $ exitcode == 0 ) ;
2007-12-20 17:07:21 +01:00
return unless defined ( $ pcap_file ) ;
2007-04-19 08:04:35 +00:00
2007-12-20 17:07:21 +01:00
unlink ( $ pcap_file ) ;
2007-04-19 08:04:35 +00:00
}
2010-01-11 09:36:48 +11:00
# expand strings from %ENV
sub expand_environment_strings ($)
{
my $ s = shift ;
# we use a reverse sort so we do the longer ones first
foreach my $ k ( sort { $ b cmp $ a } keys % ENV ) {
$ s =~ s/\$$k/$ENV{$k}/g ;
}
return $ s ;
}
2010-04-10 22:20:12 +02:00
sub run_testsuite ($$$$$)
2007-08-12 01:49:38 +00:00
{
2010-04-10 22:20:12 +02:00
my ( $ envname , $ name , $ cmd , $ i , $ totalsuites ) = @ _ ;
2007-12-20 17:07:21 +01:00
my $ pcap_file = setup_pcap ( $ name ) ;
2007-08-12 01:49:38 +00:00
2009-06-05 16:10:12 +02:00
Subunit:: start_testsuite ( $ name ) ;
2010-03-30 14:42:23 +02:00
Subunit:: progress_push ( ) ;
2009-06-17 21:37:49 +02:00
Subunit:: report_time ( time ( ) ) ;
2010-09-22 11:30:34 -07:00
system ( $ cmd ) ;
Subunit:: report_time ( time ( ) ) ;
Subunit:: progress_pop ( ) ;
2007-08-12 01:49:38 +00:00
2010-09-22 11:30:34 -07:00
if ( $? == - 1 ) {
2010-03-30 14:30:08 +02:00
Subunit:: progress_pop ( ) ;
2010-09-22 11:30:34 -07:00
Subunit:: end_testsuite ( $ name , "error" , "Unable to run $cmd: $!" ) ;
2010-10-19 14:49:17 +11:00
exit ( 1 ) ;
2010-09-22 11:30:34 -07:00
} elsif ( $? & 127 ) {
Subunit:: end_testsuite ( $ name , "error" ,
sprintf ( "%s died with signal %d, %s coredump\n" , $ cmd , ( $? & 127 ) , ( $? & 128 ) ? 'with' : 'without' ) ) ;
2010-09-23 15:14:57 -07:00
exit ( 1 ) ;
2008-04-15 23:52:06 +02:00
}
2010-09-22 11:30:34 -07:00
my $ exitcode = $? >> 8 ;
2007-12-20 15:54:02 +01:00
my $ envlog = getlog_env ( $ envname ) ;
2009-06-04 13:49:11 +02:00
if ( $ envlog ne "" ) {
2009-06-04 17:30:23 +02:00
print "envlog: $envlog\n" ;
2009-06-04 13:49:11 +02:00
}
2007-12-20 15:54:05 +01:00
2009-06-04 17:30:23 +02:00
print "command: $cmd\n" ;
2010-01-11 09:36:48 +11:00
printf "expanded command: %s\n" , expand_environment_strings ( $ cmd ) ;
2007-04-19 08:04:35 +00:00
2009-06-04 13:49:11 +02:00
if ( $ exitcode == 0 ) {
2009-06-05 16:32:52 +02:00
Subunit:: end_testsuite ( $ name , "success" ) ;
2007-12-20 15:54:02 +01:00
} else {
2009-06-05 16:32:52 +02:00
Subunit:: end_testsuite ( $ name , "failure" , "Exit code was $exitcode" ) ;
2007-12-20 15:54:02 +01:00
}
2007-04-19 08:04:35 +00:00
2009-06-04 13:49:11 +02:00
cleanup_pcap ( $ pcap_file , $ exitcode ) ;
2007-08-12 00:50:25 +00:00
2008-04-15 23:52:06 +02:00
if ( not $ opt_socket_wrapper_keep_pcap and defined ( $ pcap_file ) ) {
2009-06-04 13:49:11 +02:00
print "PCAP FILE: $pcap_file\n" ;
2007-08-12 00:50:25 +00:00
}
2007-04-19 08:04:35 +00:00
2009-06-04 13:49:11 +02:00
if ( $ exitcode != 0 ) {
2007-03-05 21:28:55 +00:00
exit ( 1 ) if ( $ opt_one ) ;
2007-01-12 02:33:09 +00:00
}
2007-04-18 00:12:39 +00:00
2009-06-04 13:49:11 +02:00
return $ exitcode ;
2007-01-12 02:33:09 +00:00
}
2007-01-13 16:08:58 +00:00
sub ShowHelp ()
{
print " Samba test runner
Copyright ( C ) Jelmer Vernooij <jelmer\@samba.org>
2009-02-04 11:20:14 +01:00
Copyright ( C ) Stefan Metzmacher <metze\@samba.org>
2007-01-13 16:08:58 +00:00
2008-10-19 14:50:25 +02:00
Usage: $ Script [ OPTIONS ] TESTNAME - REGEX
2007-01-13 16:08:58 +00:00
Generic options:
2007-01-13 20:02:10 +00:00
- - help this help page
2011-11-30 20:42:58 +01:00
- - target = samba [ 3 ] | win Samba version to target
- - testlist = FILE file to read available tests from
2007-03-05 21:28:55 +00:00
Paths:
- - prefix = DIR prefix to run tests in [ st ]
- - srcdir = DIR source directory [ . ]
2011-04-15 12:41:22 +10:00
- - bindir = DIR binaries directory [ . / bin ]
2007-03-05 21:28:55 +00:00
Target Specific:
2011-11-30 20:42:58 +01:00
- - socket - wrapper - pcap save traffic to pcap directories
2007-04-18 00:12:39 +00:00
- - socket - wrapper - keep - pcap keep all pcap files , not just those for tests that
failed
2007-01-13 20:02:10 +00:00
- - socket - wrapper enable socket wrapper
2007-04-18 00:12:39 +00:00
Samba4 Specific:
2008-10-19 14:50:25 +02:00
- - ldap = openldap | fedora - ds back samba onto specified ldap server
2007-03-05 21:28:55 +00:00
Behaviour:
2007-01-13 20:02:10 +00:00
- - quick run quick overall test
2007-01-14 04:32:11 +00:00
- - one abort when the first test fails
2010-12-09 13:37:13 +01:00
- - testenv run a shell in the requested test environment
2010-12-09 14:46:09 +01:00
- - list list available tests
2007-01-13 16:08:58 +00:00
" ;
exit ( 0 ) ;
}
my $ result = GetOptions (
2007-04-12 12:45:41 +00:00
'help|h|?' = > \ $ opt_help ,
2007-03-05 21:28:55 +00:00
'target=s' = > \ $ opt_target ,
'prefix=s' = > \ $ prefix ,
2007-01-13 20:02:10 +00:00
'socket-wrapper' = > \ $ opt_socket_wrapper ,
2007-04-18 00:12:39 +00:00
'socket-wrapper-pcap' = > \ $ opt_socket_wrapper_pcap ,
'socket-wrapper-keep-pcap' = > \ $ opt_socket_wrapper_keep_pcap ,
2007-01-14 04:32:11 +00:00
'quick' = > \ $ opt_quick ,
2007-03-05 21:28:55 +00:00
'one' = > \ $ opt_one ,
2007-10-25 22:20:52 +02:00
'exclude=s' = > \ @ opt_exclude ,
'include=s' = > \ @ opt_include ,
2007-03-05 21:28:55 +00:00
'srcdir=s' = > \ $ srcdir ,
2011-04-15 12:41:22 +10:00
'bindir=s' = > \ $ bindir ,
2007-03-21 15:57:07 +00:00
'testenv' = > \ $ opt_testenv ,
2010-12-09 14:46:09 +01:00
'list' = > \ $ opt_list ,
2007-04-17 00:30:01 +00:00
'ldap:s' = > \ $ ldap ,
2007-04-10 20:19:31 +00:00
'resetup-environment' = > \ $ opt_resetup_env ,
2010-04-08 16:16:15 +02:00
'testlist=s' = > \ @ testlists ,
2012-10-26 15:53:57 -08:00
'random-order' = > \ $ opt_random_order ,
2010-04-08 16:16:15 +02:00
'load-list=s' = > \ $ opt_load_list ,
2012-10-26 15:53:57 -08:00
'binary-mapping=s' = > \ $ opt_binary_mapping
2007-01-13 16:08:58 +00:00
) ;
2007-03-05 21:28:55 +00:00
exit ( 1 ) if ( not $ result ) ;
2007-01-13 16:08:58 +00:00
ShowHelp ( ) if ( $ opt_help ) ;
2007-01-12 02:33:09 +00:00
2010-12-09 14:46:09 +01:00
die ( "--list and --testenv are mutually exclusive" ) if ( $ opt_list and $ opt_testenv ) ;
2009-11-16 16:34:13 +01:00
# we want unbuffered output
$| = 1 ;
2009-08-14 13:04:21 +10:00
my @ tests = @ ARGV ;
2007-01-12 02:33:09 +00:00
2007-03-05 21:28:55 +00:00
# quick hack to disable rpc validation when using valgrind - its way too slow
unless ( defined ( $ ENV { VALGRIND } ) ) {
$ ENV { VALIDATE } = "validate" ;
2013-03-20 10:58:22 +01:00
$ ENV { MALLOC_CHECK_ } = 3 ;
2007-01-12 02:33:09 +00:00
}
2009-10-22 11:04:40 +11:00
# make all our python scripts unbuffered
$ ENV { PYTHONUNBUFFERED } = 1 ;
2009-02-02 12:43:20 +01:00
my $ bindir_abs = abs_path ( $ bindir ) ;
2007-04-17 00:30:01 +00:00
# Backwards compatibility:
if ( defined ( $ ENV { TEST_LDAP } ) and $ ENV { TEST_LDAP } eq "yes" ) {
2007-12-21 02:33:43 -06:00
if ( defined ( $ ENV { FEDORA_DS_ROOT } ) ) {
2007-05-29 13:06:08 +00:00
$ ldap = "fedora-ds" ;
2007-04-17 00:30:01 +00:00
} else {
$ ldap = "openldap" ;
}
2007-03-21 15:57:07 +00:00
}
my $ torture_maxtime = ( $ ENV { TORTURE_MAXTIME } or 1200 ) ;
if ( $ ldap ) {
# LDAP is slow
$ torture_maxtime *= 2 ;
}
2007-01-12 02:33:09 +00:00
$ prefix =~ s + // + / + ;
2007-04-17 13:06:00 +00:00
$ prefix =~ s + /./ + / + ;
$ prefix =~ s + / $+ + ;
2007-04-19 07:39:45 +00:00
die ( "using an empty prefix isn't allowed" ) unless $ prefix ne "" ;
2011-04-29 15:54:20 +10:00
# Ensure we have the test prefix around.
#
# We need restrictive
# permissions on this as some subdirectories in this tree will have
# wider permissions (ie 0777) and this would allow other users on the
# host to subvert the test process.
mkdir ( $ prefix , 0700 ) unless - d $ prefix ;
chmod 0700 , $ prefix ;
2007-04-19 07:39:45 +00:00
2007-04-17 13:06:00 +00:00
my $ prefix_abs = abs_path ( $ prefix ) ;
2010-10-01 01:31:06 +00:00
my $ tmpdir_abs = abs_path ( "$prefix/tmp" ) ;
mkdir ( $ tmpdir_abs , 0777 ) unless - d $ tmpdir_abs ;
2007-04-17 13:06:00 +00:00
my $ srcdir_abs = abs_path ( $ srcdir ) ;
die ( "using an empty absolute prefix isn't allowed" ) unless $ prefix_abs ne "" ;
die ( "using '/' as absolute prefix isn't allowed" ) unless $ prefix_abs ne "/" ;
2007-01-12 02:33:09 +00:00
$ ENV { PREFIX } = $ prefix ;
2008-02-07 23:47:18 +01:00
$ ENV { KRB5CCNAME } = "$prefix/krb5ticket" ;
2007-07-12 09:52:32 +00:00
$ ENV { PREFIX_ABS } = $ prefix_abs ;
2007-01-12 02:33:09 +00:00
$ ENV { SRCDIR } = $ srcdir ;
2007-07-12 09:52:32 +00:00
$ ENV { SRCDIR_ABS } = $ srcdir_abs ;
2011-02-21 16:01:44 +11:00
$ ENV { BINDIR } = $ bindir_abs ;
2007-01-12 02:33:09 +00:00
2007-10-08 15:22:26 +00:00
my $ tls_enabled = not $ opt_quick ;
2007-01-12 02:33:09 +00:00
$ ENV { TLS_ENABLED } = ( $ tls_enabled ? "yes" : "no" ) ;
2010-10-30 11:29:49 +11:00
2008-05-23 15:20:32 +02:00
sub prefix_pathvar ($$)
{
my ( $ name , $ newpath ) = @ _ ;
if ( defined ( $ ENV { $ name } ) ) {
$ ENV { $ name } = "$newpath:$ENV{$name}" ;
} else {
$ ENV { $ name } = $ newpath ;
}
2007-12-17 11:12:26 +01:00
}
2009-02-02 12:43:20 +01:00
prefix_pathvar ( "PKG_CONFIG_PATH" , "$bindir_abs/pkgconfig" ) ;
prefix_pathvar ( "PYTHONPATH" , "$bindir_abs/python" ) ;
2007-01-12 02:33:09 +00:00
2007-10-12 08:08:46 +02:00
if ( $ opt_socket_wrapper_keep_pcap ) {
# Socket wrapper keep pcap implies socket wrapper pcap
$ opt_socket_wrapper_pcap = 1 ;
}
2007-04-18 00:12:39 +00:00
2007-03-05 21:28:55 +00:00
if ( $ opt_socket_wrapper_pcap ) {
# Socket wrapper pcap implies socket wrapper
$ opt_socket_wrapper = 1 ;
}
2007-01-12 02:33:09 +00:00
2007-03-05 21:28:55 +00:00
my $ socket_wrapper_dir ;
2007-04-04 14:24:44 +00:00
if ( $ opt_socket_wrapper ) {
2010-01-19 00:55:48 +01:00
$ socket_wrapper_dir = SocketWrapper:: setup_dir ( "$prefix_abs/w" , $ opt_socket_wrapper_pcap ) ;
2007-03-05 21:28:55 +00:00
print "SOCKET_WRAPPER_DIR=$socket_wrapper_dir\n" ;
2011-11-27 19:53:35 +01:00
} elsif ( not $ opt_list ) {
2008-10-20 12:09:36 +02:00
unless ( $< == 0 ) {
2011-11-27 19:53:35 +01:00
warn ( "not using socket wrapper, but also not running as root. Will not be able to listen on proper ports" ) ;
2008-10-20 12:09:36 +02:00
}
2007-01-12 02:33:09 +00:00
}
2007-03-21 15:57:07 +00:00
my $ target ;
2007-09-30 09:07:07 +00:00
my $ testenv_default = "none" ;
2007-03-05 21:28:55 +00:00
2011-07-04 10:24:19 +02:00
my % binary_mapping = ( ) ;
2011-04-15 12:27:30 +10:00
if ( $ opt_binary_mapping ) {
my @ binmapping_list = split ( /,/ , $ opt_binary_mapping ) ;
foreach my $ mapping ( @ binmapping_list ) {
my ( $ bin , $ map ) = split ( /\:/ , $ mapping ) ;
$ binary_mapping { $ bin } = $ map ;
}
}
$ ENV { BINARY_MAPPING } = $ opt_binary_mapping ;
2011-04-19 13:50:40 +10:00
# After this many seconds, the server will self-terminate. All tests
# must terminate in this time, and testenv will only stay alive this
# long
my $ server_maxtime = 7500 ;
if ( defined ( $ ENV { SMBD_MAXTIME } ) and $ ENV { SMBD_MAXTIME } ne "" ) {
$ server_maxtime = $ ENV { SMBD_MAXTIME } ;
}
2011-11-30 20:42:14 +01:00
unless ( $ opt_list ) {
if ( $ opt_target eq "samba" ) {
if ( $ opt_socket_wrapper and `$bindir/smbd -b | grep SOCKET_WRAPPER` eq "" ) {
die ( "You must include --enable-socket-wrapper when compiling Samba in order to execute 'make test'. Exiting...." ) ;
}
$ testenv_default = "dc" ;
require target::Samba ;
2012-01-26 09:42:27 +11:00
$ target = new Samba ( $ bindir , \ % binary_mapping , $ ldap , $ srcdir , $ server_maxtime ) ;
2011-11-30 20:42:14 +01:00
} elsif ( $ opt_target eq "samba3" ) {
2011-11-30 22:57:18 +01:00
if ( $ opt_socket_wrapper and `$bindir/smbd -b | grep SOCKET_WRAPPER` eq "" ) {
2011-11-30 20:42:14 +01:00
die ( "You must include --enable-socket-wrapper when compiling Samba in order to execute 'make test'. Exiting...." ) ;
}
$ testenv_default = "member" ;
require target::Samba3 ;
2012-01-26 09:42:27 +11:00
$ target = new Samba3 ( $ bindir , \ % binary_mapping , $ srcdir_abs , $ server_maxtime ) ;
2007-04-18 00:12:39 +00:00
}
2007-01-12 02:33:09 +00:00
}
2007-09-02 00:24:38 +00:00
sub read_test_regexes ($)
{
my ( $ name ) = @ _ ;
my @ ret = ( ) ;
open ( LF , "<$name" ) or die ( "unable to read $name: $!" ) ;
while ( <LF> ) {
2007-03-05 21:28:55 +00:00
chomp ;
2008-05-29 18:17:42 +02:00
next if ( /^#/ ) ;
2007-10-26 21:15:04 +02:00
if ( /^(.*?)([ \t]+)\#([\t ]*)(.*?)$/ ) {
push ( @ ret , [ $ 1 , $ 4 ] ) ;
2007-09-02 00:24:38 +00:00
} else {
2007-10-26 21:15:04 +02:00
s/^(.*?)([ \t]+)\#([\t ]*)(.*?)$// ;
2007-09-02 00:24:38 +00:00
push ( @ ret , [ $ _ , undef ] ) ;
}
}
close ( LF ) ;
return @ ret ;
}
2007-10-25 22:20:52 +02:00
foreach ( @ opt_exclude ) {
push ( @ excludes , read_test_regexes ( $ _ ) ) ;
}
foreach ( @ opt_include ) {
push ( @ includes , read_test_regexes ( $ _ ) ) ;
2007-03-05 22:24:21 +00:00
}
2010-06-16 11:02:48 +02:00
my $ interfaces = join ( ',' , ( "127.0.0.11/8" ,
"127.0.0.12/8" ,
"127.0.0.13/8" ,
"127.0.0.14/8" ,
"127.0.0.15/8" ,
"127.0.0.16/8" ) ) ;
2007-01-12 02:33:09 +00:00
2010-09-23 01:42:57 -07:00
my $ clientdir = "$prefix_abs/client" ;
my $ conffile = "$clientdir/client.conf" ;
2008-10-20 10:53:26 +02:00
$ ENV { SMB_CONF_PATH } = $ conffile ;
2007-04-10 20:19:31 +00:00
2010-09-23 01:42:57 -07:00
sub write_clientconf ($$$)
2007-04-10 20:19:31 +00:00
{
2010-09-23 01:42:57 -07:00
my ( $ conffile , $ clientdir , $ vars ) = @ _ ;
2007-04-10 20:19:31 +00:00
2010-09-23 01:42:57 -07:00
mkdir ( "$clientdir" , 0777 ) unless - d "$clientdir" ;
2010-09-04 18:24:02 +02:00
2010-09-23 01:42:57 -07:00
if ( - d "$clientdir/private" ) {
unlink <$clientdir/private/*> ;
2007-04-11 12:10:40 +00:00
} else {
2010-09-23 01:42:57 -07:00
mkdir ( "$clientdir/private" , 0777 ) ;
2007-04-11 12:10:40 +00:00
}
2010-09-23 01:42:57 -07:00
if ( - d "$clientdir/lockdir" ) {
unlink <$clientdir/lockdir/*> ;
2009-01-28 11:59:26 +01:00
} else {
2010-09-23 01:42:57 -07:00
mkdir ( "$clientdir/lockdir" , 0777 ) ;
2009-01-28 11:59:26 +01:00
}
2011-07-12 13:12:50 +02:00
if ( - d "$clientdir/statedir" ) {
unlink <$clientdir/statedir/*> ;
} else {
mkdir ( "$clientdir/statedir" , 0777 ) ;
}
if ( - d "$clientdir/cachedir" ) {
unlink <$clientdir/cachedir/*> ;
} else {
mkdir ( "$clientdir/cachedir" , 0777 ) ;
}
2011-05-22 19:40:19 +02:00
# this is ugly, but the ncalrpcdir needs exactly 0755
# otherwise tests fail.
my $ mask = umask ;
umask 0022 ;
if ( - d "$clientdir/ncalrpcdir/np" ) {
unlink <$clientdir/ncalrpcdir/np/*> ;
2011-07-04 17:01:29 +02:00
rmdir "$clientdir/ncalrpcdir/np" ;
2011-05-22 19:40:19 +02:00
}
2010-09-23 01:42:57 -07:00
if ( - d "$clientdir/ncalrpcdir" ) {
unlink <$clientdir/ncalrpcdir/*> ;
2011-07-04 17:01:29 +02:00
rmdir "$clientdir/ncalrpcdir" ;
2009-05-01 18:18:31 +02:00
}
2011-05-22 19:40:19 +02:00
mkdir ( "$clientdir/ncalrpcdir" , 0755 ) ;
umask $ mask ;
2009-05-01 18:18:31 +02:00
2007-04-10 20:19:31 +00:00
open ( CF , ">$conffile" ) ;
print CF "[global]\n" ;
2007-04-12 12:45:41 +00:00
print CF "\tnetbios name = client\n" ;
2007-04-10 20:19:31 +00:00
if ( defined ( $ vars - > { DOMAIN } ) ) {
print CF "\tworkgroup = $vars->{DOMAIN}\n" ;
}
if ( defined ( $ vars - > { REALM } ) ) {
print CF "\trealm = $vars->{REALM}\n" ;
}
2008-02-19 18:03:02 +01:00
if ( $ opt_socket_wrapper ) {
print CF "\tinterfaces = $interfaces\n" ;
}
2007-04-10 20:19:31 +00:00
print CF "
2010-09-23 01:42:57 -07:00
private dir = $ clientdir / private
lock dir = $ clientdir / lockdir
2011-07-20 13:02:22 +02:00
state directory = $ clientdir / statedir
cache directory = $ clientdir / cachedir
2010-09-23 01:42:57 -07:00
ncalrpc dir = $ clientdir / ncalrpcdir
2011-04-07 12:33:34 +10:00
name resolve order = file bcast
2011-07-13 17:26:31 +10:00
panic action = $ RealBin / gdb_backtrace \ % d
2007-04-09 00:53:05 +00:00
max xmit = 32 K
notify:inotify = false
ldb:nosync = true
system : anonymous = true
2008-10-31 15:07:34 +01:00
client lanman auth = Yes
2010-09-02 16:46:20 +10:00
log level = 1
2010-09-23 01:42:57 -07:00
torture:basedir = $ clientdir
2007-04-11 12:10:40 +00:00
#We don't want to pass our self-tests if the PAC code is wrong
2007-04-09 00:53:05 +00:00
gensec:require_pac = true
2010-03-11 13:04:56 +01:00
resolv:host file = $ prefix_abs / dns_host_file
2010-09-23 17:32:46 +10:00
#We don't want to run 'speed' tests for very long
torture:timelimit = 1
2007-04-09 00:53:05 +00:00
" ;
2007-04-10 20:19:31 +00:00
close ( CF ) ;
}
2007-01-14 04:32:11 +00:00
my @ todo = ( ) ;
2007-01-12 02:33:09 +00:00
2009-08-14 13:04:21 +10:00
sub should_run_test ($)
{
my $ name = shift ;
if ( $# tests == - 1 ) {
return 1 ;
}
for ( my $ i = 0 ; $ i <= $# tests ; $ i + + ) {
if ( $ name =~ /$tests[$i]/i ) {
return 1 ;
}
}
return 0 ;
}
2007-09-02 11:16:16 +00:00
sub read_testlist ($)
{
my ( $ filename ) = @ _ ;
my @ ret = ( ) ;
open ( IN , $ filename ) or die ( "Unable to open $filename: $!" ) ;
while ( <IN> ) {
2010-09-21 20:58:23 -07:00
if ( /-- TEST(-LOADLIST|-IDLIST|) --\n/ ) {
2010-04-12 16:11:31 +02:00
my $ supports_loadlist = ( defined ( $ 1 ) and $ 1 eq "-LOADLIST" ) ;
2010-09-21 20:36:50 -07:00
my $ supports_idlist = ( defined ( $ 1 ) and $ 1 eq "-IDLIST" ) ;
2007-09-02 11:16:16 +00:00
my $ name = <IN> ;
$ name =~ s/\n//g ;
my $ env = <IN> ;
$ env =~ s/\n//g ;
my $ cmdline = <IN> ;
$ cmdline =~ s/\n//g ;
2009-08-14 13:04:21 +10:00
if ( should_run_test ( $ name ) == 1 ) {
2010-09-21 20:36:50 -07:00
push ( @ ret , [ $ name , $ env , $ cmdline , $ supports_loadlist , $ supports_idlist ] ) ;
2007-09-02 11:16:16 +00:00
}
} else {
print ;
}
}
close ( IN ) or die ( "Error creating recipe" ) ;
return @ ret ;
}
2007-10-25 22:20:52 +02:00
if ( $# testlists == - 1 ) {
die ( "No testlists specified" ) ;
2007-03-21 15:57:07 +00:00
}
2007-09-02 11:16:16 +00:00
2008-10-19 16:07:00 +02:00
$ ENV { SELFTEST_PREFIX } = "$prefix_abs" ;
2010-10-01 01:31:06 +00:00
$ ENV { SELFTEST_TMPDIR } = "$tmpdir_abs" ;
2010-12-27 12:57:18 +01:00
$ ENV { TEST_DATA_PREFIX } = "$tmpdir_abs" ;
2008-10-19 16:07:00 +02:00
if ( $ opt_socket_wrapper ) {
$ ENV { SELFTEST_INTERFACES } = $ interfaces ;
} else {
$ ENV { SELFTEST_INTERFACES } = "" ;
}
if ( $ opt_quick ) {
$ ENV { SELFTEST_QUICK } = "1" ;
} else {
$ ENV { SELFTEST_QUICK } = "" ;
}
$ ENV { SELFTEST_MAXTIME } = $ torture_maxtime ;
2007-12-20 15:54:05 +01:00
my @ available = ( ) ;
foreach my $ fn ( @ testlists ) {
foreach ( read_testlist ( $ fn ) ) {
my $ name = $$ _ [ 0 ] ;
2009-06-05 16:10:12 +02:00
next if ( @ includes and not defined ( find_in_list ( \ @ includes , $ name ) ) ) ;
2007-12-20 15:54:05 +01:00
push ( @ available , $ _ ) ;
}
}
2010-04-08 16:16:15 +02:00
my $ restricted = undef ;
2010-09-05 03:16:48 +02:00
my $ restricted_used = { } ;
2010-04-08 16:16:15 +02:00
if ( $ opt_load_list ) {
$ restricted = [] ;
open ( LOAD_LIST , "<$opt_load_list" ) or die ( "Unable to open $opt_load_list" ) ;
2010-09-05 02:20:56 +02:00
while ( <LOAD_LIST> ) {
chomp ;
2010-04-08 16:16:15 +02:00
push ( @$ restricted , $ _ ) ;
}
close ( LOAD_LIST ) ;
}
my $ individual_tests = undef ;
$ individual_tests = { } ;
foreach my $ testsuite ( @ available ) {
my $ name = $$ testsuite [ 0 ] ;
2007-12-20 15:54:05 +01:00
my $ skipreason = skip ( $ name ) ;
2010-09-22 19:28:02 -07:00
if ( defined ( $ restricted ) ) {
2010-04-08 16:16:15 +02:00
# Find the testsuite for this test
2010-09-05 03:16:48 +02:00
my $ match = undef ;
2010-04-08 16:16:15 +02:00
foreach my $ r ( @$ restricted ) {
if ( $ r eq $ name ) {
$ individual_tests - > { $ name } = [] ;
2010-09-05 03:16:48 +02:00
$ match = $ r ;
$ restricted_used - > { $ r } = 1 ;
2010-09-21 17:35:53 -07:00
} elsif ( substr ( $ r , 0 , length ( $ name ) + 1 ) eq "$name." ) {
2010-09-22 19:21:58 -07:00
push ( @ { $ individual_tests - > { $ name } } , $ r ) ;
2010-09-05 03:16:48 +02:00
$ match = $ r ;
$ restricted_used - > { $ r } = 1 ;
2010-04-08 16:16:15 +02:00
}
}
2010-09-22 19:28:02 -07:00
if ( $ match ) {
if ( defined ( $ skipreason ) ) {
2011-11-27 19:53:35 +01:00
if ( not $ opt_list ) {
2010-09-22 19:28:02 -07:00
Subunit:: skip_testsuite ( $ name , $ skipreason ) ;
2011-11-27 19:53:35 +01:00
}
2010-09-22 19:28:02 -07:00
} else {
push ( @ todo , $ testsuite ) ;
}
}
} elsif ( defined ( $ skipreason ) ) {
2011-11-27 19:53:35 +01:00
if ( not $ opt_list ) {
Subunit:: skip_testsuite ( $ name , $ skipreason ) ;
}
2007-12-20 15:54:05 +01:00
} else {
2010-09-22 19:28:02 -07:00
push ( @ todo , $ testsuite ) ;
2007-10-31 14:48:48 +01:00
}
2007-01-14 04:32:11 +00:00
}
2010-09-05 02:20:56 +02:00
if ( defined ( $ restricted ) ) {
foreach ( @$ restricted ) {
2010-09-05 03:16:48 +02:00
unless ( defined ( $ restricted_used - > { $ _ } ) ) {
2010-09-05 02:20:56 +02:00
print "No test or testsuite found matching $_\n" ;
}
}
} elsif ( $# todo == - 1 ) {
2007-10-08 14:57:11 +00:00
print STDERR "No tests to run\n" ;
exit ( 1 ) ;
2010-09-05 02:20:56 +02:00
}
2007-10-08 14:57:11 +00:00
2007-03-05 21:28:55 +00:00
my $ suitestotal = $# todo + 1 ;
2010-09-22 19:28:02 -07:00
2011-11-27 19:53:35 +01:00
unless ( $ opt_list ) {
Subunit:: progress ( $ suitestotal ) ;
Subunit:: report_time ( time ( ) ) ;
}
2010-09-22 19:28:02 -07:00
2007-01-14 04:32:11 +00:00
my $ i = 0 ;
$| = 1 ;
2007-04-10 20:19:31 +00:00
my % running_envs = ( ) ;
2007-03-05 21:28:55 +00:00
2009-01-30 08:25:27 +01:00
sub get_running_env ($)
{
my ( $ name ) = @ _ ;
my $ envname = $ name ;
$ envname =~ s/:.*// ;
return $ running_envs { $ envname } ;
}
2007-04-28 08:48:11 +00:00
my @ exported_envvars = (
# domain stuff
"DOMAIN" ,
"REALM" ,
2007-04-28 08:57:06 +00:00
# domain controller stuff
"DC_SERVER" ,
"DC_SERVER_IP" ,
"DC_NETBIOSNAME" ,
"DC_NETBIOSALIAS" ,
2010-03-12 10:36:12 +11:00
# domain member
2010-02-19 15:56:30 +11:00
"MEMBER_SERVER" ,
"MEMBER_SERVER_IP" ,
"MEMBER_NETBIOSNAME" ,
"MEMBER_NETBIOSALIAS" ,
2010-03-12 10:36:12 +11:00
# rpc proxy controller stuff
2010-02-19 15:56:30 +11:00
"RPC_PROXY_SERVER" ,
"RPC_PROXY_SERVER_IP" ,
"RPC_PROXY_NETBIOSNAME" ,
"RPC_PROXY_NETBIOSALIAS" ,
2010-03-12 10:36:12 +11:00
# domain controller stuff for Vampired DC
"VAMPIRE_DC_SERVER" ,
"VAMPIRE_DC_SERVER_IP" ,
"VAMPIRE_DC_NETBIOSNAME" ,
"VAMPIRE_DC_NETBIOSALIAS" ,
2013-05-13 09:16:24 -07:00
"PROMOTED_DC_SERVER" ,
"PROMOTED_DC_SERVER_IP" ,
"PROMOTED_DC_NETBIOSNAME" ,
"PROMOTED_DC_NETBIOSALIAS" ,
2007-04-28 08:48:11 +00:00
# server stuff
"SERVER" ,
2007-04-28 08:57:06 +00:00
"SERVER_IP" ,
2007-04-28 08:48:11 +00:00
"NETBIOSNAME" ,
2007-04-28 08:57:06 +00:00
"NETBIOSALIAS" ,
2007-04-28 08:48:11 +00:00
# user stuff
"USERNAME" ,
2010-06-02 15:35:33 +02:00
"USERID" ,
2007-04-28 08:48:11 +00:00
"PASSWORD" ,
2007-04-28 08:57:06 +00:00
"DC_USERNAME" ,
"DC_PASSWORD" ,
2007-04-28 08:48:11 +00:00
# misc stuff
2007-07-13 08:38:51 +00:00
"KRB5_CONFIG" ,
2007-10-02 15:56:33 +00:00
"WINBINDD_SOCKET_DIR" ,
2010-06-02 15:35:33 +02:00
"WINBINDD_PRIV_PIPE_DIR" ,
2011-01-07 21:28:45 -08:00
"NMBD_SOCKET_DIR" ,
2012-06-27 12:40:59 +10:00
"LOCAL_PATH" ,
# nss_wrapper
"NSS_WRAPPER_PASSWD" ,
2012-12-28 12:36:06 +11:00
"NSS_WRAPPER_GROUP" ,
2012-06-27 12:40:59 +10:00
2012-12-28 12:36:06 +11:00
# UID/GID for rfc2307 mapping tests
"UID_RFC2307TEST" ,
"GID_RFC2307TEST"
2007-04-28 08:48:11 +00:00
) ;
2007-09-02 17:13:56 +00:00
$ SIG { INT } = $ SIG { QUIT } = $ SIG { TERM } = sub {
my $ signame = shift ;
teardown_env ( $ _ ) foreach ( keys % running_envs ) ;
die ( "Received signal $signame" ) ;
} ;
2010-09-23 10:28:22 -07:00
sub setup_env ($$)
2007-04-10 20:19:31 +00:00
{
2010-09-23 10:28:22 -07:00
my ( $ name , $ prefix ) = @ _ ;
2009-01-30 08:25:27 +01:00
my $ testenv_vars = undef ;
my $ envname = $ name ;
my $ option = $ name ;
$ envname =~ s/:.*// ;
2009-01-30 10:01:48 +01:00
$ option =~ s/^[^:]*// ;
$ option =~ s/^:// ;
2009-01-30 08:25:27 +01:00
$ option = "client" if $ option eq "" ;
2007-04-08 23:55:01 +00:00
2007-04-19 15:05:59 +00:00
if ( $ envname eq "none" ) {
2009-01-30 10:29:39 +01:00
$ testenv_vars = { } ;
2009-01-30 08:25:27 +01:00
} elsif ( defined ( get_running_env ( $ envname ) ) ) {
$ testenv_vars = get_running_env ( $ envname ) ;
2011-04-18 13:44:36 +10:00
if ( not $ testenv_vars - > { target } - > check_env ( $ testenv_vars ) ) {
print $ testenv_vars - > { target } - > getlog_env ( $ testenv_vars ) ;
2007-04-19 14:54:09 +00:00
$ testenv_vars = undef ;
}
2007-04-10 20:19:31 +00:00
} else {
2007-04-11 03:45:39 +00:00
$ testenv_vars = $ target - > setup_env ( $ envname , $ prefix ) ;
2012-02-13 12:14:57 +11:00
if ( defined ( $ testenv_vars ) and $ testenv_vars eq "UNKNOWN" ) {
return $ testenv_vars ;
} elsif ( defined ( $ testenv_vars ) && not defined ( $ testenv_vars - > { target } ) ) {
2011-04-19 12:43:54 +10:00
$ testenv_vars - > { target } = $ target ;
}
if ( not defined ( $ testenv_vars ) ) {
2012-02-23 16:34:47 +11:00
warn ( "$opt_target can't start up known environment '$envname'" ) ;
2011-04-18 13:44:36 +10:00
}
2007-04-10 20:19:31 +00:00
}
2007-04-19 14:54:09 +00:00
2011-04-19 12:43:54 +10:00
2007-04-19 14:54:09 +00:00
return undef unless defined ( $ testenv_vars ) ;
2007-09-02 17:13:56 +00:00
$ running_envs { $ envname } = $ testenv_vars ;
2009-01-30 08:25:27 +01:00
if ( $ option eq "local" ) {
SocketWrapper:: set_default_iface ( $ testenv_vars - > { SOCKET_WRAPPER_DEFAULT_IFACE } ) ;
$ ENV { SMB_CONF_PATH } = $ testenv_vars - > { SERVERCONFFILE } ;
} elsif ( $ option eq "client" ) {
2010-06-16 11:02:48 +02:00
SocketWrapper:: set_default_iface ( 11 ) ;
2010-09-23 01:42:57 -07:00
write_clientconf ( $ conffile , $ clientdir , $ testenv_vars ) ;
2009-01-30 08:25:27 +01:00
$ ENV { SMB_CONF_PATH } = $ conffile ;
} else {
die ( "Unknown option[$option] for envname[$envname]" ) ;
}
2007-04-28 08:48:11 +00:00
foreach ( @ exported_envvars ) {
2007-04-10 20:19:31 +00:00
if ( defined ( $ testenv_vars - > { $ _ } ) ) {
$ ENV { $ _ } = $ testenv_vars - > { $ _ } ;
} else {
delete $ ENV { $ _ } ;
}
}
return $ testenv_vars ;
}
2007-04-28 08:48:11 +00:00
sub exported_envvars_str ($)
{
my ( $ testenv_vars ) = @ _ ;
my $ out = "" ;
foreach ( @ exported_envvars ) {
next unless defined ( $ testenv_vars - > { $ _ } ) ;
$ out . = $ _ . "=" . $ testenv_vars - > { $ _ } . "\n" ;
}
return $ out ;
}
2007-04-18 14:02:26 +00:00
sub getlog_env ($)
{
my ( $ envname ) = @ _ ;
return "" if ( $ envname eq "none" ) ;
2011-04-18 13:44:36 +10:00
my $ env = get_running_env ( $ envname ) ;
return $ env - > { target } - > getlog_env ( $ env ) ;
2007-04-18 14:02:26 +00:00
}
2007-04-19 14:54:09 +00:00
sub check_env ($)
{
my ( $ envname ) = @ _ ;
return 1 if ( $ envname eq "none" ) ;
2011-04-18 13:44:36 +10:00
my $ env = get_running_env ( $ envname ) ;
return $ env - > { target } - > check_env ( $ env ) ;
2007-04-19 14:54:09 +00:00
}
2007-04-10 20:19:31 +00:00
sub teardown_env ($)
{
my ( $ envname ) = @ _ ;
2007-04-17 00:30:01 +00:00
return if ( $ envname eq "none" ) ;
2011-04-18 13:44:36 +10:00
my $ env = get_running_env ( $ envname ) ;
$ env - > { target } - > teardown_env ( $ env ) ;
2007-04-10 20:19:31 +00:00
delete $ running_envs { $ envname } ;
}
2007-04-16 03:16:23 +00:00
2010-03-12 10:45:16 +11:00
# This 'global' file needs to be empty when we start
unlink ( "$prefix_abs/dns_host_file" ) ;
2012-10-26 15:53:57 -08:00
if ( $ opt_random_order ) {
require List::Util ;
my @ newtodo = List::Util:: shuffle ( @ todo ) ;
@ todo = @ newtodo ;
}
2007-03-07 02:11:40 +00:00
if ( $ opt_testenv ) {
2007-04-28 08:48:11 +00:00
my $ testenv_name = $ ENV { SELFTEST_TESTENV } ;
2007-09-30 09:07:07 +00:00
$ testenv_name = $ testenv_default unless defined ( $ testenv_name ) ;
2007-04-28 08:48:11 +00:00
2010-09-23 10:28:22 -07:00
my $ testenv_vars = setup_env ( $ testenv_name , $ prefix ) ;
2007-04-28 08:48:11 +00:00
2013-07-03 12:49:43 -07:00
if ( not $ testenv_vars or $ testenv_vars eq "UNKNOWN" ) {
die ( "Unable to setup environment $testenv_name" ) ;
}
2010-09-14 14:36:56 +02:00
2007-04-08 23:55:01 +00:00
$ ENV { PIDDIR } = $ testenv_vars - > { PIDDIR } ;
2010-10-02 14:23:43 -07:00
$ ENV { ENVNAME } = $ testenv_name ;
2007-04-28 08:48:11 +00:00
my $ envvarstr = exported_envvars_str ( $ testenv_vars ) ;
2013-01-03 14:33:45 -08:00
my @ term_args = ( " echo - e \ "
2007-04-28 08:48:11 +00:00
Welcome to the Samba4 Test environment '$testenv_name'
2007-03-07 02:11:40 +00:00
This matches the client environment used in make test
2008-09-24 03:16:15 +02:00
server is pid `cat \$PIDDIR/samba.pid`
2007-03-07 02:11:40 +00:00
Some useful environment variables:
TORTURE_OPTIONS = \ $ TORTURE_OPTIONS
2009-01-30 11:03:45 +01:00
SMB_CONF_PATH = \ $ SMB_CONF_PATH
2007-04-28 08:48:11 +00:00
$ envvarstr
2012-09-29 20:40:13 +10:00
\ " && LD_LIBRARY_PATH=$ENV{LD_LIBRARY_PATH} bash" ) ;
2013-01-03 14:33:45 -08:00
my @ term = ( ) ;
if ( $ ENV { TERMINAL } ) {
@ term = ( $ ENV { TERMINAL } ) ;
} else {
@ term = ( "xterm" , "-e" ) ;
unshift ( @ term_args , ( "bash" , "-c" ) ) ;
}
2012-09-29 20:40:13 +10:00
system ( @ term , @ term_args ) ;
2007-04-28 08:48:11 +00:00
teardown_env ( $ testenv_name ) ;
2010-12-09 14:46:09 +01:00
} elsif ( $ opt_list ) {
foreach ( @ todo ) {
my $ cmd = $$ _ [ 2 ] ;
my $ name = $$ _ [ 0 ] ;
my $ envname = $$ _ [ 1 ] ;
2010-12-09 15:35:23 +01:00
unless ( $ cmd =~ /\$LISTOPT/ ) {
2010-12-09 14:46:09 +01:00
warn ( "Unable to list tests in $name" ) ;
next ;
}
2010-12-11 18:21:58 +01:00
$ cmd =~ s/\$LISTOPT/--list/g ;
2010-12-09 14:46:09 +01:00
system ( $ cmd ) ;
2010-12-09 16:48:24 +01:00
if ( $? == - 1 ) {
die ( "Unable to run $cmd: $!" ) ;
} elsif ( $? & 127 ) {
2012-12-15 22:16:28 +01:00
die ( sprintf ( "%s died with signal %d, %s coredump\n" , $ cmd , ( $? & 127 ) , ( $? & 128 ) ? 'with' : 'without' ) ) ;
2010-12-09 16:48:24 +01:00
}
my $ exitcode = $? >> 8 ;
if ( $ exitcode != 0 ) {
die ( "$cmd exited with exit code $exitcode" ) ;
}
2010-12-09 14:46:09 +01:00
}
2007-03-07 02:11:40 +00:00
} else {
foreach ( @ todo ) {
$ i + + ;
2007-03-21 15:57:07 +00:00
my $ cmd = $$ _ [ 2 ] ;
2007-03-07 02:11:40 +00:00
my $ name = $$ _ [ 0 ] ;
2007-03-21 15:57:07 +00:00
my $ envname = $$ _ [ 1 ] ;
2010-09-05 02:20:56 +02:00
2010-09-23 10:28:22 -07:00
my $ envvars = setup_env ( $ envname , $ prefix ) ;
2007-04-19 14:54:09 +00:00
if ( not defined ( $ envvars ) ) {
2010-09-14 14:36:56 +02:00
Subunit:: start_testsuite ( $ name ) ;
Subunit:: end_testsuite ( $ name , "error" ,
2010-10-19 14:49:17 +11:00
"unable to set up environment $envname - exiting" ) ;
2007-04-19 14:54:09 +00:00
next ;
2012-02-13 12:14:57 +11:00
} elsif ( $ envvars eq "UNKNOWN" ) {
Subunit:: start_testsuite ( $ name ) ;
Subunit:: end_testsuite ( $ name , "skip" ,
"environment $envname is unknown in this test backend - skipping" ) ;
next ;
2007-04-19 14:54:09 +00:00
}
2007-03-21 15:57:07 +00:00
2010-06-25 02:35:29 +02:00
# Generate a file with the individual tests to run, if the
# test runner for this test suite supports it.
2010-09-21 20:36:50 -07:00
if ( $ individual_tests and $ individual_tests - > { $ name } ) {
if ( $$ _ [ 3 ] ) {
my ( $ fh , $ listid_file ) = tempfile ( UNLINK = > 0 ) ;
foreach my $ test ( @ { $ individual_tests - > { $ name } } ) {
2010-09-22 19:21:58 -07:00
print $ fh substr ( $ test , length ( $ name ) + 1 ) . "\n" ;
2010-09-21 20:36:50 -07:00
}
2010-09-22 19:08:37 -07:00
$ cmd =~ s/\$LOADLIST/--load-list=$listid_file/g ;
2010-09-21 20:36:50 -07:00
} elsif ( $$ _ [ 4 ] ) {
2010-09-21 20:58:23 -07:00
$ cmd =~ s/\s+[^\s]+\s*$// ;
$ cmd . = " " . join ( ' ' , @ { $ individual_tests - > { $ name } } ) ;
2010-04-10 22:20:12 +02:00
}
}
2010-09-14 14:36:56 +02:00
run_testsuite ( $ envname , $ name , $ cmd , $ i , $ suitestotal ) ;
2007-03-21 15:57:07 +00:00
2007-04-10 20:19:31 +00:00
teardown_env ( $ envname ) if ( $ opt_resetup_env ) ;
2007-01-14 04:32:11 +00:00
}
2007-01-13 20:02:10 +00:00
}
2007-01-12 02:33:09 +00:00
2007-01-14 04:32:11 +00:00
print "\n" ;
2007-04-10 20:19:31 +00:00
teardown_env ( $ _ ) foreach ( keys % running_envs ) ;
my $ failed = 0 ;
2007-01-12 02:33:09 +00:00
# if there were any valgrind failures, show them
foreach ( <$prefix/valgrind.log*> ) {
next unless ( - s $ _ ) ;
2009-10-19 22:58:23 +11:00
print "VALGRIND FAILURE\n" ;
$ failed + + ;
system ( "cat $_" ) ;
2007-01-12 02:33:09 +00:00
}
2009-06-04 13:49:11 +02:00
exit 0 ;