2011-05-30 00:11:52 +04:00
|
|
|
#-- copyright
|
|
|
|
# ChiliProject is a project management system.
|
2011-05-30 22:52:25 +04:00
|
|
|
#
|
2011-05-30 00:11:52 +04:00
|
|
|
# Copyright (C) 2010-2011 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")
|
2009-03-28 03:38:57 +03:00
|
|
|
assert_equal 1, ActionMailer::Base.deliveries.size
|
|
|
|
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
|
2007-11-08 22:00:37 +03:00
|
|
|
end
|