summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--mysql-test/lib/mtr_cases.pm37
1 files changed, 27 insertions, 10 deletions
diff --git a/mysql-test/lib/mtr_cases.pm b/mysql-test/lib/mtr_cases.pm
index a82e3ee10b7..1327afdb426 100644
--- a/mysql-test/lib/mtr_cases.pm
+++ b/mysql-test/lib/mtr_cases.pm
@@ -117,7 +117,7 @@ sub collect_test_cases ($$$$) {
if ( @$opt_cases )
{
# A list of tests was specified on the command line
- # Check that the tests specified was found
+ # Check that the tests specified were found
# in at least one suite
foreach my $test_name_spec ( @$opt_cases )
{
@@ -189,30 +189,33 @@ sub collect_test_cases ($$$$) {
}
-# Returns (suitename, testname)
+# Returns (suitename, testname, combinations....)
sub split_testname {
my ($test_name)= @_;
# If .test file name is used, get rid of directory part
$test_name= basename($test_name) if $test_name =~ /\.test$/;
+ # Then, get the combinations:
+ my ($test_name, @combs) = split /,/, $test_name;
+
# Now split name on .'s
my @parts= split(/\./, $test_name);
if (@parts == 1){
# Only testname given, ex: alias
- return (undef , $parts[0]);
+ return (undef , $parts[0], @combs);
} elsif (@parts == 2) {
# Either testname.test or suite.testname given
# Ex. main.alias or alias.test
if ($parts[1] eq "test")
{
- return (undef , $parts[0]);
+ return (undef , $parts[0], @combs);
}
else
{
- return ($parts[0], $parts[1]);
+ return ($parts[0], $parts[1], @combs);
}
}
@@ -499,14 +502,14 @@ sub process_suite {
# Collect in specified order
foreach my $test_name_spec ( @$opt_cases )
{
- my ($sname, $tname)= split_testname($test_name_spec);
+ my ($sname, $tname, @combs)= split_testname($test_name_spec);
# Check correct suite if suitename is defined
next if defined $sname and $sname ne $suitename
and $sname ne "$basename-";
next unless $all_cases{$tname};
- push @cases, collect_one_test_case($suite, $all_cases{$tname}, $tname);
+ push @cases, collect_one_test_case($suite, $all_cases{$tname}, $tname, @combs);
}
} else {
for (sort keys %all_cases)
@@ -559,9 +562,9 @@ sub process_opts {
}
}
-sub make_combinations($@)
+sub make_combinations($$@)
{
- my ($test, @combinations) = @_;
+ my ($test, $test_combs, @combinations) = @_;
return ($test) if $test->{'skip'} or not @combinations;
if ($combinations[0]->{skip}) {
@@ -578,11 +581,19 @@ sub make_combinations($@)
if (My::Options::is_set($test->{master_opt}, $comb->{comb_opt}) &&
My::Options::is_set($test->{slave_opt}, $comb->{comb_opt}) ){
+ delete $test_combs->{$comb->{name}};
+
# Add combination name short name
push @{$test->{combinations}}, $comb->{name};
return ($test);
}
+
+ # Skip all other combinations, if this combination is forced
+ if (delete $test_combs->{$comb->{name}}) {
+ @combinations = ($comb); # run the loop below only for this combination
+ last;
+ }
}
my @cases;
@@ -635,6 +646,8 @@ sub collect_one_test_case {
my $suite = shift;
my $tpath = shift;
my $tname = shift;
+ my %test_combs = map { $_ => 1 } @_;
+
my $suitename = $suite->{name};
my $name = "$suitename.$tname";
@@ -829,7 +842,11 @@ sub collect_one_test_case {
my @cases = ($tinfo);
for my $comb ($suite->{combinations}, @{$file_combinations{$filename}})
{
- @cases = map make_combinations($_, @{$comb}), @cases;
+ @cases = map make_combinations($_, \%test_combs, @{$comb}), @cases;
+ }
+ if (keys %test_combs) {
+ mtr_error("Could not run $name with '".(
+ join(',', sort keys %test_combs))."' combination(s)");
}
for $tinfo (@cases) {