Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

group_test.rb 4.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. # Redmine - project management software
  2. # Copyright (C) 2006-2017 Jean-Philippe Lang
  3. #
  4. # This program is free software; you can redistribute it and/or
  5. # modify it under the terms of the GNU General Public License
  6. # as published by the Free Software Foundation; either version 2
  7. # of the License, or (at your option) any later version.
  8. #
  9. # This program is distributed in the hope that it will be useful,
  10. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. # GNU General Public License for more details.
  13. #
  14. # You should have received a copy of the GNU General Public License
  15. # along with this program; if not, write to the Free Software
  16. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  17. require File.expand_path('../../test_helper', __FILE__)
  18. class GroupTest < ActiveSupport::TestCase
  19. fixtures :projects, :trackers, :issue_statuses, :issues,
  20. :enumerations, :users,
  21. :projects_trackers,
  22. :roles,
  23. :member_roles,
  24. :members,
  25. :groups_users
  26. include Redmine::I18n
  27. def setup
  28. User.current = nil
  29. end
  30. def test_create
  31. g = Group.new(:name => 'New group')
  32. assert g.save
  33. g.reload
  34. assert_equal 'New group', g.name
  35. end
  36. def test_name_should_accept_255_characters
  37. name = 'a' * 255
  38. g = Group.new(:name => name)
  39. assert g.save
  40. g.reload
  41. assert_equal name, g.name
  42. end
  43. def test_blank_name_error_message
  44. set_language_if_valid 'en'
  45. g = Group.new
  46. assert !g.save
  47. assert_include "Name cannot be blank", g.errors.full_messages
  48. end
  49. def test_blank_name_error_message_fr
  50. set_language_if_valid 'fr'
  51. str = "Nom doit \xc3\xaatre renseign\xc3\xa9(e)".force_encoding('UTF-8')
  52. g = Group.new
  53. assert !g.save
  54. assert_include str, g.errors.full_messages
  55. end
  56. def test_group_roles_should_be_given_to_added_user
  57. group = Group.find(11)
  58. user = User.find(9)
  59. project = Project.first
  60. Member.create!(:principal => group, :project => project, :role_ids => [1, 2])
  61. group.users << user
  62. assert user.member_of?(project)
  63. end
  64. def test_new_roles_should_be_given_to_existing_user
  65. group = Group.find(11)
  66. user = User.find(9)
  67. project = Project.first
  68. group.users << user
  69. m = Member.create!(:principal => group, :project => project, :role_ids => [1, 2])
  70. assert user.member_of?(project)
  71. end
  72. def test_user_roles_should_updated_when_updating_user_ids
  73. group = Group.find(11)
  74. user = User.find(9)
  75. project = Project.first
  76. Member.create!(:principal => group, :project => project, :role_ids => [1, 2])
  77. group.user_ids = [user.id]
  78. group.save!
  79. assert User.find(9).member_of?(project)
  80. group.user_ids = [1]
  81. group.save!
  82. assert !User.find(9).member_of?(project)
  83. end
  84. def test_user_roles_should_updated_when_updating_group_roles
  85. group = Group.find(11)
  86. user = User.find(9)
  87. project = Project.first
  88. group.users << user
  89. m = Member.create!(:principal => group, :project => project, :role_ids => [1])
  90. assert_equal [1], user.reload.roles_for_project(project).collect(&:id).sort
  91. m.role_ids = [1, 2]
  92. assert_equal [1, 2], user.reload.roles_for_project(project).collect(&:id).sort
  93. m.role_ids = [2]
  94. assert_equal [2], user.reload.roles_for_project(project).collect(&:id).sort
  95. m.role_ids = [1]
  96. assert_equal [1], user.reload.roles_for_project(project).collect(&:id).sort
  97. end
  98. def test_user_memberships_should_be_removed_when_removing_group_membership
  99. assert User.find(8).member_of?(Project.find(5))
  100. Member.find_by_project_id_and_user_id(5, 10).destroy
  101. assert !User.find(8).member_of?(Project.find(5))
  102. end
  103. def test_user_roles_should_be_removed_when_removing_user_from_group
  104. assert User.find(8).member_of?(Project.find(5))
  105. User.find(8).groups = []
  106. assert !User.find(8).member_of?(Project.find(5))
  107. end
  108. def test_destroy_should_unassign_issues
  109. group = Group.find(10)
  110. Issue.where(:id => 1).update_all(["assigned_to_id = ?", group.id])
  111. assert group.destroy
  112. assert group.destroyed?
  113. assert_nil Issue.find(1).assigned_to_id
  114. end
  115. def test_builtin_groups_should_be_created_if_missing
  116. Group.delete_all
  117. assert_difference 'Group.count', 2 do
  118. group = Group.anonymous
  119. assert_equal GroupAnonymous, group.class
  120. group = Group.non_member
  121. assert_equal GroupNonMember, group.class
  122. end
  123. end
  124. def test_builtin_in_group_should_be_uniq
  125. group = GroupAnonymous.new
  126. group.name = 'Foo'
  127. assert !group.save
  128. end
  129. def test_builtin_in_group_should_not_accept_users
  130. group = Group.anonymous
  131. assert_raise RuntimeError do
  132. group.users << User.find(1)
  133. end
  134. assert_equal 0, group.reload.users.count
  135. end
  136. def test_sorted_scope_should_sort_groups_alphabetically
  137. Group.delete_all
  138. b = Group.generate!(:name => 'B')
  139. a = Group.generate!(:name => 'A')
  140. assert_equal %w(A B), Group.sorted.to_a.map(&:name)
  141. end
  142. end