2011-10-29 16:19:11 +04:00
|
|
|
#-- encoding: UTF-8
|
2011-05-30 00:11:52 +04:00
|
|
|
#-- copyright
|
|
|
|
# ChiliProject is a project management system.
|
2011-05-30 22:52:25 +04:00
|
|
|
#
|
2012-01-03 23:36:40 +04:00
|
|
|
# Copyright (C) 2010-2012 the ChiliProject Team
|
2011-05-30 22:52:25 +04:00
|
|
|
#
|
2007-11-08 22:00:37 +03:00
|
|
|
# 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.
|
2011-05-30 22:52:25 +04:00
|
|
|
#
|
2011-05-30 00:11:52 +04:00
|
|
|
# See doc/COPYRIGHT.rdoc for more details.
|
|
|
|
#++
|
2010-12-13 02:24:34 +03:00
|
|
|
require File.expand_path('../../test_helper', __FILE__)
|
2007-11-08 22:00:37 +03:00
|
|
|
|
2009-09-13 21:14:35 +04:00
|
|
|
class JournalTest < ActiveSupport::TestCase
|
2011-07-08 23:44:42 +04:00
|
|
|
fixtures :issues, :issue_statuses, :journals, :enumerations
|
2007-11-08 22:00:37 +03:00
|
|
|
|
|
|
|
def setup
|
2011-05-07 01:28:04 +04:00
|
|
|
@journal = IssueJournal.find(1)
|
2007-11-08 22:00:37 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_journalized_is_an_issue
|
2010-08-05 21:05:04 +04:00
|
|
|
issue = @journal.journalized
|
2007-11-08 22:00:37 +03:00
|
|
|
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
|
2011-05-30 22:52:25 +04:00
|
|
|
assert_equal 2, status.id
|
2007-11-08 22:00:37 +03:00
|
|
|
end
|
2011-05-30 22:52:25 +04:00
|
|
|
|
2009-03-28 03:38:57 +03:00
|
|
|
def test_create_should_send_email_notification
|
|
|
|
ActionMailer::Base.deliveries.clear
|
|
|
|
issue = Issue.find(:first)
|
2010-11-05 16:14:00 +03:00
|
|
|
if issue.journals.empty?
|
2011-06-02 07:53:18 +04:00
|
|
|
issue.init_journal(User.current, "This journal represents the creationa of journal version 1")
|
2010-11-05 16:14:00 +03:00
|
|
|
issue.save
|
|
|
|
end
|
2009-03-28 03:38:57 +03:00
|
|
|
user = User.find(:first)
|
|
|
|
|
2010-08-05 21:05:04 +04:00
|
|
|
assert_equal 0, ActionMailer::Base.deliveries.size
|
2011-06-02 07:53:18 +04:00
|
|
|
issue.reload
|
2010-08-05 21:05:04 +04:00
|
|
|
issue.update_attribute(:subject, "New subject to trigger automatic journal entry")
|
2011-02-24 22:10:23 +03:00
|
|
|
assert_equal 2, ActionMailer::Base.deliveries.size
|
2009-03-28 03:38:57 +03:00
|
|
|
end
|
2011-05-30 22:52:25 +04:00
|
|
|
|
2011-03-30 21:40:00 +04:00
|
|
|
def test_create_should_not_send_email_notification_if_told_not_to
|
|
|
|
ActionMailer::Base.deliveries.clear
|
|
|
|
issue = Issue.find(:first)
|
|
|
|
user = User.find(:first)
|
2011-05-13 22:33:51 +04:00
|
|
|
journal = issue.init_journal(user, "A note")
|
2011-03-30 21:40:00 +04:00
|
|
|
JournalObserver.instance.send_notification = false
|
|
|
|
|
2011-05-13 22:33:51 +04:00
|
|
|
assert_difference("Journal.count") do
|
|
|
|
assert issue.save
|
|
|
|
end
|
2011-03-30 21:40:00 +04:00
|
|
|
assert_equal 0, ActionMailer::Base.deliveries.size
|
|
|
|
end
|
2011-06-04 00:01:56 +04:00
|
|
|
|
|
|
|
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
|
2011-08-27 20:26:12 +04:00
|
|
|
|
2011-06-04 00:01:56 +04:00
|
|
|
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
|
2011-08-27 20:26:12 +04:00
|
|
|
|
2011-06-02 07:53:18 +04:00
|
|
|
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
|
2011-07-02 03:28:13 +04:00
|
|
|
sleep(1) # TODO: massive hack to make sure the timestamps are different. switch to timecop later
|
2011-06-02 07:53:18 +04:00
|
|
|
|
|
|
|
assert_difference("Journal.count") do
|
|
|
|
@issue.init_journal(@user, "A note")
|
|
|
|
@issue.save
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_not_equal start, @issue.reload.updated_on
|
|
|
|
end
|
2011-07-08 23:43:03 +04:00
|
|
|
|
|
|
|
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
|
2011-07-12 03:55:28 +04:00
|
|
|
|
|
|
|
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
|
2011-11-17 13:36:44 +04:00
|
|
|
|
|
|
|
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
|
2007-11-08 22:00:37 +03:00
|
|
|
end
|