2011-10-29 16:19:11 +04:00
#-- encoding: UTF-8
2011-05-30 00:11:52 +04:00
#-- copyright
# ChiliProject is a project management system.
2011-05-30 22:52:25 +04:00
#
2012-01-03 23:36:40 +04:00
# Copyright (C) 2010-2012 the ChiliProject Team
2011-05-30 22:52:25 +04:00
#
2007-08-26 16:29:53 +04: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 2
# of the License, or (at your option) any later version.
2011-05-30 22:52:25 +04:00
#
2011-05-30 00:11:52 +04:00
# See doc/COPYRIGHT.rdoc for more details.
#++
2010-12-13 02:24:34 +03:00
require File . expand_path ( '../../test_helper' , __FILE__ )
2007-08-26 16:29:53 +04:00
2009-09-13 21:14:35 +04:00
class QueryTest < ActiveSupport :: TestCase
2009-05-10 14:54:31 +04:00
fixtures :projects , :enabled_modules , :users , :members , :member_roles , :roles , :trackers , :issue_statuses , :issue_categories , :enumerations , :issues , :watchers , :custom_fields , :custom_values , :versions , :queries
2007-08-26 16:29:53 +04:00
2008-06-22 19:35:11 +04:00
def test_custom_fields_for_all_projects_should_be_available_in_global_queries
query = Query . new ( :project = > nil , :name = > '_' )
assert query . available_filters . has_key? ( 'cf_1' )
assert ! query . available_filters . has_key? ( 'cf_3' )
end
2011-05-30 22:52:25 +04:00
2010-02-11 00:42:32 +03:00
def test_system_shared_versions_should_be_available_in_global_queries
Version . find ( 2 ) . update_attribute :sharing , 'system'
query = Query . new ( :project = > nil , :name = > '_' )
assert query . available_filters . has_key? ( 'fixed_version_id' )
assert query . available_filters [ 'fixed_version_id' ] [ :values ] . detect { | v | v . last == '2' }
end
2011-05-30 22:52:25 +04:00
2010-08-08 13:01:25 +04:00
def test_project_filter_in_global_queries
query = Query . new ( :project = > nil , :name = > '_' )
project_filter = query . available_filters [ " project_id " ]
assert_not_nil project_filter
project_ids = project_filter [ :values ] . map { | p | p [ 1 ] }
assert project_ids . include? ( " 1 " ) #public project
assert ! project_ids . include? ( " 2 " ) #private project user cannot see
end
2011-05-30 22:52:25 +04:00
2008-07-26 13:05:26 +04:00
def find_issues_with_query ( query )
Issue . find :all ,
2011-05-30 22:52:25 +04:00
:include = > [ :assigned_to , :status , :tracker , :project , :priority ] ,
2008-07-26 13:05:26 +04:00
:conditions = > query . statement
end
2009-12-06 13:28:20 +03:00
2010-09-10 22:46:29 +04:00
def assert_find_issues_with_query_is_successful ( query )
assert_nothing_raised do
find_issues_with_query ( query )
end
end
def assert_query_statement_includes ( query , condition )
assert query . statement . include? ( condition ) , " Query statement condition not found in: #{ query . statement } "
end
2009-12-06 13:28:20 +03:00
def test_query_should_allow_shared_versions_for_a_project_query
subproject_version = Version . find ( 4 )
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'fixed_version_id' , '=' , [ subproject_version . id . to_s ] )
assert query . statement . include? ( " #{ Issue . table_name } .fixed_version_id IN ('4') " )
end
2011-05-30 22:52:25 +04:00
2007-08-26 16:29:53 +04:00
def test_query_with_multiple_custom_fields
query = Query . find ( 1 )
assert query . valid?
2008-04-26 20:55:24 +04:00
assert query . statement . include? ( " #{ CustomValue . table_name } .value IN ('MySQL') " )
2008-07-26 13:05:26 +04:00
issues = find_issues_with_query ( query )
2007-08-26 16:29:53 +04:00
assert_equal 1 , issues . length
assert_equal Issue . find ( 3 ) , issues . first
end
2011-05-30 22:52:25 +04:00
2008-04-29 13:57:47 +04:00
def test_operator_none
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'fixed_version_id' , '!*' , [ '' ] )
query . add_filter ( 'cf_1' , '!*' , [ '' ] )
assert query . statement . include? ( " #{ Issue . table_name } .fixed_version_id IS NULL " )
assert query . statement . include? ( " #{ CustomValue . table_name } .value IS NULL OR #{ CustomValue . table_name } .value = '' " )
2008-07-26 13:05:26 +04:00
find_issues_with_query ( query )
2008-04-29 13:57:47 +04:00
end
2011-05-30 22:52:25 +04:00
2008-07-26 13:05:26 +04:00
def test_operator_none_for_integer
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'estimated_hours' , '!*' , [ '' ] )
issues = find_issues_with_query ( query )
assert ! issues . empty?
assert issues . all? { | i | ! i . estimated_hours }
end
2008-04-29 13:57:47 +04:00
def test_operator_all
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'fixed_version_id' , '*' , [ '' ] )
query . add_filter ( 'cf_1' , '*' , [ '' ] )
assert query . statement . include? ( " #{ Issue . table_name } .fixed_version_id IS NOT NULL " )
assert query . statement . include? ( " #{ CustomValue . table_name } .value IS NOT NULL AND #{ CustomValue . table_name } .value <> '' " )
2008-07-26 13:05:26 +04:00
find_issues_with_query ( query )
2008-04-29 13:57:47 +04:00
end
2011-05-30 22:52:25 +04:00
2008-04-29 13:57:47 +04:00
def test_operator_greater_than
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'done_ratio' , '>=' , [ '40' ] )
assert query . statement . include? ( " #{ Issue . table_name } .done_ratio >= 40 " )
2008-07-26 13:05:26 +04:00
find_issues_with_query ( query )
2008-04-29 13:57:47 +04:00
end
2011-07-10 21:29:29 +04:00
def test_operator_date_equals
query = Query . new ( :name = > '_' )
query . add_filter ( 'due_date' , '=' , [ '2011-07-10' ] )
assert_match / issues \ .due_date > '2011-07-09 23:59:59( \ .9+)?' AND issues \ .due_date <= '2011-07-10 23:59:59( \ .9+)? / , query . statement
find_issues_with_query ( query )
end
def test_operator_date_lesser_than
query = Query . new ( :name = > '_' )
query . add_filter ( 'due_date' , '<=' , [ '2011-07-10' ] )
assert_match / issues \ .due_date <= '2011-07-10 23:59:59( \ .9+)? / , query . statement
find_issues_with_query ( query )
end
def test_operator_date_greater_than
query = Query . new ( :name = > '_' )
query . add_filter ( 'due_date' , '>=' , [ '2011-07-10' ] )
assert_match / issues \ .due_date > '2011-07-09 23:59:59( \ .9+)?' / , query . statement
find_issues_with_query ( query )
end
def test_operator_date_between
query = Query . new ( :name = > '_' )
query . add_filter ( 'due_date' , '><' , [ '2011-06-23' , '2011-07-10' ] )
assert_match / issues \ .due_date > '2011-06-22 23:59:59( \ .9+)?' AND issues \ .due_date <= '2011-07-10 23:59:59( \ .9+)? / , query . statement
find_issues_with_query ( query )
end
2008-04-29 13:57:47 +04:00
def test_operator_in_more_than
2008-11-23 19:40:35 +03:00
Issue . find ( 7 ) . update_attribute ( :due_date , ( Date . today + 15 ) )
2008-04-29 13:57:47 +04:00
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'due_date' , '>t+' , [ '15' ] )
2008-11-23 19:40:35 +03:00
issues = find_issues_with_query ( query )
assert ! issues . empty?
issues . each { | issue | assert ( issue . due_date > = ( Date . today + 15 ) ) }
2008-04-29 13:57:47 +04:00
end
def test_operator_in_less_than
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'due_date' , '<t+' , [ '15' ] )
2008-11-23 19:40:35 +03:00
issues = find_issues_with_query ( query )
assert ! issues . empty?
issues . each { | issue | assert ( issue . due_date > = Date . today && issue . due_date < = ( Date . today + 15 ) ) }
end
2011-05-30 22:52:25 +04:00
2008-11-23 19:40:35 +03:00
def test_operator_less_than_ago
Issue . find ( 7 ) . update_attribute ( :due_date , ( Date . today - 3 ) )
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'due_date' , '>t-' , [ '3' ] )
issues = find_issues_with_query ( query )
assert ! issues . empty?
issues . each { | issue | assert ( issue . due_date > = ( Date . today - 3 ) && issue . due_date < = Date . today ) }
end
2011-05-30 22:52:25 +04:00
2008-11-23 19:40:35 +03:00
def test_operator_more_than_ago
Issue . find ( 7 ) . update_attribute ( :due_date , ( Date . today - 10 ) )
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'due_date' , '<t-' , [ '10' ] )
assert query . statement . include? ( " #{ Issue . table_name } .due_date <= " )
issues = find_issues_with_query ( query )
assert ! issues . empty?
issues . each { | issue | assert ( issue . due_date < = ( Date . today - 10 ) ) }
end
def test_operator_in
Issue . find ( 7 ) . update_attribute ( :due_date , ( Date . today + 2 ) )
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'due_date' , 't+' , [ '2' ] )
issues = find_issues_with_query ( query )
assert ! issues . empty?
issues . each { | issue | assert_equal ( ( Date . today + 2 ) , issue . due_date ) }
end
def test_operator_ago
Issue . find ( 7 ) . update_attribute ( :due_date , ( Date . today - 3 ) )
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'due_date' , 't-' , [ '3' ] )
issues = find_issues_with_query ( query )
assert ! issues . empty?
issues . each { | issue | assert_equal ( ( Date . today - 3 ) , issue . due_date ) }
2008-04-29 13:57:47 +04:00
end
def test_operator_today
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'due_date' , 't' , [ '' ] )
2008-11-23 19:40:35 +03:00
issues = find_issues_with_query ( query )
assert ! issues . empty?
issues . each { | issue | assert_equal Date . today , issue . due_date }
2008-04-29 13:57:47 +04:00
end
def test_operator_this_week_on_date
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'due_date' , 'w' , [ '' ] )
2008-07-26 13:05:26 +04:00
find_issues_with_query ( query )
2008-04-29 13:57:47 +04:00
end
def test_operator_this_week_on_datetime
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . add_filter ( 'created_on' , 'w' , [ '' ] )
2008-07-26 13:05:26 +04:00
find_issues_with_query ( query )
2008-04-29 13:57:47 +04:00
end
def test_operator_contains
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
2009-06-28 16:12:27 +04:00
query . add_filter ( 'subject' , '~' , [ 'uNable' ] )
assert query . statement . include? ( " LOWER( #{ Issue . table_name } .subject) LIKE '%unable%' " )
result = find_issues_with_query ( query )
assert result . empty?
result . each { | issue | assert issue . subject . downcase . include? ( 'unable' ) }
2008-04-29 13:57:47 +04:00
end
2011-05-30 22:52:25 +04:00
2008-04-29 13:57:47 +04:00
def test_operator_does_not_contains
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
2009-06-28 16:12:27 +04:00
query . add_filter ( 'subject' , '!~' , [ 'uNable' ] )
assert query . statement . include? ( " LOWER( #{ Issue . table_name } .subject) NOT LIKE '%unable%' " )
2008-07-26 13:05:26 +04:00
find_issues_with_query ( query )
2008-04-29 13:57:47 +04:00
end
2011-05-30 22:52:25 +04:00
2012-06-20 17:19:31 +04:00
def test_user_custom_field_filtered_on_me
User . current = User . find ( 2 )
cf = IssueCustomField . create! ( :field_format = > 'user' , :is_for_all = > true , :is_filter = > true , :name = > 'User custom field' , :tracker_ids = > [ 1 ] )
project = Project . find ( 1 )
tracker = Tracker . find ( 1 )
project . trackers << tracker unless project . trackers . include? ( tracker )
issue = Issue . create! ( :project = > project , :tracker = > tracker , :subject = > 'Test' , :author_id = > 1 )
issue . update_attribute ( :custom_field_values , { cf . id . to_s = > '2' } )
query = Query . new ( :name = > '_' , :project = > project )
filter = query . available_filters [ " cf_ #{ cf . id } " ]
assert_not_nil filter
assert filter [ :values ] . map { | v | v [ 1 ] } . include? ( 'me' )
query . filters = { " cf_ #{ cf . id } " = > { :operator = > '=' , :values = > [ 'me' ] } }
result = query . issues
assert_equal 1 , result . size
2012-06-20 20:00:34 +04:00
assert_equal issue , result . first
2012-06-20 17:19:31 +04:00
end
2009-02-12 20:35:57 +03:00
def test_filter_watched_issues
User . current = User . find ( 1 )
query = Query . new ( :name = > '_' , :filters = > { 'watcher_id' = > { :operator = > '=' , :values = > [ 'me' ] } } )
result = find_issues_with_query ( query )
assert_not_nil result
assert ! result . empty?
assert_equal Issue . visible . watched_by ( User . current ) . sort_by ( & :id ) , result . sort_by ( & :id )
User . current = nil
end
2011-05-30 22:52:25 +04:00
2009-02-12 20:35:57 +03:00
def test_filter_unwatched_issues
User . current = User . find ( 1 )
query = Query . new ( :name = > '_' , :filters = > { 'watcher_id' = > { :operator = > '!' , :values = > [ 'me' ] } } )
result = find_issues_with_query ( query )
assert_not_nil result
assert ! result . empty?
assert_equal ( ( Issue . visible - Issue . watched_by ( User . current ) ) . sort_by ( & :id ) . size , result . sort_by ( & :id ) . size )
User . current = nil
end
2011-05-30 22:52:25 +04:00
2007-10-01 12:44:17 +04:00
def test_default_columns
q = Query . new
2011-05-30 22:52:25 +04:00
assert ! q . columns . empty?
2007-10-01 12:44:17 +04:00
end
2011-05-30 22:52:25 +04:00
2007-10-01 12:44:17 +04:00
def test_set_column_names
q = Query . new
q . column_names = [ 'tracker' , :subject , '' , 'unknonw_column' ]
assert_equal [ :tracker , :subject ] , q . columns . collect { | c | c . name }
c = q . columns . first
assert q . has_column? ( c )
end
2011-05-30 22:52:25 +04:00
2009-11-16 21:07:30 +03:00
def test_groupable_columns_should_include_custom_fields
q = Query . new
assert q . groupable_columns . detect { | c | c . is_a? QueryCustomFieldColumn }
end
2010-12-22 00:46:54 +03:00
def test_grouped_with_valid_column
q = Query . new ( :group_by = > 'status' )
assert q . grouped?
assert_not_nil q . group_by_column
assert_equal :status , q . group_by_column . name
assert_not_nil q . group_by_statement
assert_equal 'status' , q . group_by_statement
end
2011-05-30 22:52:25 +04:00
2010-12-22 00:46:54 +03:00
def test_grouped_with_invalid_column
q = Query . new ( :group_by = > 'foo' )
assert ! q . grouped?
assert_nil q . group_by_column
assert_nil q . group_by_statement
end
2011-05-30 22:52:25 +04:00
2009-03-12 21:06:54 +03:00
def test_default_sort
q = Query . new
assert_equal [ ] , q . sort_criteria
end
2011-05-30 22:52:25 +04:00
2009-03-12 21:06:54 +03:00
def test_set_sort_criteria_with_hash
q = Query . new
q . sort_criteria = { '0' = > [ 'priority' , 'desc' ] , '2' = > [ 'tracker' ] }
assert_equal [ [ 'priority' , 'desc' ] , [ 'tracker' , 'asc' ] ] , q . sort_criteria
end
2011-05-30 22:52:25 +04:00
2009-03-12 21:06:54 +03:00
def test_set_sort_criteria_with_array
q = Query . new
q . sort_criteria = [ [ 'priority' , 'desc' ] , 'tracker' ]
assert_equal [ [ 'priority' , 'desc' ] , [ 'tracker' , 'asc' ] ] , q . sort_criteria
end
2011-05-30 22:52:25 +04:00
2009-03-12 21:06:54 +03:00
def test_create_query_with_sort
q = Query . new ( :name = > 'Sorted' )
q . sort_criteria = [ [ 'priority' , 'desc' ] , 'tracker' ]
assert q . save
q . reload
assert_equal [ [ 'priority' , 'desc' ] , [ 'tracker' , 'asc' ] ] , q . sort_criteria
end
2011-05-30 22:52:25 +04:00
2009-01-11 19:33:51 +03:00
def test_sort_by_string_custom_field_asc
q = Query . new
c = q . available_columns . find { | col | col . is_a? ( QueryCustomFieldColumn ) && col . custom_field . field_format == 'string' }
assert c
assert c . sortable
issues = Issue . find :all ,
2011-05-30 22:52:25 +04:00
:include = > [ :assigned_to , :status , :tracker , :project , :priority ] ,
2009-01-11 19:33:51 +03:00
:conditions = > q . statement ,
:order = > " #{ c . sortable } ASC "
values = issues . collect { | i | i . custom_value_for ( c . custom_field ) . to_s }
2009-01-11 21:38:07 +03:00
assert ! values . empty?
2009-01-11 19:33:51 +03:00
assert_equal values . sort , values
end
2011-05-30 22:52:25 +04:00
2009-01-11 19:33:51 +03:00
def test_sort_by_string_custom_field_desc
q = Query . new
c = q . available_columns . find { | col | col . is_a? ( QueryCustomFieldColumn ) && col . custom_field . field_format == 'string' }
assert c
assert c . sortable
issues = Issue . find :all ,
2011-05-30 22:52:25 +04:00
:include = > [ :assigned_to , :status , :tracker , :project , :priority ] ,
2009-01-11 19:33:51 +03:00
:conditions = > q . statement ,
:order = > " #{ c . sortable } DESC "
values = issues . collect { | i | i . custom_value_for ( c . custom_field ) . to_s }
2009-01-11 21:38:07 +03:00
assert ! values . empty?
2009-01-11 19:33:51 +03:00
assert_equal values . sort . reverse , values
end
2011-05-30 22:52:25 +04:00
2009-01-11 21:38:07 +03:00
def test_sort_by_float_custom_field_asc
q = Query . new
c = q . available_columns . find { | col | col . is_a? ( QueryCustomFieldColumn ) && col . custom_field . field_format == 'float' }
assert c
assert c . sortable
issues = Issue . find :all ,
2011-05-30 22:52:25 +04:00
:include = > [ :assigned_to , :status , :tracker , :project , :priority ] ,
2009-01-11 21:38:07 +03:00
:conditions = > q . statement ,
:order = > " #{ c . sortable } ASC "
values = issues . collect { | i | begin ; Kernel . Float ( i . custom_value_for ( c . custom_field ) . to_s ) ; rescue ; nil ; end } . compact
assert ! values . empty?
assert_equal values . sort , values
end
2011-05-30 22:52:25 +04:00
2009-11-28 13:29:48 +03:00
def test_invalid_query_should_raise_query_statement_invalid_error
q = Query . new
assert_raise Query :: StatementInvalid do
q . issues ( :conditions = > " foo = 1 " )
end
end
2011-05-30 22:52:25 +04:00
2009-12-02 21:57:17 +03:00
def test_issue_count_by_association_group
q = Query . new ( :name = > '_' , :group_by = > 'assigned_to' )
count_by_group = q . issue_count_by_group
assert_kind_of Hash , count_by_group
assert_equal %w( NilClass User ) , count_by_group . keys . collect { | k | k . class . name } . uniq . sort
assert_equal %w( Fixnum ) , count_by_group . values . collect { | k | k . class . name } . uniq
assert count_by_group . has_key? ( User . find ( 3 ) )
end
def test_issue_count_by_list_custom_field_group
q = Query . new ( :name = > '_' , :group_by = > 'cf_1' )
count_by_group = q . issue_count_by_group
assert_kind_of Hash , count_by_group
assert_equal %w( NilClass String ) , count_by_group . keys . collect { | k | k . class . name } . uniq . sort
assert_equal %w( Fixnum ) , count_by_group . values . collect { | k | k . class . name } . uniq
assert count_by_group . has_key? ( 'MySQL' )
end
2011-05-30 22:52:25 +04:00
2009-12-02 21:57:17 +03:00
def test_issue_count_by_date_custom_field_group
q = Query . new ( :name = > '_' , :group_by = > 'cf_8' )
count_by_group = q . issue_count_by_group
assert_kind_of Hash , count_by_group
assert_equal %w( Date NilClass ) , count_by_group . keys . collect { | k | k . class . name } . uniq . sort
assert_equal %w( Fixnum ) , count_by_group . values . collect { | k | k . class . name } . uniq
end
2011-05-30 22:52:25 +04:00
2008-05-25 16:50:33 +04:00
def test_label_for
q = Query . new
assert_equal 'assigned_to' , q . label_for ( 'assigned_to_id' )
end
2011-05-30 22:52:25 +04:00
2008-03-30 16:29:07 +04:00
def test_editable_by
admin = User . find ( 1 )
manager = User . find ( 2 )
developer = User . find ( 3 )
2011-05-30 22:52:25 +04:00
2008-03-30 16:29:07 +04:00
# Public query on project 1
q = Query . find ( 1 )
assert q . editable_by? ( admin )
assert q . editable_by? ( manager )
assert ! q . editable_by? ( developer )
# Private query on project 1
q = Query . find ( 2 )
assert q . editable_by? ( admin )
assert ! q . editable_by? ( manager )
assert q . editable_by? ( developer )
# Private query for all projects
q = Query . find ( 3 )
assert q . editable_by? ( admin )
assert ! q . editable_by? ( manager )
assert q . editable_by? ( developer )
# Public query for all projects
q = Query . find ( 4 )
assert q . editable_by? ( admin )
assert ! q . editable_by? ( manager )
assert ! q . editable_by? ( developer )
end
2010-08-05 01:01:56 +04:00
2011-10-26 05:13:32 +04:00
context " # display_subprojects " do
setup do
Setting . display_subprojects_issues = 0
User . current = nil
end
should " not include subprojects when false " do
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . display_subprojects = false
issues = find_issues_with_query ( query )
issue_ids = issues . collect ( & :id )
assert issue_ids . include? ( 1 ) , " Didn't find issue 1 on current project "
assert ! issue_ids . include? ( 5 ) , " Issue 5 on sub-project included when it shouldn't be "
assert ! issue_ids . include? ( 6 ) , " Issue 6 on a private sub-project included when it shouldn't be "
end
should " include subprojects when true " do
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . display_subprojects = true
issues = find_issues_with_query ( query )
issue_ids = issues . collect ( & :id )
assert issue_ids . include? ( 1 ) , " Didn't find issue 1 on current project "
assert issue_ids . include? ( 5 ) , " Didn't find issue 5 on sub-project "
assert ! issue_ids . include? ( 6 ) , " Issue 6 on a private sub-project included when it shouldn't be "
end
should " include private subprojects automatically when true " do
User . current = User . find ( 2 )
query = Query . new ( :project = > Project . find ( 1 ) , :name = > '_' )
query . display_subprojects = true
issues = find_issues_with_query ( query )
issue_ids = issues . collect ( & :id )
assert issue_ids . include? ( 1 ) , " Didn't find issue 1 on current project "
assert issue_ids . include? ( 5 ) , " Didn't find issue 5 on sub-project "
assert issue_ids . include? ( 6 ) , " Didn't find issue 6 on a private sub-project "
end
end
2010-08-05 01:01:56 +04:00
context " # available_filters " do
2010-09-10 22:46:29 +04:00
setup do
@query = Query . new ( :name = > " _ " )
end
2011-05-30 22:52:25 +04:00
2010-08-05 01:01:56 +04:00
should " include users of visible projects in cross-project view " do
2010-09-10 22:46:29 +04:00
users = @query . available_filters [ " assigned_to_id " ]
2010-08-05 01:01:56 +04:00
assert_not_nil users
assert users [ :values ] . map { | u | u [ 1 ] } . include? ( " 3 " )
end
2010-09-10 22:46:29 +04:00
2010-12-20 23:03:22 +03:00
should " include visible projects in cross-project view " do
projects = @query . available_filters [ " project_id " ]
assert_not_nil projects
assert projects [ :values ] . map { | u | u [ 1 ] } . include? ( " 1 " )
end
2010-09-10 22:46:29 +04:00
context " 'member_of_group' filter " do
should " be present " do
assert @query . available_filters . keys . include? ( " member_of_group " )
end
2011-05-30 22:52:25 +04:00
2010-09-10 22:46:29 +04:00
should " be an optional list " do
assert_equal :list_optional , @query . available_filters [ " member_of_group " ] [ :type ]
end
2011-05-30 22:52:25 +04:00
2010-09-10 22:46:29 +04:00
should " have a list of the groups as values " do
Group . destroy_all # No fixtures
group1 = Group . generate! . reload
group2 = Group . generate! . reload
expected_group_list = [
2010-10-16 04:00:23 +04:00
[ group1 . name , group1 . id . to_s ] ,
[ group2 . name , group2 . id . to_s ]
2010-09-10 22:46:29 +04:00
]
2010-09-20 06:55:32 +04:00
assert_equal expected_group_list . sort , @query . available_filters [ " member_of_group " ] [ :values ] . sort
2010-09-10 22:46:29 +04:00
end
end
2010-09-10 23:44:45 +04:00
context " 'assigned_to_role' filter " do
should " be present " do
assert @query . available_filters . keys . include? ( " assigned_to_role " )
end
2011-05-30 22:52:25 +04:00
2010-09-10 23:44:45 +04:00
should " be an optional list " do
assert_equal :list_optional , @query . available_filters [ " assigned_to_role " ] [ :type ]
end
2011-05-30 22:52:25 +04:00
2010-09-10 23:44:45 +04:00
should " have a list of the Roles as values " do
2010-10-16 04:00:23 +04:00
assert @query . available_filters [ " assigned_to_role " ] [ :values ] . include? ( [ 'Manager' , '1' ] )
assert @query . available_filters [ " assigned_to_role " ] [ :values ] . include? ( [ 'Developer' , '2' ] )
assert @query . available_filters [ " assigned_to_role " ] [ :values ] . include? ( [ 'Reporter' , '3' ] )
2010-09-10 23:44:45 +04:00
end
should " not include the built in Roles as values " do
2010-10-16 04:00:23 +04:00
assert ! @query . available_filters [ " assigned_to_role " ] [ :values ] . include? ( [ 'Non member' , '4' ] )
assert ! @query . available_filters [ " assigned_to_role " ] [ :values ] . include? ( [ 'Anonymous' , '5' ] )
2010-09-10 23:44:45 +04:00
end
end
2011-10-03 11:52:00 +04:00
context " 'watcher_id' filter " do
context " globally " do
context " for an anonymous user " do
should " not be present " do
assert ! @query . available_filters . keys . include? ( " watcher_id " )
end
end
context " for a logged in user " do
setup do
User . current = User . find 1
end
teardown do
User . current = nil
end
should " be present " do
assert @query . available_filters . keys . include? ( " watcher_id " )
end
should " be a list " do
assert_equal :list , @query . available_filters [ " watcher_id " ] [ :type ]
end
should " have a list of active users as values " do
assert @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " << me >> " , " me " ] )
assert @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " John Smith " , " 2 " ] )
assert @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " Dave Lopper " , " 3 " ] )
assert @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " redMine Admin " , " 1 " ] )
assert @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " User Misc " , " 8 " ] )
end
should " not include active users not member of any project " do
assert ! @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ 'Robert Hill' , '4' ] )
end
should " not include locked users as values " do
assert ! @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ 'Dave2 Lopper2' , '5' ] )
end
should " not include the anonymous user as values " do
assert ! @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ 'Anonymous' , '6' ] )
end
end
end
context " in a project " do
setup do
@query . project = Project . find ( 1 )
end
context " for an anonymous user " do
should " not be present " do
assert ! @query . available_filters . keys . include? ( " watcher_id " )
end
end
context " for a logged in user " do
setup do
User . current = User . find 1
end
teardown do
User . current = nil
end
should " be present " do
assert @query . available_filters . keys . include? ( " watcher_id " )
end
should " be a list " do
assert_equal :list , @query . available_filters [ " watcher_id " ] [ :type ]
end
should " have a list of the project members as values " do
assert @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " << me >> " , " me " ] )
assert @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " John Smith " , " 2 " ] )
assert @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " Dave Lopper " , " 3 " ] )
end
should " not include non-project members as values " do
assert ! @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ " redMine Admin " , " 1 " ] )
end
should " not include locked project members as values " do
assert ! @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ 'Dave2 Lopper2' , '5' ] )
end
should " not include the anonymous user as values " do
assert ! @query . available_filters [ " watcher_id " ] [ :values ] . include? ( [ 'Anonymous' , '6' ] )
end
end
end
end
2010-08-05 01:01:56 +04:00
end
2010-09-10 22:46:29 +04:00
context " # statement " do
context " with 'member_of_group' filter " do
setup do
Group . destroy_all # No fixtures
@user_in_group = User . generate!
@second_user_in_group = User . generate!
@user_in_group2 = User . generate!
@user_not_in_group = User . generate!
2011-05-30 22:52:25 +04:00
2010-09-10 22:46:29 +04:00
@group = Group . generate! . reload
@group . users << @user_in_group
@group . users << @second_user_in_group
2011-05-30 22:52:25 +04:00
2010-09-10 22:46:29 +04:00
@group2 = Group . generate! . reload
@group2 . users << @user_in_group2
2011-05-30 22:52:25 +04:00
2011-03-02 13:12:57 +03:00
@empty_group = Group . generate! . reload
2010-09-10 22:46:29 +04:00
end
2011-05-30 22:52:25 +04:00
2010-09-10 22:46:29 +04:00
should " search assigned to for users in the group " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'member_of_group' , '=' , [ @group . id . to_s ] )
assert_query_statement_includes @query , " #{ Issue . table_name } .assigned_to_id IN (' #{ @user_in_group . id } ',' #{ @second_user_in_group . id } ') "
assert_find_issues_with_query_is_successful @query
end
should " search not assigned to any group member (none) " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'member_of_group' , '!*' , [ '' ] )
# Users not in a group
assert_query_statement_includes @query , " #{ Issue . table_name } .assigned_to_id IS NULL OR #{ Issue . table_name } .assigned_to_id NOT IN (' #{ @user_in_group . id } ',' #{ @second_user_in_group . id } ',' #{ @user_in_group2 . id } ') "
assert_find_issues_with_query_is_successful @query
end
should " search assigned to any group member (all) " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'member_of_group' , '*' , [ '' ] )
# Only users in a group
assert_query_statement_includes @query , " #{ Issue . table_name } .assigned_to_id IN (' #{ @user_in_group . id } ',' #{ @second_user_in_group . id } ',' #{ @user_in_group2 . id } ') "
assert_find_issues_with_query_is_successful @query
2011-03-02 13:12:57 +03:00
end
2011-05-30 22:52:25 +04:00
2011-03-02 13:12:57 +03:00
should " return no results on empty set " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'member_of_group' , '=' , [ @empty_group . id . to_s ] )
2011-05-30 22:52:25 +04:00
2011-03-02 13:12:57 +03:00
assert_query_statement_includes @query , " (0=1) "
assert find_issues_with_query ( @query ) . empty?
end
2011-05-30 22:52:25 +04:00
2011-03-02 13:12:57 +03:00
should " return results on disallowed empty set " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'member_of_group' , '!' , [ @empty_group . id . to_s ] )
2011-05-30 22:52:25 +04:00
2011-03-02 13:12:57 +03:00
assert_query_statement_includes @query , " (1=1) "
assert_find_issues_with_query_is_successful @query
2010-09-10 22:46:29 +04:00
end
end
2010-09-10 23:44:45 +04:00
context " with 'assigned_to_role' filter " do
setup do
# No fixtures
MemberRole . delete_all
Member . delete_all
Role . delete_all
2011-05-30 22:52:25 +04:00
2010-09-10 23:44:45 +04:00
@manager_role = Role . generate! ( :name = > 'Manager' )
@developer_role = Role . generate! ( :name = > 'Developer' )
2011-03-02 13:12:57 +03:00
@empty_role = Role . generate! ( :name = > 'Empty' )
2010-09-10 23:44:45 +04:00
@project = Project . generate!
@manager = User . generate!
@developer = User . generate!
@boss = User . generate!
User . add_to_project ( @manager , @project , @manager_role )
User . add_to_project ( @developer , @project , @developer_role )
User . add_to_project ( @boss , @project , [ @manager_role , @developer_role ] )
end
2011-05-30 22:52:25 +04:00
2010-09-10 23:44:45 +04:00
should " search assigned to for users with the Role " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'assigned_to_role' , '=' , [ @manager_role . id . to_s ] )
assert_query_statement_includes @query , " #{ Issue . table_name } .assigned_to_id IN (' #{ @manager . id } ',' #{ @boss . id } ') "
assert_find_issues_with_query_is_successful @query
end
should " search assigned to for users not assigned to any Role (none) " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'assigned_to_role' , '!*' , [ '' ] )
assert_query_statement_includes @query , " #{ Issue . table_name } .assigned_to_id IS NULL OR #{ Issue . table_name } .assigned_to_id NOT IN (' #{ @manager . id } ',' #{ @developer . id } ',' #{ @boss . id } ') "
assert_find_issues_with_query_is_successful @query
end
should " search assigned to for users assigned to any Role (all) " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'assigned_to_role' , '*' , [ '' ] )
assert_query_statement_includes @query , " #{ Issue . table_name } .assigned_to_id IN (' #{ @manager . id } ',' #{ @developer . id } ',' #{ @boss . id } ') "
assert_find_issues_with_query_is_successful @query
end
2011-03-02 13:12:57 +03:00
should " return no results on empty set " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'assigned_to_role' , '=' , [ @empty_role . id . to_s ] )
2011-05-30 22:52:25 +04:00
2011-03-02 13:12:57 +03:00
assert_query_statement_includes @query , " (0=1) "
assert find_issues_with_query ( @query ) . empty?
end
2011-05-30 22:52:25 +04:00
2011-03-02 13:12:57 +03:00
should " return results on disallowed empty set " do
@query = Query . new ( :name = > '_' )
@query . add_filter ( 'assigned_to_role' , '!' , [ @empty_role . id . to_s ] )
2011-05-30 22:52:25 +04:00
2011-03-02 13:12:57 +03:00
assert_query_statement_includes @query , " (1=1) "
assert_find_issues_with_query_is_successful @query
end
2010-09-10 23:44:45 +04:00
end
2010-09-10 22:46:29 +04:00
end
2011-05-30 22:52:25 +04:00
2007-08-26 16:29:53 +04:00
end