Commit ac735d50 authored by Sergei Golubchik's avatar Sergei Golubchik

support ./mtr suite.test,com,bi,na,tions syntax

parent 2b8143a5
...@@ -117,7 +117,7 @@ sub collect_test_cases ($$$$) { ...@@ -117,7 +117,7 @@ sub collect_test_cases ($$$$) {
if ( @$opt_cases ) if ( @$opt_cases )
{ {
# A list of tests was specified on the command line # 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 # in at least one suite
foreach my $test_name_spec ( @$opt_cases ) foreach my $test_name_spec ( @$opt_cases )
{ {
...@@ -189,30 +189,33 @@ sub collect_test_cases ($$$$) { ...@@ -189,30 +189,33 @@ sub collect_test_cases ($$$$) {
} }
# Returns (suitename, testname) # Returns (suitename, testname, combinations....)
sub split_testname { sub split_testname {
my ($test_name)= @_; my ($test_name)= @_;
# If .test file name is used, get rid of directory part # If .test file name is used, get rid of directory part
$test_name= basename($test_name) if $test_name =~ /\.test$/; $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 # Now split name on .'s
my @parts= split(/\./, $test_name); my @parts= split(/\./, $test_name);
if (@parts == 1){ if (@parts == 1){
# Only testname given, ex: alias # Only testname given, ex: alias
return (undef , $parts[0]); return (undef , $parts[0], @combs);
} elsif (@parts == 2) { } elsif (@parts == 2) {
# Either testname.test or suite.testname given # Either testname.test or suite.testname given
# Ex. main.alias or alias.test # Ex. main.alias or alias.test
if ($parts[1] eq "test") if ($parts[1] eq "test")
{ {
return (undef , $parts[0]); return (undef , $parts[0], @combs);
} }
else else
{ {
return ($parts[0], $parts[1]); return ($parts[0], $parts[1], @combs);
} }
} }
...@@ -499,14 +502,14 @@ sub process_suite { ...@@ -499,14 +502,14 @@ sub process_suite {
# Collect in specified order # Collect in specified order
foreach my $test_name_spec ( @$opt_cases ) 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 # Check correct suite if suitename is defined
next if defined $sname and $sname ne $suitename next if defined $sname and $sname ne $suitename
and $sname ne "$basename-"; and $sname ne "$basename-";
next unless $all_cases{$tname}; 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 { } else {
for (sort keys %all_cases) for (sort keys %all_cases)
...@@ -559,9 +562,9 @@ sub process_opts { ...@@ -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; return ($test) if $test->{'skip'} or not @combinations;
if ($combinations[0]->{skip}) { if ($combinations[0]->{skip}) {
...@@ -578,11 +581,19 @@ sub make_combinations($@) ...@@ -578,11 +581,19 @@ sub make_combinations($@)
if (My::Options::is_set($test->{master_opt}, $comb->{comb_opt}) && if (My::Options::is_set($test->{master_opt}, $comb->{comb_opt}) &&
My::Options::is_set($test->{slave_opt}, $comb->{comb_opt}) ){ My::Options::is_set($test->{slave_opt}, $comb->{comb_opt}) ){
delete $test_combs->{$comb->{name}};
# Add combination name short name # Add combination name short name
push @{$test->{combinations}}, $comb->{name}; push @{$test->{combinations}}, $comb->{name};
return ($test); 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; my @cases;
...@@ -635,6 +646,8 @@ sub collect_one_test_case { ...@@ -635,6 +646,8 @@ sub collect_one_test_case {
my $suite = shift; my $suite = shift;
my $tpath = shift; my $tpath = shift;
my $tname = shift; my $tname = shift;
my %test_combs = map { $_ => 1 } @_;
my $suitename = $suite->{name}; my $suitename = $suite->{name};
my $name = "$suitename.$tname"; my $name = "$suitename.$tname";
...@@ -829,7 +842,11 @@ sub collect_one_test_case { ...@@ -829,7 +842,11 @@ sub collect_one_test_case {
my @cases = ($tinfo); my @cases = ($tinfo);
for my $comb ($suite->{combinations}, @{$file_combinations{$filename}}) 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) { for $tinfo (@cases) {
......
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