140 lines
4.2 KiB
Ruby
140 lines
4.2 KiB
Ruby
#-- encoding: UTF-8
|
|
#-- copyright
|
|
# ChiliProject is a project management system.
|
|
#
|
|
# Copyright (C) 2010-2013 the ChiliProject Team
|
|
#
|
|
# 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.
|
|
#
|
|
# See doc/COPYRIGHT.rdoc for more details.
|
|
#++
|
|
require File.expand_path('../../test_helper', __FILE__)
|
|
|
|
class JournalTest < ActiveSupport::TestCase
|
|
fixtures :issues, :issue_statuses, :journals, :enumerations,\
|
|
:users, :trackers, :projects, :members, :member_roles, :roles,\
|
|
:enabled_modules
|
|
|
|
def setup
|
|
@journal = IssueJournal.find(1)
|
|
end
|
|
|
|
def test_journalized_is_an_issue
|
|
issue = @journal.journalized
|
|
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 = issues :issues_001
|
|
|
|
assert_equal 0, ActionMailer::Base.deliveries.size
|
|
issue.update_attribute(:subject, "New subject to trigger automatic journal entry")
|
|
assert_equal 2, ActionMailer::Base.deliveries.size
|
|
end
|
|
|
|
def test_create_should_not_send_email_notification_if_told_not_to
|
|
ActionMailer::Base.deliveries.clear
|
|
issue = issues :issues_001
|
|
user = users :users_001
|
|
journal = issue.init_journal(user, "A note")
|
|
JournalObserver.instance.send_notification = false
|
|
|
|
assert_difference("Journal.count") do
|
|
assert issue.save
|
|
end
|
|
assert_equal 0, ActionMailer::Base.deliveries.size
|
|
end
|
|
|
|
test "creating the initial journal should track the changes from creation" do
|
|
@project = Project.generate!
|
|
issue = Issue.new do |i|
|
|
i.project = @project
|
|
i.subject = "Test initial journal"
|
|
i.tracker = @project.trackers.first
|
|
i.author = User.generate!
|
|
i.description = "Some content"
|
|
end
|
|
|
|
assert_difference("Journal.count") do
|
|
assert issue.save
|
|
end
|
|
|
|
journal = issue.reload.journals.first
|
|
assert_equal ["","Test initial journal"], journal.changes["subject"]
|
|
assert_equal [0, @project.id], journal.changes["project_id"]
|
|
assert_equal [nil, "Some content"], journal.changes["description"]
|
|
end
|
|
|
|
test "creating a journal should update the updated_on value of the parent record (touch)" do
|
|
@user = User.generate!
|
|
@project = Project.generate!
|
|
@issue = Issue.generate_for_project!(@project).reload
|
|
start = @issue.updated_on
|
|
sleep(1) # TODO: massive hack to make sure the timestamps are different. switch to timecop later
|
|
|
|
assert_difference("Journal.count") do
|
|
@issue.init_journal(@user, "A note")
|
|
@issue.save
|
|
end
|
|
|
|
assert_not_equal start, @issue.reload.updated_on
|
|
end
|
|
|
|
test "accessing #journaled on a Journal should not error (parent class)" do
|
|
journal = Journal.new
|
|
assert_nothing_raised do
|
|
assert_equal nil, journal.journaled
|
|
end
|
|
end
|
|
|
|
test "setting journal fields through the journaled object for creation" do
|
|
@issue = Issue.generate_for_project!(Project.generate!)
|
|
|
|
@issue.journal_user = @issue.author
|
|
@issue.journal_notes = 'Test setting fields on Journal from Issue'
|
|
assert_difference('Journal.count') do
|
|
assert @issue.save
|
|
end
|
|
|
|
assert_equal "Test setting fields on Journal from Issue", @issue.last_journal.notes
|
|
assert_equal @issue.author, @issue.last_journal.user
|
|
end
|
|
|
|
test "subclasses of journaled models should have journal of parent type" do
|
|
Ticket = Class.new(Issue)
|
|
|
|
project = Project.generate!
|
|
ticket = Ticket.new do |t|
|
|
t.project = project
|
|
t.subject = "Test initial journal"
|
|
t.tracker = project.trackers.first
|
|
t.author = User.generate!
|
|
t.description = "Some content"
|
|
end
|
|
|
|
begin
|
|
oldstdout = $stdout
|
|
$stdout = StringIO.new
|
|
ticket.save!
|
|
assert $stdout.string.empty?, "No errors should be logged to stdout."
|
|
ensure
|
|
$stdout = oldstdout
|
|
end
|
|
|
|
journal = ticket.journals.first
|
|
assert_equal IssueJournal, journal.class
|
|
end
|
|
end
|