summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/views/timelog/_form.html.erb24
-rw-r--r--app/views/timelog/edit.js.erb1
-rw-r--r--test/functional/timelog_controller_test.rb39
3 files changed, 53 insertions, 11 deletions
diff --git a/app/views/timelog/_form.html.erb b/app/views/timelog/_form.html.erb
index 2d1134c4c..aa62ffc78 100644
--- a/app/views/timelog/_form.html.erb
+++ b/app/views/timelog/_form.html.erb
@@ -2,15 +2,14 @@
<%= back_url_hidden_field_tag %>
<div class="box tabular">
- <% if @time_entry.new_record? %>
- <% if params[:project_id] %>
- <%= hidden_field_tag 'project_id', params[:project_id] %>
- <% elsif params[:issue_id] %>
- <%= hidden_field_tag 'issue_id', params[:issue_id] %>
- <% else %>
- <p><%= f.select :project_id, project_tree_options_for_select(Project.allowed_to(:log_time).to_a, :selected => @time_entry.project, :include_blank => true), :required => true %></p>
- <% end %>
+ <% if @time_entry.new_record? && params[:project_id] %>
+ <%= hidden_field_tag 'project_id', params[:project_id] %>
+ <% elsif @time_entry.new_record? && params[:issue_id] %>
+ <%= hidden_field_tag 'issue_id', params[:issue_id] %>
+ <% else %>
+ <p><%= f.select :project_id, project_tree_options_for_select(Project.allowed_to(:log_time).to_a, :selected => @time_entry.project, :include_blank => true), :required => true %></p>
<% end %>
+
<p>
<%= f.text_field :issue_id, :size => 6, :required => Setting.timelog_required_fields.include?('issue_id') %>
<span id="time_entry_issue">
@@ -29,6 +28,9 @@
<%= javascript_tag do %>
$(document).ready(function(){
+ $('#time_entry_project_id').change(function(){
+ $('#time_entry_issue_id').val('');
+ });
$('#time_entry_project_id, #time_entry_issue_id').change(function(){
$.ajax({
url: '<%= escape_javascript(@time_entry.new_record? ? new_time_entry_path(:format => 'js') : edit_time_entry_path(:format => 'js')) %>',
@@ -45,10 +47,10 @@
term: request.term
};
var project_id;
- <% if @project %>
- project_id = '<%= @project.id %>';
+ <% if @time_entry.new_record? && @project %>
+ project_id = '<%= @project.id %>';
<% else %>
- project_id = $('#time_entry_project_id').val();
+ project_id = $('#time_entry_project_id').val();
<% end %>
if(project_id){
data['project_id'] = project_id;
diff --git a/app/views/timelog/edit.js.erb b/app/views/timelog/edit.js.erb
index cd7861140..4cba8cfe6 100644
--- a/app/views/timelog/edit.js.erb
+++ b/app/views/timelog/edit.js.erb
@@ -1 +1,2 @@
+$('#time_entry_activity_id').html('<%= escape_javascript options_for_select(activity_collection_for_select_options(@time_entry), @time_entry.activity_id) %>');
$('#time_entry_issue').html('<%= escape_javascript link_to_issue(@time_entry.issue) if @time_entry.issue.try(:visible?) %>');
diff --git a/test/functional/timelog_controller_test.rb b/test/functional/timelog_controller_test.rb
index baad0c95d..ead919006 100644
--- a/test/functional/timelog_controller_test.rb
+++ b/test/functional/timelog_controller_test.rb
@@ -125,6 +125,14 @@ class TimelogControllerTest < Redmine::ControllerTest
assert_select 'option', :text => '--- Please select ---'
end
+ def test_get_edit_should_show_projects_select
+ @request.session[:user_id] = 2
+ get :edit, :params => {:id => 2, :project_id => nil}
+ assert_response :success
+
+ assert_select 'select[name=?]', 'time_entry[project_id]'
+ end
+
def test_post_create
@request.session[:user_id] = 3
assert_difference 'TimeEntry.count' do
@@ -489,6 +497,37 @@ class TimelogControllerTest < Redmine::ControllerTest
assert_select_error /Issue is invalid/
end
+ def test_update_should_allow_to_change_project
+ entry = TimeEntry.generate!(:project_id => 1)
+
+ @request.session[:user_id] = 1
+ put :update, :params => {
+ :id => entry.id,
+ :time_entry => {
+ :project_id => '2'
+ }
+ }
+ assert_response 302
+ entry.reload
+
+ assert_equal 2, entry.project_id
+ end
+
+ def test_update_should_fail_with_issue_from_another_project
+ entry = TimeEntry.generate!(:project_id => 1, :issue_id => 1)
+
+ @request.session[:user_id] = 1
+ put :update, :params => {
+ :id => entry.id,
+ :time_entry => {
+ :project_id => '2'
+ }
+ }
+
+ assert_response :success
+ assert_select_error /Issue is invalid/
+ end
+
def test_get_bulk_edit
@request.session[:user_id] = 2