Commit e0a4e9c1 authored by Max Kanat-Alexander's avatar Max Kanat-Alexander

Bug 637662: Make all the boolean charts work as expected for the "blocks"

and "dependson" fields. r=mkanat, a=mkanat (module owner)
parent dddef33e
...@@ -274,9 +274,7 @@ use constant OPERATOR_FIELD_OVERRIDE => { ...@@ -274,9 +274,7 @@ use constant OPERATOR_FIELD_OVERRIDE => {
'attachments' => { 'attachments' => {
_non_changed => \&_attachments, _non_changed => \&_attachments,
}, },
blocked => { blocked => MULTI_SELECT_OVERRIDE,
_non_changed => \&_blocked_nonchanged,
},
bug_group => MULTI_SELECT_OVERRIDE, bug_group => MULTI_SELECT_OVERRIDE,
classification => { classification => {
_non_changed => \&_classification_nonchanged, _non_changed => \&_classification_nonchanged,
...@@ -292,9 +290,7 @@ use constant OPERATOR_FIELD_OVERRIDE => { ...@@ -292,9 +290,7 @@ use constant OPERATOR_FIELD_OVERRIDE => {
days_elapsed => { days_elapsed => {
_default => \&_days_elapsed, _default => \&_days_elapsed,
}, },
dependson => { dependson => MULTI_SELECT_OVERRIDE,
_non_changed => \&_dependson_nonchanged,
},
keywords => MULTI_SELECT_OVERRIDE, keywords => MULTI_SELECT_OVERRIDE,
'flagtypes.name' => { 'flagtypes.name' => {
_default => \&_flagtypes_name, _default => \&_flagtypes_name,
...@@ -2525,47 +2521,6 @@ sub _classification_nonchanged { ...@@ -2525,47 +2521,6 @@ sub _classification_nonchanged {
"classifications.id", "classifications", $term); "classifications.id", "classifications", $term);
} }
# XXX This should be combined with blocked_nonchanged.
sub _dependson_nonchanged {
my ($self, $args) = @_;
my ($chart_id, $joins, $field, $operator) =
@$args{qw(chart_id joins field operator)};
my $table = "dependson_$chart_id";
my $full_field = "$table.$field";
$args->{full_field} = $full_field;
$self->_do_operator_function($args);
my $term = $args->{term};
my $dep_join = {
table => 'dependencies',
as => $table,
to => 'blocked',
extra => [$term],
};
push(@$joins, $dep_join);
$args->{term} = "$full_field IS NOT NULL";
}
sub _blocked_nonchanged {
my ($self, $args) = @_;
my ($chart_id, $joins, $field, $operator) =
@$args{qw(chart_id joins field operator)};
my $table = "blocked_$chart_id";
my $full_field = "$table.$field";
$args->{full_field} = $full_field;
$self->_do_operator_function($args);
my $term = $args->{term};
my $dep_join = {
table => 'dependencies',
as => $table,
to => 'dependson',
extra => [$term],
};
push(@$joins, $dep_join);
$args->{term} = "$full_field IS NOT NULL";
}
sub _alias_nonchanged { sub _alias_nonchanged {
my ($self, $args) = @_; my ($self, $args) = @_;
$args->{full_field} = "COALESCE(bugs.alias, '')"; $args->{full_field} = "COALESCE(bugs.alias, '')";
...@@ -2617,8 +2572,9 @@ sub _multiselect_negative { ...@@ -2617,8 +2572,9 @@ sub _multiselect_negative {
$args->{operator} = $self->_reverse_operator($operator); $args->{operator} = $self->_reverse_operator($operator);
$self->_do_operator_function($args); $self->_do_operator_function($args);
my $term = $args->{term}; my $term = $args->{term};
my $select = $args->{_select_field} || 'bug_id';
$args->{term} = $args->{term} =
"bugs.bug_id NOT IN (SELECT bug_id FROM $table WHERE $term)"; "bugs.bug_id NOT IN (SELECT $select FROM $table WHERE $term)";
} }
sub _multiselect_multiple { sub _multiselect_multiple {
...@@ -2667,6 +2623,12 @@ sub _multiselect_table { ...@@ -2667,6 +2623,12 @@ sub _multiselect_table {
return "bug_group_map INNER JOIN groups return "bug_group_map INNER JOIN groups
ON bug_group_map.group_id = groups.id"; ON bug_group_map.group_id = groups.id";
} }
elsif ($field eq 'blocked' or $field eq 'dependson') {
my $select = $field eq 'blocked' ? 'dependson' : 'blocked';
$args->{_select_field} = $select;
$args->{full_field} = "dependencies.$field";
return "dependencies";
}
my $table = "bug_$field"; my $table = "bug_$field";
$args->{full_field} = "bug_$field.value"; $args->{full_field} = "bug_$field.value";
return $table; return $table;
...@@ -2677,7 +2639,8 @@ sub _multiselect_term { ...@@ -2677,7 +2639,8 @@ sub _multiselect_term {
my $table = $self->_multiselect_table($args); my $table = $self->_multiselect_table($args);
$self->_do_operator_function($args); $self->_do_operator_function($args);
my $term = $args->{term}; my $term = $args->{term};
return "bugs.bug_id IN (SELECT bug_id FROM $table WHERE $term)"; my $select = $args->{_select_field} || 'bug_id';
return "bugs.bug_id IN (SELECT $select FROM $table WHERE $term)";
} }
sub _multiselect_nonchanged { sub _multiselect_nonchanged {
......
...@@ -193,11 +193,6 @@ use constant SUBSTR_NO_FIELD_ADD => FIELD_TYPE_DATETIME, qw( ...@@ -193,11 +193,6 @@ use constant SUBSTR_NO_FIELD_ADD => FIELD_TYPE_DATETIME, qw(
# Certain fields fail all the "negative" search tests: # Certain fields fail all the "negative" search tests:
# #
# Blocked and Dependson "notequals" only finds bugs that have
# values for the field, but where the dependency list doesn't contain
# the bug you listed. It doesn't find bugs that fully lack values for
# the fields, as it should.
#
# bug_file_loc can be NULL, so it gets missed by the normal # bug_file_loc can be NULL, so it gets missed by the normal
# notequals search. # notequals search.
# #
...@@ -220,10 +215,8 @@ use constant NEGATIVE_BROKEN => ( ...@@ -220,10 +215,8 @@ use constant NEGATIVE_BROKEN => (
'attachments.description' => { contains => [5] }, 'attachments.description' => { contains => [5] },
'attachments.filename' => { contains => [5] }, 'attachments.filename' => { contains => [5] },
'attachments.mimetype' => { contains => [5] }, 'attachments.mimetype' => { contains => [5] },
blocked => { contains => [3,4,5] },
bug_file_loc => { contains => [5] }, bug_file_loc => { contains => [5] },
deadline => { contains => [5] }, deadline => { contains => [5] },
dependson => { contains => [2,4,5] },
longdesc => { contains => [1] }, longdesc => { contains => [1] },
'longdescs.isprivate' => { contains => [1] }, 'longdescs.isprivate' => { contains => [1] },
# Custom fields are busted because they can be NULL. # Custom fields are busted because they can be NULL.
...@@ -486,8 +479,6 @@ use constant CHANGED_FROM_TO_BROKEN_NOT => ( ...@@ -486,8 +479,6 @@ use constant CHANGED_FROM_TO_BROKEN_NOT => (
# Common broken tests for the "not" or "no" operators. # Common broken tests for the "not" or "no" operators.
use constant NEGATIVE_BROKEN_NOT => ( use constant NEGATIVE_BROKEN_NOT => (
"blocked" => { contains => [3, 4, 5] },
"dependson" => { contains => [2, 4, 5] },
"flagtypes.name" => { contains => [1 .. 5] }, "flagtypes.name" => { contains => [1 .. 5] },
); );
......
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