1 # Redmine - project management software
2 # Copyright (C) 2006-2011 Jean-Philippe Lang
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.
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.
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.
18 require File.expand_path('../../test_helper', __FILE__)
20 class JournalTest < ActiveSupport::TestCase
21 fixtures :projects, :issues, :issue_statuses, :journals, :journal_details, :users, :members, :member_roles
24 @journal = Journal.find 1
27 def test_journalized_is_an_issue
28 issue = @journal.issue
29 assert_kind_of Issue, issue
30 assert_equal 1, issue.id
34 status = @journal.new_status
36 assert_kind_of IssueStatus, status
37 assert_equal 2, status.id
40 def test_create_should_send_email_notification
41 ActionMailer::Base.deliveries.clear
42 issue = Issue.find(:first)
43 user = User.find(:first)
44 journal = issue.init_journal(user, issue)
47 assert_equal 1, ActionMailer::Base.deliveries.size
50 def test_visible_scope_for_anonymous
51 # Anonymous user should see issues of public projects only
52 journals = Journal.visible(User.anonymous).all
54 assert_nil journals.detect {|journal| !journal.issue.project.is_public?}
55 # Anonymous user should not see issues without permission
56 Role.anonymous.remove_permission!(:view_issues)
57 journals = Journal.visible(User.anonymous).all
58 assert journals.empty?
61 def test_visible_scope_for_user
63 assert user.projects.empty?
64 # Non member user should see issues of public projects only
65 journals = Journal.visible(user).all
67 assert_nil journals.detect {|journal| !journal.issue.project.is_public?}
68 # Non member user should not see issues without permission
69 Role.non_member.remove_permission!(:view_issues)
71 journals = Journal.visible(user).all
72 assert journals.empty?
73 # User should see issues of projects for which he has view_issues permissions only
74 Member.create!(:principal => user, :project_id => 1, :role_ids => [1])
76 journals = Journal.visible(user).all
78 assert_nil journals.detect {|journal| journal.issue.project_id != 1}
81 def test_visible_scope_for_admin
83 user.members.each(&:destroy)
84 assert user.projects.empty?
85 journals = Journal.visible(user).all
87 # Admin should see issues on private projects that he does not belong to
88 assert journals.detect {|journal| !journal.issue.project.is_public?}