Removed unnecessary calculations in time entries index.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8085 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
9e5ed4208b
commit
1050993348
|
@ -320,8 +320,6 @@ private
|
||||||
end
|
end
|
||||||
|
|
||||||
@from, @to = @to, @from if @from && @to && @from > @to
|
@from, @to = @to, @from if @from && @to && @from > @to
|
||||||
@from ||= (TimeEntry.earilest_date_for_project(@project) || Date.today)
|
|
||||||
@to ||= (TimeEntry.latest_date_for_project(@project) || Date.today)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def parse_params_for_bulk_time_entry_attributes(params)
|
def parse_params_for_bulk_time_entry_attributes(params)
|
||||||
|
|
|
@ -53,10 +53,18 @@ class TimeEntry < ActiveRecord::Base
|
||||||
:include => :project,
|
:include => :project,
|
||||||
:conditions => project.project_condition(include_subprojects)
|
:conditions => project.project_condition(include_subprojects)
|
||||||
}}
|
}}
|
||||||
named_scope :spent_between, lambda {|from, to| {
|
named_scope :spent_between, lambda {|from, to|
|
||||||
:conditions => ["#{TimeEntry.table_name}.spent_on BETWEEN ? AND ?", from, to]
|
if from && to
|
||||||
}}
|
{:conditions => ["#{TimeEntry.table_name}.spent_on BETWEEN ? AND ?", from, to]}
|
||||||
|
elsif from
|
||||||
|
{:conditions => ["#{TimeEntry.table_name}.spent_on >= ?", from]}
|
||||||
|
elsif to
|
||||||
|
{:conditions => ["#{TimeEntry.table_name}.spent_on <= ?", to]}
|
||||||
|
else
|
||||||
|
{}
|
||||||
|
end
|
||||||
|
}
|
||||||
|
|
||||||
def after_initialize
|
def after_initialize
|
||||||
if new_record? && self.activity.nil?
|
if new_record? && self.activity.nil?
|
||||||
if default_activity = TimeEntryActivity.default
|
if default_activity = TimeEntryActivity.default
|
||||||
|
@ -96,20 +104,4 @@ class TimeEntry < ActiveRecord::Base
|
||||||
def editable_by?(usr)
|
def editable_by?(usr)
|
||||||
(usr == user && usr.allowed_to?(:edit_own_time_entries, project)) || usr.allowed_to?(:edit_time_entries, project)
|
(usr == user && usr.allowed_to?(:edit_own_time_entries, project)) || usr.allowed_to?(:edit_time_entries, project)
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.earilest_date_for_project(project=nil)
|
|
||||||
finder_conditions = ARCondition.new(Project.allowed_to_condition(User.current, :view_time_entries))
|
|
||||||
if project
|
|
||||||
finder_conditions << ["project_id IN (?)", project.hierarchy.collect(&:id)]
|
|
||||||
end
|
|
||||||
TimeEntry.minimum(:spent_on, :include => :project, :conditions => finder_conditions.conditions)
|
|
||||||
end
|
|
||||||
|
|
||||||
def self.latest_date_for_project(project=nil)
|
|
||||||
finder_conditions = ARCondition.new(Project.allowed_to_condition(User.current, :view_time_entries))
|
|
||||||
if project
|
|
||||||
finder_conditions << ["project_id IN (?)", project.hierarchy.collect(&:id)]
|
|
||||||
end
|
|
||||||
TimeEntry.maximum(:spent_on, :include => :project, :conditions => finder_conditions.conditions)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -270,8 +270,8 @@ class TimelogControllerTest < ActionController::TestCase
|
||||||
assert_not_nil assigns(:total_hours)
|
assert_not_nil assigns(:total_hours)
|
||||||
assert_equal "162.90", "%.2f" % assigns(:total_hours)
|
assert_equal "162.90", "%.2f" % assigns(:total_hours)
|
||||||
# display all time by default
|
# display all time by default
|
||||||
assert_equal '2007-03-12'.to_date, assigns(:from)
|
assert_nil assigns(:from)
|
||||||
assert_equal '2007-04-22'.to_date, assigns(:to)
|
assert_nil assigns(:to)
|
||||||
assert_tag :form,
|
assert_tag :form,
|
||||||
:attributes => {:action => "/projects/ecookbook/time_entries", :id => 'query_form'}
|
:attributes => {:action => "/projects/ecookbook/time_entries", :id => 'query_form'}
|
||||||
end
|
end
|
||||||
|
@ -320,9 +320,9 @@ class TimelogControllerTest < ActionController::TestCase
|
||||||
assert_equal 2, assigns(:entries).size
|
assert_equal 2, assigns(:entries).size
|
||||||
assert_not_nil assigns(:total_hours)
|
assert_not_nil assigns(:total_hours)
|
||||||
assert_equal 154.25, assigns(:total_hours)
|
assert_equal 154.25, assigns(:total_hours)
|
||||||
# display all time based on what's been logged
|
# display all time
|
||||||
assert_equal '2007-03-12'.to_date, assigns(:from)
|
assert_nil assigns(:from)
|
||||||
assert_equal '2007-04-22'.to_date, assigns(:to)
|
assert_nil assigns(:to)
|
||||||
# TODO: remove /projects/:project_id/issues/:issue_id/time_entries routes
|
# TODO: remove /projects/:project_id/issues/:issue_id/time_entries routes
|
||||||
# to use /issues/:issue_id/time_entries
|
# to use /issues/:issue_id/time_entries
|
||||||
assert_tag :form,
|
assert_tag :form,
|
||||||
|
|
|
@ -125,52 +125,4 @@ class TimeEntryTest < ActiveSupport::TestCase
|
||||||
:activity => activity)
|
:activity => activity)
|
||||||
assert_equal project.id, te.project.id
|
assert_equal project.id, te.project.id
|
||||||
end
|
end
|
||||||
|
|
||||||
context "#earilest_date_for_project" do
|
|
||||||
setup do
|
|
||||||
User.current = nil
|
|
||||||
@public_project = Project.generate!(:is_public => true)
|
|
||||||
@issue = Issue.generate_for_project!(@public_project)
|
|
||||||
TimeEntry.generate!(:spent_on => '2010-01-01',
|
|
||||||
: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
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context "with a project" do
|
|
||||||
should "return the lowest spent_on value that is visible to the current user for that project and it's subprojects only" do
|
|
||||||
assert_equal "2010-01-01", TimeEntry.earilest_date_for_project(@public_project).to_s
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
context "#latest_date_for_project" do
|
|
||||||
setup do
|
|
||||||
User.current = nil
|
|
||||||
@public_project = Project.generate!(:is_public => true)
|
|
||||||
@issue = Issue.generate_for_project!(@public_project)
|
|
||||||
TimeEntry.generate!(:spent_on => '2010-01-01',
|
|
||||||
:issue => @issue,
|
|
||||||
:project => @public_project)
|
|
||||||
end
|
|
||||||
|
|
||||||
context "without a project" do
|
|
||||||
should "return the highest spent_on value that is visible to the current user" do
|
|
||||||
assert_equal "2010-01-01", TimeEntry.latest_date_for_project.to_s
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context "with a project" do
|
|
||||||
should "return the highest spent_on value that is visible to the current user for that project and it's subprojects only" do
|
|
||||||
project = Project.find(1)
|
|
||||||
assert_equal "2007-04-22", TimeEntry.latest_date_for_project(project).to_s
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue