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.

issue_priority_test.rb 5.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  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 IssuePriorityTest < ActiveSupport::TestCase
  20. fixtures :enumerations, :issues
  21. def setup
  22. User.current = nil
  23. end
  24. def test_named_scope
  25. assert_equal Enumeration.find_by_name('Normal'), Enumeration.named('normal').first
  26. end
  27. def test_default_should_return_the_default_priority
  28. assert_equal Enumeration.find_by_name('Normal'), IssuePriority.default
  29. end
  30. def test_default_should_return_nil_when_no_default_priority
  31. IssuePriority.update_all :is_default => false
  32. assert_nil IssuePriority.default
  33. end
  34. def test_default_or_middle_should_return_the_default_priority
  35. assert_equal Enumeration.find_by_name('Normal'), IssuePriority.default_or_middle
  36. end
  37. def test_default_or_middle_should_return_middle_when_no_default_priority
  38. IssuePriority.update_all :is_default => false
  39. assert_equal Enumeration.find_by_name('High'), IssuePriority.default_or_middle
  40. end
  41. def test_should_be_an_enumeration
  42. assert IssuePriority <= Enumeration
  43. end
  44. def test_objects_count
  45. # low priority
  46. assert_equal 6, IssuePriority.find(4).objects_count
  47. # urgent
  48. assert_equal 0, IssuePriority.find(7).objects_count
  49. end
  50. def test_option_name
  51. assert_equal :enumeration_issue_priorities, IssuePriority.new.option_name
  52. end
  53. def test_should_be_created_at_last_position
  54. IssuePriority.delete_all
  55. priorities = [1, 2, 3].map {|i| IssuePriority.create!(:name => "P#{i}")}
  56. assert_equal [1, 2, 3], priorities.map(&:position)
  57. end
  58. def test_clear_position_names_should_set_position_names_to_nil
  59. IssuePriority.clear_position_names
  60. assert IssuePriority.all.all? {|priority| priority.position_name.nil?}
  61. end
  62. def test_compute_position_names_with_default_priority
  63. IssuePriority.clear_position_names
  64. IssuePriority.compute_position_names
  65. assert_equal %w(lowest default high3 high2 highest), IssuePriority.active.to_a.sort.map(&:position_name)
  66. end
  67. def test_compute_position_names_without_default_priority_should_split_priorities
  68. IssuePriority.clear_position_names
  69. IssuePriority.update_all :is_default => false
  70. IssuePriority.compute_position_names
  71. assert_equal %w(lowest low2 default high2 highest), IssuePriority.active.to_a.sort.map(&:position_name)
  72. end
  73. def test_low_high_helpers
  74. IssuePriority.delete_all
  75. priorities = [1, 2, 3, 4, 5, 6].map {|i| IssuePriority.create!(:name => "P#{i}")}
  76. middle = IssuePriority.find_by_position(3)
  77. [1, 2].each do |p|
  78. assert IssuePriority.find_by_position(p).low?
  79. assert !IssuePriority.find_by_position(p).high?
  80. end
  81. assert !middle.high?
  82. assert !middle.low?
  83. [4, 5, 6].each do |p|
  84. assert IssuePriority.find_by_position(p).high?
  85. assert !IssuePriority.find_by_position(p).low?
  86. end
  87. default = IssuePriority.find_by_position(5)
  88. default.update is_default: true
  89. [1, 2, 3, 4].each do |p|
  90. assert IssuePriority.find_by_position(p).low?
  91. assert !IssuePriority.find_by_position(p).high?
  92. end
  93. assert !default.high?
  94. assert !default.low?
  95. [6].each do |p|
  96. assert IssuePriority.find_by_position(p).high?
  97. assert !IssuePriority.find_by_position(p).low?
  98. end
  99. end
  100. def test_adding_a_priority_should_update_position_names
  101. priority = IssuePriority.create!(:name => 'New')
  102. assert_equal %w(lowest default high4 high3 high2 highest), IssuePriority.active.to_a.sort.map(&:position_name)
  103. end
  104. def test_moving_a_priority_should_update_position_names
  105. prio = IssuePriority.first
  106. prio.position = IssuePriority.count
  107. prio.save!
  108. prio.reload
  109. assert_equal 'highest', prio.position_name
  110. end
  111. def test_deactivating_a_priority_should_update_position_names
  112. prio = IssuePriority.active.order(:position).last
  113. prio.active = false
  114. prio.save
  115. assert_equal 'highest', IssuePriority.active.order(:position).last.position_name
  116. end
  117. def test_changing_default_priority_should_update_position_names
  118. prio = IssuePriority.first
  119. prio.is_default = true
  120. prio.save
  121. assert_equal %w(default high4 high3 high2 highest), IssuePriority.active.to_a.sort.map(&:position_name)
  122. end
  123. def test_destroying_a_priority_should_update_position_names
  124. IssuePriority.find_by_position_name('highest').destroy
  125. assert_equal %w(lowest default high2 highest), IssuePriority.active.to_a.sort.map(&:position_name)
  126. end
  127. end