You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

project_query_test.rb 4.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. # frozen_string_literal: true
  2. # Redmine - project management software
  3. # Copyright (C) 2006- Jean-Philippe Lang
  4. #
  5. # This program is free software; you can redistribute it and/or
  6. # modify it under the terms of the GNU General Public License
  7. # as published by the Free Software Foundation; either version 2
  8. # of the License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with this program; if not, write to the Free Software
  17. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. require_relative '../test_helper'
  19. class ProjectQueryTest < ActiveSupport::TestCase
  20. fixtures :projects, :users,
  21. :members, :roles, :member_roles,
  22. :issue_categories, :enumerations,
  23. :groups_users,
  24. :enabled_modules,
  25. :custom_fields, :custom_values,
  26. :queries
  27. include Redmine::I18n
  28. def test_filter_values_be_arrays
  29. q = ProjectQuery.new
  30. assert_nil q.project
  31. q.available_filters.each do |name, filter|
  32. values = filter.values
  33. assert (values.nil? || values.is_a?(Array)),
  34. "#values for #{name} filter returned a #{values.class.name}"
  35. end
  36. end
  37. def test_project_statuses_filter_should_return_project_statuses
  38. set_language_if_valid 'en'
  39. query = ProjectQuery.new(:name => '_')
  40. query.filters = {'status' => {:operator => '=', :values => []}}
  41. values = query.available_filters['status'][:values]
  42. assert_equal ['active', 'closed'], values.map(&:first)
  43. assert_equal ['1', '5'], values.map(&:second)
  44. end
  45. def test_default_columns
  46. q = ProjectQuery.new
  47. assert q.columns.any?
  48. assert q.inline_columns.any?
  49. assert q.block_columns.empty?
  50. end
  51. def test_available_columns_should_include_project_custom_fields
  52. query = ProjectQuery.new
  53. assert_include :cf_3, query.available_columns.map(&:name)
  54. end
  55. def test_available_display_types_should_returns_bord_and_list
  56. query = ProjectQuery.new
  57. query.admin_projects = nil
  58. assert_equal ['board', 'list'], query.available_display_types
  59. end
  60. def test_available_display_types_should_always_returns_list_when_admin_projects_is_set
  61. query = ProjectQuery.new
  62. query.admin_projects = 1
  63. assert_equal ['list'], query.available_display_types
  64. end
  65. def test_display_type_default_should_equal_with_setting_project_list_display_type
  66. ProjectQuery.new.available_display_types.each do |t|
  67. with_settings :project_list_display_type => t do
  68. q = ProjectQuery.new
  69. assert_equal t, q.display_type
  70. end
  71. end
  72. end
  73. def test_should_determine_default_project_query
  74. user = User.find(1)
  75. query = ProjectQuery.find(11)
  76. user_query = ProjectQuery.find(12)
  77. user_query.update(visibility: Query::VISIBILITY_PUBLIC)
  78. [nil, user, User.anonymous].each do |u|
  79. assert_nil IssueQuery.default(user: u)
  80. end
  81. # only global default is set
  82. with_settings :default_project_query => query.id do
  83. [nil, user, User.anonymous].each do |u|
  84. assert_equal query, ProjectQuery.default(user: u)
  85. end
  86. end
  87. # user default, overrides global default
  88. user.pref.default_project_query = user_query.id
  89. user.pref.save
  90. with_settings :default_project_query => query.id do
  91. assert_equal user_query, ProjectQuery.default(user: user)
  92. end
  93. end
  94. def test_project_query_default_should_return_nil_if_default_query_destroyed
  95. query = ProjectQuery.find(11)
  96. Setting.default_project_query = query.id
  97. query.destroy
  98. assert_nil ProjectQuery.default
  99. end
  100. def test_display_type_should_returns_list_when_admin_projects_is_set
  101. q = ProjectQuery.new
  102. q.admin_projects = 1
  103. assert_equal 'list', q.display_type
  104. end
  105. def test_project_statuses_values_should_equal_ancestors_return
  106. ancestor = Query.new
  107. q = ProjectQuery.new
  108. assert_equal ancestor.project_statuses_values, q.project_statuses_values
  109. end
  110. def test_project_statuses_values_should_includes_project_status_archeved_when_admin_projects_is_set
  111. q = ProjectQuery.new
  112. q.admin_projects = 1
  113. assert_includes q.project_statuses_values, [l(:project_status_archived), Project::STATUS_ARCHIVED.to_s]
  114. Query.new.project_statuses_values.each do |status|
  115. assert_includes q.project_statuses_values, status
  116. end
  117. end
  118. def test_base_scope_should_return_visible_projects
  119. q = ProjectQuery.new
  120. assert_equal Project.visible, q.base_scope
  121. end
  122. def test_base_scope_should_return_all_projects_when_admin_projects_is_set
  123. q = ProjectQuery.new
  124. q.admin_projects = 1
  125. assert_equal Project.all, q.base_scope
  126. end
  127. end