# Redmine - project management software # Copyright (C) 2006-2012 Jean-Philippe Lang # # 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. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. require File.expand_path('../../test_helper', __FILE__) class JournalTest < ActiveSupport::TestCase fixtures :projects, :issues, :issue_statuses, :journals, :journal_details, :users, :members, :member_roles def setup @journal = Journal.find 1 end def test_journalized_is_an_issue issue = @journal.issue assert_kind_of Issue, issue assert_equal 1, issue.id end def test_new_status status = @journal.new_status assert_not_nil status assert_kind_of IssueStatus, status assert_equal 2, status.id end def test_create_should_send_email_notification ActionMailer::Base.deliveries.clear issue = Issue.find(:first) user = User.find(:first) journal = issue.init_journal(user, issue) assert journal.save assert_equal 1, ActionMailer::Base.deliveries.size end def test_visible_scope_for_anonymous # Anonymous user should see issues of public projects only journals = Journal.visible(User.anonymous).all assert journals.any? assert_nil journals.detect {|journal| !journal.issue.project.is_public?} # Anonymous user should not see issues without permission Role.anonymous.remove_permission!(:view_issues) journals = Journal.visible(User.anonymous).all assert journals.empty? end def test_visible_scope_for_user user = User.find(9) assert user.projects.empty? # Non member user should see issues of public projects only journals = Journal.visible(user).all assert journals.any? assert_nil journals.detect {|journal| !journal.issue.project.is_public?} # Non member user should not see issues without permission Role.non_member.remove_permission!(:view_issues) user.reload journals = Journal.visible(user).all assert journals.empty? # User should see issues of projects for which he has view_issues permissions only Member.create!(:principal => user, :project_id => 1, :role_ids => [1]) user.reload journals = Journal.visible(user).all assert journals.any? assert_nil journals.detect {|journal| journal.issue.project_id != 1} end def test_visible_scope_for_admin user = User.find(1) user.members.each(&:destroy) assert user.projects.empty? journals = Journal.visible(user).all assert journals.any? # Admin should see issues on private projects that he does not belong to assert journals.detect {|journal| !journal.issue.project.is_public?} end end