Commit 359c4c28 authored by Sergei Golubchik's avatar Sergei Golubchik

small cleanup

parent 38fb6c55
...@@ -35,6 +35,19 @@ sub new { ...@@ -35,6 +35,19 @@ sub new {
return $self; return $self;
} }
sub copy {
my $self= shift;
my $copy= My::Test->new();
while (my ($key, $value) = each(%$self)) {
if (ref $value eq "ARRAY") {
push(@{$copy->{$key}}, @$value);
} else {
$copy->{$key}= $value;
}
}
$copy;
}
sub fullname { sub fullname {
my ($self)= @_; my ($self)= @_;
$self->{name} . (defined $self->{combinations} $self->{name} . (defined $self->{combinations}
......
...@@ -337,46 +337,23 @@ sub collect_one_suite ...@@ -337,46 +337,23 @@ sub collect_one_suite
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
my %disabled; my %disabled;
my @disabled_collection= @{$opt_skip_test_list} if defined @{$opt_skip_test_list}; my @disabled_collection= @{$opt_skip_test_list} if defined @{$opt_skip_test_list};
unshift (@disabled_collection, "$testdir/disabled.def"); push (@disabled_collection, "$testdir/disabled.def");
for my $skip (@disabled_collection) for my $skip (@disabled_collection)
{
if ( open(DISABLED, $skip ) )
{ {
if ( open(DISABLED, $skip ) ) while ( <DISABLED> )
{ {
# $^O on Windows considered not generic enough chomp;
my $plat= (IS_WINDOWS) ? 'windows' : $^O; next if /^\s*#/ or /^\s*$/;
mtr_error("Syntax error in $skip line $.")
while ( <DISABLED> ) unless /^\s*([-0-9A-Za-z_]+\.)?([-0-9A-Za-z_]+)\s*:\s*(.*?)\s*$/;
{ next if defined $1 and $1 ne "$suite.";
chomp; $disabled{$2}= $3;
#diasble the test case if platform matches }
if ( /\@/ ) close DISABLED;
{
if ( /\@$plat/ )
{
/^\s*(\S+)\s*\@$plat.*:\s*(.*?)\s*$/ ;
$disabled{$1}= $2 if not exists $disabled{$1};
}
elsif ( /\@!(\S*)/ )
{
if ( $1 ne $plat)
{
/^\s*(\S+)\s*\@!.*:\s*(.*?)\s*$/ ;
$disabled{$1}= $2 if not exists $disabled{$1};
}
}
}
elsif ( /^\s*(\S+)\s*:\s*(.*?)\s*$/ )
{
chomp;
if ( /^\s*(\S+)\s*:\s*(.*?)\s*$/ )
{
$disabled{$1}= $2 if not exists $disabled{$1};
}
}
}
close DISABLED;
}
} }
}
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# Read combinations for this suite # Read combinations for this suite
...@@ -444,8 +421,7 @@ sub collect_one_suite ...@@ -444,8 +421,7 @@ sub collect_one_suite
next if ($do_test_reg and not $_ =~ /$do_test_reg/o); next if ($do_test_reg and not $_ =~ /$do_test_reg/o);
push(@cases, collect_one_test_case($suitedir, $testdir, $resdir, push(@cases, collect_one_test_case($suitedir, $testdir, $resdir,
$suite, $_, "$_.test", \%disabled, $suite, $_, \%disabled, $suite_opts));
$suite_opts));
} }
# Return empty list if no testcases found # Return empty list if no testcases found
...@@ -582,18 +558,12 @@ sub make_combinations($@) ...@@ -582,18 +558,12 @@ sub make_combinations($@)
foreach my $comb (@combinations) foreach my $comb (@combinations)
{ {
# Copy test options # Copy test options
my $new_test= My::Test->new(); my $new_test= $test->copy();
while (my ($key, $value) = each(%$test)) {
if (ref $value eq "ARRAY") {
push(@{$new_test->{$key}}, @$value);
} else {
$new_test->{$key}= $value;
}
}
# Append the combination options to master_opt and slave_opt # Prepend the combination options to master_opt and slave_opt
push(@{$new_test->{master_opt}}, @{$comb->{comb_opt}}); # (on the command line combinations go *before* .opt files)
push(@{$new_test->{slave_opt}}, @{$comb->{comb_opt}}); unshift @{$new_test->{master_opt}}, @{$comb->{comb_opt}};
unshift @{$new_test->{slave_opt}}, @{$comb->{comb_opt}};
# Add combination name short name # Add combination name short name
push @{$new_test->{combinations}}, $comb->{name}; push @{$new_test->{combinations}}, $comb->{name};
...@@ -617,11 +587,11 @@ sub collect_one_test_case { ...@@ -617,11 +587,11 @@ sub collect_one_test_case {
my $resdir= shift; my $resdir= shift;
my $suitename= shift; my $suitename= shift;
my $tname= shift; my $tname= shift;
my $filename= shift;
my $disabled= shift; my $disabled= shift;
my $suite_opts= shift; my $suite_opts= shift;
my $local_default_storage_engine= $default_storage_engine; my $local_default_storage_engine= $default_storage_engine;
my $filename= "$testdir/$tname.test";
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# Set defaults # Set defaults
...@@ -630,14 +600,16 @@ sub collect_one_test_case { ...@@ -630,14 +600,16 @@ sub collect_one_test_case {
( (
name => "$suitename.$tname", name => "$suitename.$tname",
shortname => $tname, shortname => $tname,
path => "$testdir/$filename", path => $filename,
suite => $suites{$suitename}, suite => $suites{$suitename},
master_opt => [ @$suite_opts ],
slave_opt => [ @$suite_opts ],
); );
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# Skip some tests but include in list, just mark them as skipped # Skip some tests but include in list, just mark them as skipped
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
my $name= basename($suitename) . ".$tname"; my $name= $suitename . ".$tname";
if ( $skip_test_reg and ($tname =~ /$skip_test_reg/o || if ( $skip_test_reg and ($tname =~ /$skip_test_reg/o ||
$name =~ /$skip_test/o)) $name =~ /$skip_test/o))
{ {
...@@ -648,25 +620,9 @@ sub collect_one_test_case { ...@@ -648,25 +620,9 @@ sub collect_one_test_case {
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# Check for disabled tests # Check for disabled tests
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
my $marked_as_disabled= 0; if ($disabled->{$tname})
if ( $disabled->{$tname} or $disabled->{"$suitename.$tname"} )
{
# Test was marked as disabled in suites disabled.def file
$marked_as_disabled= 1;
# Test name may have been disabled with or without suite name part
$tinfo->{'comment'}= $disabled->{$tname} ||
$disabled->{"$suitename.$tname"};
}
my $disabled_file= "$testdir/$tname.disabled";
if ( -f $disabled_file )
{
$marked_as_disabled= 1;
$tinfo->{'comment'}= mtr_fromfile($disabled_file);
}
if ( $marked_as_disabled )
{ {
$tinfo->{'comment'}= $disabled->{$tname};
if ( $enable_disabled ) if ( $enable_disabled )
{ {
# User has selected to run all disabled tests # User has selected to run all disabled tests
...@@ -681,12 +637,6 @@ sub collect_one_test_case { ...@@ -681,12 +637,6 @@ sub collect_one_test_case {
} }
} }
# ----------------------------------------------------------------------
# Append suite extra options to both master and slave
# ----------------------------------------------------------------------
push(@{$tinfo->{'master_opt'}}, @$suite_opts);
push(@{$tinfo->{'slave_opt'}}, @$suite_opts);
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# Check for test specific config file # Check for test specific config file
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
...@@ -732,7 +682,6 @@ sub collect_one_test_case { ...@@ -732,7 +682,6 @@ sub collect_one_test_case {
} }
} }
my $filename = "$testdir/${tname}.test";
my ($master_opts, $slave_opts)= my ($master_opts, $slave_opts)=
tags_from_test_file($tinfo, $filename, $suitedir); tags_from_test_file($tinfo, $filename, $suitedir);
...@@ -923,9 +872,9 @@ my $tags_map= {'big_test' => ['big_test', 1], ...@@ -923,9 +872,9 @@ my $tags_map= {'big_test' => ['big_test', 1],
my $tags_regex_string= join('|', keys %$tags_map); my $tags_regex_string= join('|', keys %$tags_map);
my $tags_regex= qr:include/($tags_regex_string)\.inc:o; my $tags_regex= qr:include/($tags_regex_string)\.inc:o;
my $file_to_tags= { }; my %file_to_tags;
my $file_to_master_opts= { }; my %file_to_master_opts;
my $file_to_slave_opts= { }; my %file_to_slave_opts;
# Get various tags from a file, recursively scanning also included files. # Get various tags from a file, recursively scanning also included files.
# And get options from .opt file, also recursively for included files. # And get options from .opt file, also recursively for included files.
...@@ -938,7 +887,7 @@ my $file_to_slave_opts= { }; ...@@ -938,7 +887,7 @@ my $file_to_slave_opts= { };
sub get_tags_from_file($$) { sub get_tags_from_file($$) {
my ($file, $suitedir)= @_; my ($file, $suitedir)= @_;
return @{$file_to_tags->{$file}} if exists $file_to_tags->{$file}; return @{$file_to_tags{$file}} if exists $file_to_tags{$file};
my $F= IO::File->new($file) my $F= IO::File->new($file)
or mtr_error("can't open file \"$file\": $!"); or mtr_error("can't open file \"$file\": $!");
...@@ -978,8 +927,8 @@ sub get_tags_from_file($$) { ...@@ -978,8 +927,8 @@ sub get_tags_from_file($$) {
if (-e $sourced_file) if (-e $sourced_file)
{ {
push @$tags, get_tags_from_file($sourced_file, $suitedir); push @$tags, get_tags_from_file($sourced_file, $suitedir);
push @$master_opts, @{$file_to_master_opts->{$sourced_file}}; push @$master_opts, @{$file_to_master_opts{$sourced_file}};
push @$slave_opts, @{$file_to_slave_opts->{$sourced_file}}; push @$slave_opts, @{$file_to_slave_opts{$sourced_file}};
push @combinations, @{$file_combinations{$sourced_file}}; push @combinations, @{$file_combinations{$sourced_file}};
last; last;
} }
...@@ -999,9 +948,9 @@ sub get_tags_from_file($$) { ...@@ -999,9 +948,9 @@ sub get_tags_from_file($$) {
push @combinations, [ combinations_from_file("$file_no_ext.combinations") ]; push @combinations, [ combinations_from_file("$file_no_ext.combinations") ];
# Save results so we can reuse without parsing if seen again. # Save results so we can reuse without parsing if seen again.
$file_to_tags->{$file}= $tags; $file_to_tags{$file}= $tags;
$file_to_master_opts->{$file}= $master_opts; $file_to_master_opts{$file}= $master_opts;
$file_to_slave_opts->{$file}= $slave_opts; $file_to_slave_opts{$file}= $slave_opts;
$file_combinations{$file}= [ uniq(@combinations) ]; $file_combinations{$file}= [ uniq(@combinations) ];
return @{$tags}; return @{$tags};
} }
...@@ -1017,7 +966,7 @@ sub tags_from_test_file { ...@@ -1017,7 +966,7 @@ sub tags_from_test_file {
{ {
$tinfo->{$_->[0]}= $_->[1]; $tinfo->{$_->[0]}= $_->[1];
} }
return ($file_to_master_opts->{$file}, $file_to_slave_opts->{$file}); return ($file_to_master_opts{$file}, $file_to_slave_opts{$file});
} }
sub unspace { sub unspace {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment