Mercurial > hg > soundsoftware-site
diff test/unit/time_entry_test.rb @ 909:cbb26bc654de redmine-1.3
Update to Redmine 1.3-stable branch (Redmine SVN rev 8964)
author | Chris Cannam |
---|---|
date | Fri, 24 Feb 2012 19:09:32 +0000 |
parents | 07fa8a8b56a8 |
children | 433d4f72a19b |
line wrap: on
line diff
--- a/test/unit/time_entry_test.rb Fri Feb 24 18:36:29 2012 +0000 +++ b/test/unit/time_entry_test.rb Fri Feb 24 19:09:32 2012 +0000 @@ -1,16 +1,16 @@ -# redMine - project management software -# Copyright (C) 2006-2008 Jean-Philippe Lang +# Redmine - project management software +# Copyright (C) 2006-2011 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. @@ -18,7 +18,15 @@ require File.expand_path('../../test_helper', __FILE__) class TimeEntryTest < ActiveSupport::TestCase - fixtures :issues, :projects, :users, :time_entries + fixtures :issues, :projects, :users, :time_entries, + :members, :roles, :member_roles, :auth_sources, + :trackers, :issue_statuses, + :projects_trackers, + :journals, :journal_details, + :issue_categories, :enumerations, + :groups_users, + :enabled_modules, + :workflows def test_hours_format assertions = { "2" => 2.0, @@ -38,53 +46,86 @@ "3 hours" => 3.0, "12min" => 0.2, } - + assertions.each do |k, v| t = TimeEntry.new(:hours => k) assert_equal v, t.hours, "Converting #{k} failed:" end end - + def test_hours_should_default_to_nil assert_nil TimeEntry.new.hours end - + def test_spent_on_with_blank c = TimeEntry.new c.spent_on = '' assert_nil c.spent_on end - + def test_spent_on_with_nil c = TimeEntry.new c.spent_on = nil assert_nil c.spent_on end - + def test_spent_on_with_string c = TimeEntry.new c.spent_on = "2011-01-14" assert_equal Date.parse("2011-01-14"), c.spent_on end - + def test_spent_on_with_invalid_string c = TimeEntry.new c.spent_on = "foo" assert_nil c.spent_on end - + def test_spent_on_with_date c = TimeEntry.new c.spent_on = Date.today assert_equal Date.today, c.spent_on end - + def test_spent_on_with_time c = TimeEntry.new c.spent_on = Time.now assert_equal Date.today, c.spent_on end + def test_validate_time_entry + anon = User.anonymous + project = Project.find(1) + issue = Issue.new(:project_id => 1, :tracker_id => 1, :author_id => anon.id, :status_id => 1, + :priority => IssuePriority.all.first, :subject => 'test_create', + :description => 'IssueTest#test_create', :estimated_hours => '1:30') + assert issue.save + activity = TimeEntryActivity.find_by_name('Design') + te = TimeEntry.create(:spent_on => '2010-01-01', + :hours => 100000, + :issue => issue, + :project => project, + :user => anon, + :activity => activity) + assert_equal 1, te.errors.count + end + + def test_set_project_if_nil + anon = User.anonymous + project = Project.find(1) + issue = Issue.new(:project_id => 1, :tracker_id => 1, :author_id => anon.id, :status_id => 1, + :priority => IssuePriority.all.first, :subject => 'test_create', + :description => 'IssueTest#test_create', :estimated_hours => '1:30') + assert issue.save + activity = TimeEntryActivity.find_by_name('Design') + te = TimeEntry.create(:spent_on => '2010-01-01', + :hours => 10, + :issue => issue, + :user => anon, + :activity => activity) + assert_equal project.id, te.project.id + end + context "#earilest_date_for_project" do setup do User.current = nil @@ -94,7 +135,7 @@ :issue => @issue, :project => @public_project) end - + context "without a project" do should "return the lowest spent_on value that is visible to the current user" do assert_equal "2007-03-12", TimeEntry.earilest_date_for_project.to_s @@ -106,7 +147,7 @@ assert_equal "2010-01-01", TimeEntry.earilest_date_for_project(@public_project).to_s end end - + end context "#latest_date_for_project" do @@ -131,5 +172,5 @@ assert_equal "2007-04-22", TimeEntry.latest_date_for_project(project).to_s end end - end + end end