tracks/test/controllers/todos_controller_test.rb

1210 lines
44 KiB
Ruby
Raw Normal View History

2014-05-16 18:03:13 -04:00
require 'test_helper'
class TodosControllerTest < ActionController::TestCase
def test_get_index_when_not_logged_in
get :index
assert_redirected_to login_url
end
2021-01-05 17:13:03 +02:00
def test_locale_index
login_as(:other_user_email)
get :index
assert_response 200
2021-01-05 17:13:03 +02:00
end
############################
# not done / deferred counts
############################
def test_not_done_counts
login_as(:admin_user)
get :index
assert_equal 2, projects(:timemachine).todos.active.count
assert_equal 3, contexts(:call).todos.not_completed.count
assert_equal 1, contexts(:lab).todos.not_completed.count
end
def test_cached_not_done_counts
login_as(:admin_user)
get :index
assert_equal 2, assigns['project_not_done_counts'][projects(:timemachine).id]
assert_equal 3, assigns['context_not_done_counts'][contexts(:call).id]
assert_equal 1, assigns['context_not_done_counts'][contexts(:lab).id]
end
2013-04-26 22:30:40 -05:00
def test_cached_not_done_counts_after_hiding_project
p = Project.find(1)
p.hide!
p.save!
login_as(:admin_user)
get :index
assert_nil assigns['project_not_done_counts'][projects(:timemachine).id]
assert_equal 2, assigns['context_not_done_counts'][contexts(:call).id]
assert_nil assigns['context_not_done_counts'][contexts(:lab).id]
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_not_done_counts_after_hiding_project
p = Project.find(1)
p.hide!
p.save!
login_as(:admin_user)
get :index
assert_equal 0, projects(:timemachine).todos.active.count
assert_equal 2, contexts(:call).todos.active.count
assert_equal 0, contexts(:lab).todos.active.count
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_not_done_counts_after_hiding_and_unhiding_project
p = Project.find(1)
p.hide!
p.save!
p.activate!
p.save!
login_as(:admin_user)
get :index
assert_equal 2, projects(:timemachine).todos.active.count
assert_equal 3, contexts(:call).todos.not_completed.count
assert_equal 1, contexts(:lab).todos.not_completed.count
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_deferred_count_for_project_source_view
login_as(:admin_user)
post :toggle_check, xhr: true, params: { :id => 5, :_source_view => 'project' }
2012-07-18 11:59:17 +02:00
assert_equal 1, assigns['remaining_deferred_or_pending_count']
post :toggle_check, xhr: true, params: { :id => 15, :_source_view => 'project' }
2012-07-18 11:59:17 +02:00
assert_equal 0, assigns['remaining_deferred_or_pending_count']
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
#########
# tagging
#########
2013-04-26 22:30:40 -05:00
def test_tag_is_retrieved_properly
login_as(:admin_user)
get :index
t = assigns['not_done_todos'].find{|t| t.id == 2}
assert_equal 1, t.tags.count
assert_equal 'foo', t.tags[0].name
assert !t.starred?
end
2013-04-26 22:30:40 -05:00
def test_tagging_changes_to_tag_with_numbers
# by default has_many_polymorph searches for tags with given id if the tag is a number. we do not want that
login_as(:admin_user)
assert_difference 'Todo.count' do
put :create, params: { :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{
"notes"=>"", "description"=>"test tags", "due"=>"30/11/2006"},
"tag_list"=>"1234,5667,9876" }
# default has_many_polymorphs will fail on these high numbers as tags with those id's do not exist
end
t = assigns['todo']
assert_equal t.description, "test tags"
assert_equal 3, t.tags.count
end
2013-04-26 22:30:40 -05:00
def test_tagging_changes_to_handle_empty_tags
# by default has_many_polymorph searches for tags with given id if the tag is a number. we do not want that
login_as(:admin_user)
assert_difference 'Todo.count' do
put :create, params: { :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{
"notes"=>"", "description"=>"test tags", "due"=>"30/11/2006"},
"tag_list"=>"a,,b" }
# default has_many_polymorphs will fail on the empty tag
end
t = assigns['todo']
assert_equal t.description, "test tags"
assert_equal 2, t.tags.count
end
2012-07-18 11:59:17 +02:00
def test_find_tagged_with
login_as(:admin_user)
@user = User.find(@request.session['user_id'])
tag = Tag.where(:name => 'foo').first.taggings
2012-07-18 11:59:17 +02:00
@tagged = tag.count
get :tag, params: { :name => 'foo' }
2012-07-18 11:59:17 +02:00
assert_response :success
assert_equal 3, @tagged
end
def test_find_tagged_with_terms_separated_with_dot
login_as :admin_user
create_todo(description: "test dotted tag", tag_list: "first.last, second")
t = assigns['todo']
assert_equal "first.last, second", t.tag_list
get :tag, params: { name: 'first.last.m' }
assert_equal "text/html", request.format, "controller should set right content type"
2020-08-20 18:33:36 +03:00
assert_equal "text/html", @response.media_type
assert_equal "first.last", assigns['tag_name'], ".m should be chomped"
get :tag, params: { name: 'first.last.txt' }
assert_equal "text/plain", request.format, "controller should set right content type"
2020-08-20 18:33:36 +03:00
assert_equal "text/plain", @response.media_type
assert_equal "first.last", assigns['tag_name'], ".txt should be chomped"
get :tag, params: { name: 'first.last' }
assert_equal "text/html", request.format, "controller should set right content type"
2020-08-20 18:33:36 +03:00
assert_equal "text/html", @response.media_type
assert_equal "first.last", assigns['tag_name'], ":name should be correct"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_get_boolean_expression_from_parameters_of_tag_view_single_tag
login_as(:admin_user)
get :tag, params: { :name => "single" }
2012-07-18 11:59:17 +02:00
assert_equal true, assigns['single_tag'], "should recognize it is a single tag name"
assert_equal "single", assigns['tag_expr'][0][0], "should store the single tag"
assert_equal "single", assigns['tag_name'], "should store the single tag name"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_get_boolean_expression_from_parameters_of_tag_view_multiple_tags
login_as(:admin_user)
get :tag, params: { :name => "multiple", :and => "tags", :and1 => "present", :and2 => "here" }
2012-07-18 11:59:17 +02:00
assert_equal false, assigns['single_tag'], "should recognize it has multiple tags"
assert_equal 4, assigns['tag_expr'].size, "should have 4 AND expressions"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_get_boolean_expression_from_parameters_of_tag_view_multiple_tags_without_digitless_and
login_as(:admin_user)
get :tag, params: { :name => "multiple", :and1 => "tags", :and2 => "present", :and3 => "here" }
2012-07-18 11:59:17 +02:00
assert_equal false, assigns['single_tag'], "should recognize it has multiple tags"
assert_equal 4, assigns['tag_expr'].size, "should have 4 AND expressions"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_get_boolean_expression_from_parameters_of_tag_view_multiple_ORs
login_as(:admin_user)
get :tag, params: { :name => "multiple,tags,present" }
2012-07-18 11:59:17 +02:00
assert_equal false, assigns['single_tag'], "should recognize it has multiple tags"
assert_equal 1, assigns['tag_expr'].size, "should have 1 expressions"
assert_equal 3, assigns['tag_expr'][0].size, "should have 3 ORs in 1st expression"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_get_boolean_expression_from_parameters_of_tag_view_multiple_ORs_and_ANDS
login_as(:admin_user)
get :tag, params: { :name => "multiple,tags,present", :and => "here,is,two", :and1=>"and,three" }
2012-07-18 11:59:17 +02:00
assert_equal false, assigns['single_tag'], "should recognize it has multiple tags"
assert_equal 3, assigns['tag_expr'].size, "should have 3 expressions"
assert_equal 3, assigns['tag_expr'][0].size, "should have 3 ORs in 1st expression"
assert_equal 3, assigns['tag_expr'][1].size, "should have 3 ORs in 2nd expression"
assert_equal 2, assigns['tag_expr'][2].size, "should have 2 ORs in 3rd expression"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_set_right_title_tag_page
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
get :tag, params: { :name => "foo" }
2012-07-18 11:59:17 +02:00
assert_equal "foo", assigns['tag_title']
get :tag, params: { :name => "foo,bar", :and => "baz" }
2012-07-18 11:59:17 +02:00
assert_equal "foo,bar AND baz", assigns['tag_title']
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_set_default_tag
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
get :tag, params: { :name => "foo" }
2012-07-18 11:59:17 +02:00
assert_equal "foo", assigns['initial_tags']
get :tag, params: { :name => "foo,bar", :and => "baz" }
2012-07-18 11:59:17 +02:00
assert_equal "foo", assigns['initial_tags']
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
###############
# creating todo
###############
2013-04-26 22:30:40 -05:00
def test_create_todo
assert_difference 'Todo.count' do
login_as(:admin_user)
put :create, params: { :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>"foo bar" }
end
end
2013-04-26 22:30:40 -05:00
def test_create_todo_via_xml
login_as(:admin_user)
assert_difference 'Todo.count' do
put :create, params: { :format => "xml", "request" => { "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>"foo bar" } }
assert_response 201
end
end
2013-04-26 22:30:40 -05:00
def test_create_todo_via_xhr
login_as(:admin_user)
assert_difference 'Todo.count' do
put :create, xhr: true, params: {
"context_name" => "library",
"project_name" => "Build a working time machine",
"todo" => {
"notes" => "",
"description" => "Call Warren Buffet to find out how much he makes per day",
"due" => "30/11/2006"
},
"tag_list" => "foo bar"
}
assert_response 200
end
end
2013-04-26 22:30:40 -05:00
def test_create_todo_via_xhr_context_view
login_as(:admin_user)
assert_difference 'Todo.count' do
put :create, xhr: true, params: {
"context_name" => "library",
"project_name" => "",
"todo" => {
"notes" => "",
"description" => "Read Warren Buffet's book",
"due" => "30/12/2006"
},
"_source_view" => "context",
"default_context_name" => "library",
"tag_list" => "bar foo"
}
assert_response 200
end
end
def test_fail_to_create_todo_via_xml
login_as(:admin_user)
# try to create with no context, which is not valid
put :create, params: { :format => "xml", "request" => {
"project_name"=>"Build a working time machine",
"todo"=>{"notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>"foo bar" } }
2012-04-27 14:22:16 +02:00
assert_response 409
assert_select "errors" do
assert_select "error", "Context can't be blank"
end
end
2013-04-26 22:30:40 -05:00
def test_create_deferred_todo
original_todo_count = Todo.count
login_as(:admin_user)
put :create, params: { :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2026", 'show_from' => '30/10/2026'}, "tag_list"=>"foo bar" }
assert_equal original_todo_count + 1, Todo.count
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_add_multiple_todos
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
start_count = Todo.count
put :create, params: { :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{
:multiple_todos=>"a\nb\nmuch \"ado\" about \'nothing\'"} }
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
assert_equal start_count+3, Todo.count, "two todos should have been added"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_add_multiple_todos_with_validation_error
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
long_string = "a" * 500
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
start_count = Todo.count
put :create, params: { :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{
:multiple_todos=>"a\nb\nmuch \"ado\" about \'nothing\'\n#{long_string}"} }
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
assert_equal start_count, Todo.count, "no todos should have been added"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_add_multiple_dependent_todos
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
start_count = Todo.count
put :create, params: { :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{
:multiple_todos=>"a\nb"}, :todos_sequential => 'true' }
put :create, params: { :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{
:multiple_todos=>"c\nd"}, :todos_sequential => 'false' }
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
assert_equal start_count+4, Todo.count, "four todos should have been added"
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
# find a,b,c and d
%w{a b c d}.each do |todo|
eval "@#{todo} = Todo.where(:description => '#{todo}').first"
2012-07-18 11:59:17 +02:00
eval "assert !@#{todo}.nil?, 'a todo with description \"#{todo}\" should just have been added'"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
assert @b.predecessors.include?(@a), "a should be a predeccesor of b"
assert !@d.predecessors.include?(@c), "c should not be a predecessor of d"
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
#########
# destroy
#########
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_destroy_todo
login_as(:admin_user)
post :destroy, xhr: true, params: { :id => 1, :_source_view => 'todo' }
todo = Todo.where(:id=>1).first
2012-07-18 11:59:17 +02:00
assert_nil todo
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
###############
# edit / update
###############
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_get_edit_form_using_xhr
login_as(:admin_user)
get :edit, xhr: true, params: { :id => todos(:call_bill).id }
2012-07-18 11:59:17 +02:00
assert_response 200
end
2013-04-26 22:30:40 -05:00
def test_update_todo_project
t = Todo.find(1)
login_as(:admin_user)
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>"foo bar" }
t = Todo.find(1)
assert_equal 1, t.project_id
end
2013-04-26 22:30:40 -05:00
def test_update_todo_due_date
t = Todo.find(1)
login_as(:admin_user)
due_today_date = Time.zone.now
due_tomorrow_date = due_today_date + 1.day
due_this_week_date = Time.zone.now.end_of_week - 1.day
due_next_week_date = due_this_week_date + 7.days - 1.day
due_this_month_date = Time.zone.now.end_of_month - 1.day
post :update, xhr: true, params: { :id => 1, :_source_view => 'calendar', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>due_today_date.strftime("%d/%m/%Y")}, "tag_list"=>"foo bar" }
assert_response 200
post :update, xhr: true, params: { :id => 1, :_source_view => 'calendar', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>due_tomorrow_date.strftime("%d/%m/%Y")}, "tag_list"=>"foo bar" }
assert_response 200
post :update, xhr: true, params: { :id => 1, :_source_view => 'calendar', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>due_this_week_date.strftime("%d/%m/%Y")}, "tag_list"=>"foo bar" }
assert_response 200
post :update, xhr: true, params: { :id => 1, :_source_view => 'calendar', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>due_next_week_date.strftime("%d/%m/%Y")}, "tag_list"=>"foo bar" }
assert_response 200
post :update, xhr: true, params: { :id => 1, :_source_view => 'calendar', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>due_this_month_date.strftime("%d/%m/%Y")}, "tag_list"=>"foo bar" }
assert_response 200
end
def test_update_todo_delete_project
t = Todo.find(1)
login_as(:admin_user)
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', "context_name"=>"library", "project_name"=>"", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>"foo bar" }
t = Todo.find(1)
assert_nil t.project_id
end
2013-04-26 22:30:40 -05:00
def test_update_todo_to_deferred_is_reflected_in_badge_count
login_as(:admin_user)
get :index
assert_equal 11, assigns['count']
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', "context_name"=>"library", "project_name"=>"Make more money than Billy Gates", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006", "show_from"=>"30/11/2030"}, "tag_list"=>"foo bar" }
assert_equal 10, assigns['down_count']
end
2013-04-26 22:30:40 -05:00
def test_update_todo
t = Todo.find(1)
login_as(:admin_user)
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', "todo"=>{"context_id"=>"1", "project_id"=>"2", "id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>"foo, bar" }
t = Todo.find(1)
assert_equal "Call Warren Buffet to find out how much he makes per day", t.description
assert_equal "bar, foo", t.tag_list
expected = Date.new(2006,11,30)
actual = t.due.to_date
2025-06-29 13:25:14 +03:00
assert_equal expected, actual, "Expected #{expected.to_formatted_s(:db)}, was #{actual.to_formatted_s(:db)}"
end
2013-04-26 22:30:40 -05:00
def test_update_todos_with_blank_project_name
t = Todo.find(1)
login_as(:admin_user)
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', :project_name => '', "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>"foo, bar" }
t.reload
assert t.project.nil?
end
2013-04-26 22:30:40 -05:00
def test_update_todo_tags_to_none
t = Todo.find(1)
login_as(:admin_user)
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', "todo"=>{"context_id"=>"1", "project_id"=>"2", "id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>"" }
t = Todo.find(1)
assert_equal true, t.tag_list.empty?
end
2013-04-26 22:30:40 -05:00
def test_update_todo_tags_with_whitespace_and_dots
t = Todo.find(1)
login_as(:admin_user)
taglist = " one , two,three ,four, 8.1.2, version1.5"
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', "todo"=>{"context_id"=>"1", "project_id"=>"2", "id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"30/11/2006"}, "tag_list"=>taglist }
t = Todo.find(1)
assert_equal "8.1.2, four, one, three, two, version1.5", t.tag_list
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_removing_hidden_project_activates_todo
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
# get a project and hide it, todos in the project should be hidden
p = projects(:timemachine)
p.hide!
assert p.reload().hidden?
todo = p.todos.first
2013-04-26 22:30:40 -05:00
assert todo.hidden?, 'todo should be hidden'
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
# clear project from todo: the todo should be unhidden
post :update, xhr: true, params: {
"id" => todo.id,
"_source_view" => 'todo',
"project_name" => "",
"todo" => {
"id" => todo.id
}
}
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
assert assigns['project_changed'], "the project of the todo should be changed"
todo = Todo.find(todo.id) # reload does not seem to work anymore
assert todo.active?, "todo should be active"
end
2012-07-18 11:59:17 +02:00
2012-07-18 12:26:46 +02:00
def test_change_context_of_todo
# called by dragging a todo to another context container
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
todo = Todo.find(1)
context = Context.find(2)
2013-04-26 22:30:40 -05:00
refute_equal todo.context.id, context.id
2013-04-26 22:30:40 -05:00
post :change_context, xhr: true, params: { :id => todo.id, :todo=>{:context_id => context.id}, :_source_view=>"todo" }
2012-07-18 12:26:46 +02:00
assert assigns['context_changed'], "context should have changed"
assert_equal todo.id, assigns['todo'].id, 'correct todo should have been found'
assert_equal context.id, todo.reload.context.id, 'context of todo should be changed'
end
2013-04-26 22:30:40 -05:00
def test_update_todo_due_in_calendar_view
t = Todo.find(1)
login_as(:admin_user)
post :update, xhr: true, params: { :id => 1, :_source_view => 'calendar', "context_name"=>"library", "project_name"=>"Build a working time machine", "todo"=>{"id"=>"1", "notes"=>"", "description"=>"Call Warren Buffet to find out how much he makes per day", "due"=>"31/11/2006"}, "tag_list"=>"foo bar" }
t = Todo.find(1)
assert_response 200
end
#######
# defer
#######
def test_update_clearing_show_from_makes_todo_active
t = Todo.find(1)
t.show_from = "01/01/2030"
assert t.deferred?
login_as(:admin_user)
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', "todo"=>{"show_from"=>""}, "tag_list"=>"" }
t = Todo.find(1)
assert t.active?
assert_nil t.show_from
end
def test_update_setting_show_from_makes_todo_deferred
t = Todo.find(1)
assert t.active?
login_as(:admin_user)
post :update, xhr: true, params: { :id => 1, :_source_view => 'todo', "todo"=>{"show_from"=>"01/01/2030"}, "tag_list"=>"" }
t = Todo.find(1)
assert t.deferred?
assert_not_nil t.show_from
end
def test_find_and_activate_ready
login_as(:admin_user)
# given a todo in the tickler that should be activated
travel_to 2.weeks.ago do
create_todo(
description: "tickler",
show_from: 1.week.from_now.
in_time_zone(users(:admin_user).prefs.time_zone).
strftime("#{users(:admin_user).prefs.date_format}"))
end
todos = Todo.where(description: "tickler").where('show_from < ?', Time.zone.now)
assert_equal 1, todos.count, "there should be one todo in tickler"
todo = todos.first
assert todo.deferred?, "todo should be in deferred state"
# index page calls find_and_activate_ready
get :index
todo.reload
assert todo.active?, "todo should have been activated"
assert todo.show_from.nil?, "show_from date should have been cleared"
end
2012-07-18 11:59:17 +02:00
#######
# feeds
#######
2013-04-26 22:30:40 -05:00
def test_rss_feed_not_completed
login_as(:admin_user)
get :index, params: { :format => "rss" }
2020-08-20 18:33:36 +03:00
assert_equal 'application/rss+xml', @response.media_type
2013-04-26 22:30:40 -05:00
assert_select 'rss[version="2.0"]' do
assert_select 'channel' do
assert_select '>title', 'Tracks Actions'
assert_select '>description', "Actions for #{users(:admin_user).display_name}"
assert_select 'language', 'en-us'
assert_select 'ttl', '40'
assert_select 'item', 11 do
assert_select 'title', /.+/
assert_select 'description', /.*/
assert_select 'link', %r{http://test.host/contexts/.+}
assert_select 'guid', %r{http://test.host/todos/.+}
2025-06-29 13:25:14 +03:00
assert_select 'pubDate', todos(:call_bill_gates_every_day).created_at.to_formatted_s(:rfc822)
end
end
end
end
2013-04-26 22:30:40 -05:00
def test_atom_feed_not_completed
login_as :admin_user
get :index, params: { :format => "atom" }
2020-08-20 18:33:36 +03:00
assert_equal 'application/atom+xml', @response.media_type
2016-10-15 13:13:02 -04:00
assert_equal 'http://www.w3.org/2005/Atom', html_document.children[0].namespace.href
assert_select 'feed' do
assert_select '>title', 'Tracks Actions'
assert_select '>subtitle', "Actions for #{users(:admin_user).display_name}"
assert_select 'entry', 11 do
assert_select 'title', /.+/
assert_select 'content[type="html"]', /.*/
assert_select 'published', /(#{Regexp.escape(todos(:book).updated_at.xmlschema)}|#{Regexp.escape(projects(:moremoney).updated_at.xmlschema)})/
end
end
end
def test_text_feed_not_completed
login_as(:admin_user)
get :index, params: { :format => "txt" }
2020-08-20 18:33:36 +03:00
assert_equal 'text/plain', @response.media_type
assert !(/&nbsp;/.match(@response.body))
assert_number_of_items_in_text_feed 11
end
def test_ical_feed_not_completed
login_as :admin_user
get :index, params: { :format => "ics" }
2020-08-20 18:33:36 +03:00
assert_equal 'text/calendar', @response.media_type
assert !(/&nbsp;/.match(@response.body))
assert_number_of_items_in_ical_feed 11
end
def test_rss_feed_completed_in_last_week
login_as(:admin_user)
get :index, params: { :format => "rss", :done => '7' }
assert_number_of_items_in_rss_feed 3
end
def test_atom_feed_completed_in_last_week
login_as(:admin_user)
get :index, params: { :format => "atom", :done => '7' }
assert_number_of_items_in_atom_feed 3
end
def test_text_feed_completed_in_last_week
login_as(:admin_user)
get :index, params: { :format => "text", :done => '7' }
assert_number_of_items_in_text_feed 3
end
def test_ical_feed_completed_in_last_week
login_as(:admin_user)
get :index, params: { :format => "ics", :done => '7' }
assert_number_of_items_in_ical_feed 3
end
def test_rss_feed_with_limit
login_as(:admin_user)
get :index, params: { :format => "rss", :limit => '5' }
2013-04-26 22:30:40 -05:00
assert_number_of_items_in_rss_feed 5
end
def test_atom_feed_with_limit
login_as(:admin_user)
get :index, params: { :format => "atom", :limit => '5' }
assert_number_of_items_in_atom_feed 5
end
def test_text_feed_with_limit
login_as(:admin_user)
get :index, params: { :format => "text", :limit => '5' }
assert_number_of_items_in_text_feed 5
end
def test_ical_feed_with_limit
login_as(:admin_user)
get :index, params: { :format => "ics", :limit => '5' }
assert_number_of_items_in_ical_feed 5
end
def test_rss_feed_filter_by_context
login_as(:admin_user)
get :index, params: { :format => "rss", :context_id => 2 }
assert_number_of_items_in_rss_feed 3
end
def test_atom_feed_filter_by_context
login_as(:admin_user)
get :index, params: { :format => "atom", :context_id => 2 }
assert_number_of_items_in_atom_feed 3
end
def test_text_feed_filter_by_context
login_as(:admin_user)
get :index, params: { :format => "text", :context_id => 2 }
assert_number_of_items_in_text_feed 3
end
def test_ical_feed_filter_by_context
login_as(:admin_user)
get :index, params: { :format => "ics", :context_id => 2 }
assert_number_of_items_in_ical_feed 3
end
def test_rss_feed_filter_by_project
login_as(:admin_user)
get :index, params: { :format => "rss", :project_id => 2 }
assert_number_of_items_in_rss_feed 4
end
def test_atom_feed_filter_by_project
login_as(:admin_user)
get :index, params: { :format => "atom", :project_id => 2 }
assert_number_of_items_in_atom_feed 4
end
def test_text_feed_filter_by_project
login_as(:admin_user)
get :index, params: { :format => "text", :project_id => 2 }
assert_number_of_items_in_text_feed 4
end
def test_ical_feed_filter_by_project
login_as(:admin_user)
get :index, params: { :format => "ics", :project_id => 2 }
assert_number_of_items_in_ical_feed 4
end
def test_rss_feed_filter_by_project_and_context
login_as(:admin_user)
get :index, params: { :format => "rss", :project_id => 2, :context_id => 2 }
assert_number_of_items_in_rss_feed 1
end
def test_atom_feed_filter_by_project_and_context
login_as(:admin_user)
get :index, params: { :format => "atom", :project_id => 2, :context_id => 2 }
assert_number_of_items_in_atom_feed 1
end
def test_text_feed_filter_by_project_and_context
login_as(:admin_user)
get :index, params: { :format => "text", :project_id => 2, :context_id => 2 }
assert_number_of_items_in_text_feed 1
end
def test_ical_feed_filter_by_project_and_context
login_as(:admin_user)
get :index, params: { :format => "ics", :project_id => 2, :context_id => 2 }
assert_number_of_items_in_ical_feed 1
end
2013-04-26 22:30:40 -05:00
def test_rss_feed_not_accessible_to_anonymous_user_without_token
login_as nil
get :index, params: { :format => "rss" }
assert_response 401
end
2013-04-26 22:30:40 -05:00
def test_atom_feed_not_accessible_to_anonymous_user_without_token
login_as nil
get :index, params: { :format => "atom" }
assert_response 401
end
2013-04-26 22:30:40 -05:00
def test_text_feed_not_accessible_to_anonymous_user_without_token
login_as nil
get :index, params: { :format => "txt" }
assert_response 401
end
2013-04-26 22:30:40 -05:00
def test_rss_feed_not_accessible_to_anonymous_user_with_invalid_token
login_as nil
get :index, params: { :format => "rss", :token => 'foo' }
assert_response 401
end
2013-04-26 22:30:40 -05:00
def test_atom_feed_not_accessible_to_anonymous_user_with_invalid_token
login_as nil
get :index, params: { :format => "atom", :token => 'foo' }
assert_response 401
end
2013-04-26 22:30:40 -05:00
def test_text_feed_not_accessible_to_anonymous_user_with_invalid_token
login_as nil
get :index, params: { :format => "txt", :token => 'foo' }
assert_response 401
end
def test_rss_feed_accessible_to_anonymous_user_with_valid_token
login_as nil
get :index, params: { :format => "rss", :token => users(:admin_user).token }
assert_response :ok
end
def test_atom_feed_accessible_to_anonymous_user_with_valid_token
login_as nil
get :index, params: { :format => "atom", :token => users(:admin_user).token }
assert_response :ok
end
2013-04-26 22:30:40 -05:00
def test_text_feed_accessible_to_anonymous_user_with_valid_token
login_as nil
get :index, params: { :format => "txt", :token => users(:admin_user).token }
assert_response :ok
end
2013-04-26 22:30:40 -05:00
def test_ical_feed_accessible_to_anonymous_user_with_valid_token
login_as nil
get :index, params: { :format => "ics", :token => users(:admin_user).token }
assert_response :ok
end
2013-04-26 22:30:40 -05:00
def test_tag_rss_feed_not_accessible_to_anonymous_user_without_token
login_as nil
get :tag, params: {:name => "foo", :format => "rss" }
assert_response 401
end
2013-04-26 22:30:40 -05:00
def test_tag_atom_feed_not_accessible_to_anonymous_user_without_token
login_as nil
get :tag, params: {:name => "foo", :format => "atom" }
assert_response 401
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
def test_tag_text_feed_not_accessible_to_anonymous_user_without_token
login_as nil
get :tag, params: {:name => "foo", :format => "txt" }
2012-07-18 11:59:17 +02:00
assert_response 401
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
##############
# mobile index
##############
2013-04-26 22:30:40 -05:00
def test_mobile_index_uses_text_html_content_type
login_as(:admin_user)
get :index, params: { :format => "m" }
2020-08-20 18:33:36 +03:00
assert_equal 'text/html', @response.media_type
end
2013-04-26 22:30:40 -05:00
def test_mobile_index_assigns_down_count
login_as(:admin_user)
get :index, params: { :format => "m" }
assert_equal 11, assigns['down_count']
end
2013-04-26 22:30:40 -05:00
def test_mobile_redirect_to_login
get :index, params: { :format => "m" }
assert_redirected_to login_url(:format => "m")
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
###############
# mobile create
###############
2013-04-26 22:30:40 -05:00
def test_mobile_create_action_creates_a_new_todo
login_as(:admin_user)
post :create, params: {"format"=>"m", "todo"=>{"context_id"=>"2",
"due(1i)"=>"2007", "due(2i)"=>"1", "due(3i)"=>"2",
"show_from(1i)"=>"", "show_from(2i)"=>"", "show_from(3i)"=>"",
"project_id"=>"1",
"notes"=>"test notes", "description"=>"test_mobile_create_action"}}
t = Todo.where(:description => "test_mobile_create_action").first
assert_not_nil t
assert_equal 2, t.context_id
assert_equal 1, t.project_id
assert t.active?
assert_equal 'test notes', t.notes
assert_nil t.show_from
assert_equal Date.new(2007,1,2), t.due.to_date
end
2013-04-26 22:30:40 -05:00
def test_mobile_create_action_redirects_to_mobile_home_page_when_successful
login_as(:admin_user)
post :create, params: {"format"=>"m", "todo"=>{"context_id"=>"2",
"due(1i)"=>"2007", "due(2i)"=>"1", "due(3i)"=>"2",
"show_from(1i)"=>"", "show_from(2i)"=>"", "show_from(3i)"=>"",
"project_id"=>"1",
"notes"=>"test notes", "description"=>"test_mobile_create_action"}}
assert_redirected_to '/mobile'
end
2013-04-26 22:30:40 -05:00
def test_mobile_create_action_renders_new_template_when_save_fails
login_as(:admin_user)
post :create, params: {"format"=>"m", "todo"=>{"context_id"=>"2",
"due(1i)"=>"2007", "due(2i)"=>"1", "due(3i)"=>"2",
"show_from(1i)"=>"", "show_from(2i)"=>"", "show_from(3i)"=>"",
"project_id"=>"1",
"notes"=>"test notes"}, "tag_list"=>"test, test2"}
assert_template 'todos/new'
end
2013-04-26 22:30:40 -05:00
2012-07-18 11:59:17 +02:00
################
# recurring todo
################
2013-04-26 22:30:40 -05:00
def test_toggle_check_on_recurring_todo
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
# link todo_1 and recurring_todo_1
recurring_todo_1 = RecurringTodo.find(1)
todo_1 = Todo.where(:recurring_todo_id => 1).first
2013-04-26 22:30:40 -05:00
# mark todo_1 as complete by toggle_check
post :toggle_check, xhr: true, params: { :id => todo_1.id, :_source_view => 'todo' }
todo_1.reload
assert todo_1.completed?
2013-04-26 22:30:40 -05:00
# check that there is only one active todo belonging to recurring_todo
count = Todo.where(:recurring_todo_id => recurring_todo_1.id, :state => 'active').count
assert_equal 1, count
2013-04-26 22:30:40 -05:00
# check there is a new todo linked to the recurrence pattern
next_todo = Todo.where(:recurring_todo_id => recurring_todo_1.id, :state => 'active').first
assert_equal "Call Bill Gates every day", next_todo.description
# check that the new todo is not the same as todo_1
refute_equal todo_1.id, next_todo.id
2013-04-26 22:30:40 -05:00
# change recurrence pattern to monthly and set show_from 2 days before due
# date this forces the next todo to be put in the tickler
recurring_todo_1.show_from_delta = 2
recurring_todo_1.show_always = 0
recurring_todo_1.target = 'due_date'
recurring_todo_1.recurring_period = 'monthly'
recurring_todo_1.recurrence_selector = 0
recurring_todo_1.every_other1 = 1
recurring_todo_1.every_other2 = 2
recurring_todo_1.every_other3 = 5
# use assert to catch validation errors if present. we need to replace
# this with a good factory implementation
assert recurring_todo_1.save
2013-04-26 22:30:40 -05:00
# mark next_todo as complete by toggle_check
post :toggle_check, xhr: true, params: { :id => next_todo.id, :_source_view => 'todo' }
next_todo.reload
assert next_todo.completed?
2013-04-26 22:30:40 -05:00
# check that there are three todos belonging to recurring_todo: two
# completed and one deferred
count = Todo.where(:recurring_todo_id => recurring_todo_1.id).count
assert_equal 3, count
2013-04-26 22:30:40 -05:00
# check there is a new todo linked to the recurrence pattern in the tickler
next_todo = Todo.where(:recurring_todo_id => recurring_todo_1.id, :state => 'deferred').first
assert !next_todo.nil?
assert_equal "Call Bill Gates every day", next_todo.description
# check that the todo is in the tickler
assert !next_todo.show_from.nil?
end
2013-04-26 22:30:40 -05:00
def test_toggle_check_on_rec_todo_show_from_today
# warning: the Time.zone set in site.yml will be overwritten by
# :admin_user.prefs.time_zone in ApplicationController. This messes with
# the calculation. So set time_zone to admin_user's time_zone setting
Time.zone = users(:admin_user).prefs.time_zone
travel_to Time.zone.local(2014, 1, 15) do
today = Time.zone.now.at_midnight
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
# link todo_1 and recurring_todo_1
recurring_todo_1 = RecurringTodo.find(1)
todo_1 = Todo.where(:recurring_todo_id => 1).first
todo_1.due = today
assert todo_1.save
2013-04-26 22:30:40 -05:00
# change recurrence pattern to monthly on a specific
# day (recurrence_selector=0) and set show_from
# (every_other2=1) to today
recurring_todo_1.target = 'show_from_date'
recurring_todo_1.recurring_period = 'monthly'
recurring_todo_1.recurrence_selector = 0
recurring_todo_1.every_other1 = today.day
recurring_todo_1.every_other2 = 1
assert recurring_todo_1.save
2013-04-26 22:30:40 -05:00
# mark todo_1 as complete by toggle_check
post :toggle_check, xhr: true, params: { :id => todo_1.id, :_source_view => 'todo' }
todo_1.reload
assert todo_1.completed?
2013-04-26 22:30:40 -05:00
# locate the new todo in tickler
new_todo = Todo.where(:recurring_todo_id => recurring_todo_1.id, :state => 'deferred').first
assert !new_todo.nil?, "the todo should be in the tickler"
2013-04-26 22:30:40 -05:00
assert_equal "Call Bill Gates every day", new_todo.description
refute_equal todo_1.id, new_todo.id, "check that the new todo is not the same as todo_1"
assert !new_todo.show_from.nil?, "check that the new_todo is in the tickler to show next month"
2013-04-26 22:30:40 -05:00
assert_equal today + 1.month, new_todo.show_from
end
end
2013-04-26 22:30:40 -05:00
def test_check_for_next_todo
login_as :admin_user
Time.zone = users(:admin_user).prefs.time_zone
2013-04-26 22:30:40 -05:00
2013-09-05 17:14:01 +02:00
tomorrow = Time.zone.now + 1.day
# Given a recurrence pattern with recurring date set to tomorrow
recurring_todo_1 = RecurringTodo.find(5)
2013-09-05 17:14:01 +02:00
recurring_todo_1.every_other1 = tomorrow.day
recurring_todo_1.every_other2 = tomorrow.month
recurring_todo_1.save
2013-04-26 22:30:40 -05:00
# Given a recurring todo (todo) that belongs to the recurrence pattern (recurring_todo_1) and is due tomorrow
2013-09-05 17:14:01 +02:00
todo = Todo.where(:recurring_todo_id => 1).first
assert todo.from_recurring_todo?
todo.recurring_todo_id = 5 # rewire todo to the recurrence pattern above
2013-09-05 17:14:01 +02:00
todo.due = tomorrow
todo.save!
# When I mark the todo complete
post :toggle_check, xhr: true, params: { :id => todo.id, :_source_view => 'todo' }
2013-09-05 17:14:01 +02:00
todo = Todo.find(todo.id) #reload does not seem to work here
assert todo.completed?
2013-04-26 22:30:40 -05:00
# Then there should not be an active todo belonging to the recurrence pattern
2013-05-11 23:13:16 +02:00
next_todo = Todo.where(:recurring_todo_id => recurring_todo_1.id, :state => 'active').first
assert next_todo.nil?
2013-04-26 22:30:40 -05:00
2013-09-05 17:14:01 +02:00
# Then there should be one new deferred todo
2013-05-11 23:13:16 +02:00
next_todo = Todo.where(:recurring_todo_id => recurring_todo_1.id, :state => 'deferred').first
assert !next_todo.nil?
2013-09-05 17:14:01 +02:00
assert !next_todo.show_from.nil?
# check that the due date of the new todo is later than tomorrow
2013-09-05 17:14:01 +02:00
assert next_todo.due > todo.due
end
2012-07-18 11:59:17 +02:00
2013-09-14 00:09:00 -07:00
def test_check_for_next_todo_monthly
login_as :admin_user
Time.zone = users(:admin_user).prefs.time_zone
2013-09-14 00:09:00 -07:00
tomorrow = Time.zone.now + 1.day
# Given a monthly recurrence pattern
2013-09-14 00:09:00 -07:00
recurring_todo = RecurringTodo.find(5)
recurring_todo.target = "due_date"
recurring_todo.recurring_period = "monthly"
recurring_todo.every_other1 = tomorrow.day
recurring_todo.every_other2 = 1
recurring_todo.save
# Given a recurring todo (todo) that belongs to the recurrence pattern (recurring_todo) and is due tomorrow
2013-09-14 00:09:00 -07:00
todo = Todo.where(:recurring_todo_id => 1).first
assert todo.from_recurring_todo?
todo.recurring_todo_id = 5 # rewire todo to the recurrence pattern above
2013-09-14 00:09:00 -07:00
todo.due = tomorrow
todo.save!
# When I mark the todo complete
post :toggle_check, xhr: true, params: { :id => todo.id, :_source_view => 'todo' }
2013-09-14 00:09:00 -07:00
todo.reload
assert todo.completed?
# Then there should not be an active todo belonging to the recurrence pattern
2013-09-14 00:09:00 -07:00
next_todo = Todo.where(:recurring_todo_id => recurring_todo.id, :state => 'active').first
assert next_todo.nil?
# Then there should be one new deferred todo
next_todo = Todo.where(:recurring_todo_id => recurring_todo.id, :state => 'deferred').first
assert !next_todo.nil?
assert !next_todo.show_from.nil?
# check that the due date of the new todo is later than tomorrow
assert next_todo.due > todo.due
end
2012-07-18 11:59:17 +02:00
############
# todo notes
############
2013-04-26 22:30:40 -05:00
def test_format_note
login_as(:admin_user)
todo = users(:admin_user).todos.where("state='active'").first
todo.notes = "Normal *bold* http://foo.bar/baz"
todo.save!
get :index
assert_select("div#notes_todo_#{todo.id}", "Normal bold http://foo.bar/baz")
assert_select("a[href='http://foo.bar/baz']", "http://foo.bar/baz")
assert_select("a[target='_blank']")
assert_select("strong", "bold")
end
2012-07-18 11:59:17 +02:00
##############
# dependencies
##############
2013-04-26 22:30:40 -05:00
def test_make_todo_dependent
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
predecessor = todos(:call_bill)
successor = todos(:call_dino_ext)
2013-04-26 22:30:40 -05:00
# no predecessors yet
assert_equal 0, successor.predecessors.size
2013-04-26 22:30:40 -05:00
# add predecessor
put :add_predecessor, params: { :predecessor=>predecessor.id, :successor=>successor.id, :format => "js" }
2013-04-26 22:30:40 -05:00
assert_equal 1, successor.predecessors.count
2014-07-01 22:45:04 +02:00
assert_equal predecessor.id, successor.predecessors.reload.first.id
end
2013-04-26 22:30:40 -05:00
def test_make_todo_with_dependencies_dependent
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
predecessor = todos(:call_bill)
successor = todos(:call_dino_ext)
other_todo = todos(:phone_grandfather)
2013-04-26 22:30:40 -05:00
# predecessor -> successor
put :add_predecessor, params: { :predecessor=>predecessor.id, :successor=>successor.id, :format => "js" }
2013-04-26 22:30:40 -05:00
# other_todo -> predecessor -> successor
put :add_predecessor, params: { :predecessor=>other_todo.id, :successor=>predecessor.id, :format => "js" }
2013-04-26 22:30:40 -05:00
assert_equal 1, successor.predecessors.reload.count
assert_equal 0, other_todo.predecessors.reload.count
assert_equal 1, predecessor.predecessors.reload.count
assert_equal predecessor.id, successor.predecessors.first.id
assert_equal other_todo.id, predecessor.predecessors.first.id
end
2013-04-26 22:30:40 -05:00
def test_mingle_dependent_todos_leave
# based on #1271
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
t1 = todos(:call_bill)
t2 = todos(:call_dino_ext)
t3 = todos(:phone_grandfather)
t4 = todos(:construct_dilation_device)
2013-04-26 22:30:40 -05:00
# t1 -> t2
put :add_predecessor, params: { :predecessor=>t1.id, :successor=>t2.id, :format => "js" }
# t3 -> t4
put :add_predecessor, params: { :predecessor=>t3.id, :successor=>t4.id, :format => "js" }
2013-04-26 22:30:40 -05:00
# t2 -> t4
put :add_predecessor, params: { :predecessor=>t2.id, :successor=>t4.id, :format => "js" }
2013-04-26 22:30:40 -05:00
# should be: t1 -> t2 -> t4 and t3 -> t4
assert t4.predecessors.map(&:id).include?(t2.id)
assert t4.predecessors.map(&:id).include?(t3.id)
assert t2.predecessors.map(&:id).include?(t1.id)
end
2013-04-26 22:30:40 -05:00
def test_mingle_dependent_todos_root
# based on #1271
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
t1 = todos(:call_bill)
t2 = todos(:call_dino_ext)
t3 = todos(:phone_grandfather)
t4 = todos(:construct_dilation_device)
2013-04-26 22:30:40 -05:00
# t1 -> t2
put :add_predecessor, params: { :predecessor=>t1.id, :successor=>t2.id, :format => "js" }
# t3 -> t4
put :add_predecessor, params: { :predecessor=>t3.id, :successor=>t4.id, :format => "js" }
2013-04-26 22:30:40 -05:00
# t3 -> t2
put :add_predecessor, params: { :predecessor=>t3.id, :successor=>t2.id, :format => "js" }
2013-04-26 22:30:40 -05:00
# should be: t1 -> t2 and t3 -> t4 & t2
assert t3.successors.map(&:id).include?(t4.id)
assert t3.successors.map(&:id).include?(t2.id)
assert t2.predecessors.map(&:id).include?(t1.id)
assert t2.predecessors.map(&:id).include?(t3.id)
end
2013-04-26 22:30:40 -05:00
def test_unmingle_dependent_todos
# based on #1271
login_as(:admin_user)
2013-04-26 22:30:40 -05:00
t1 = todos(:call_bill)
t2 = todos(:call_dino_ext)
t3 = todos(:phone_grandfather)
t4 = todos(:construct_dilation_device)
2013-04-26 22:30:40 -05:00
# create same dependency tree as previous test
# should be: t1 -> t2 -> t4 and t3 -> t4
put :add_predecessor, params: { :predecessor=>t1.id, :successor=>t2.id, :format => "js" }
put :add_predecessor, params: { :predecessor=>t3.id, :successor=>t4.id, :format => "js" }
put :add_predecessor, params: { :predecessor=>t2.id, :successor=>t4.id, :format => "js" }
2013-04-26 22:30:40 -05:00
# removing t4 as successor of t2 should leave t4 blocked with t3 as predecessor
put :remove_predecessor, params: { :predecessor=>t2.id, :id=>t4.id, :format => "js" }
2013-04-26 22:30:40 -05:00
t4.reload
assert t4.pending?, "t4 should remain pending"
assert t4.predecessors.map(&:id).include?(t3.id)
end
def test_do_not_activate_done_successors
login_as(:admin_user)
predecessor = Todo.find(1)
successor = Todo.find(2)
successor.add_predecessor(predecessor)
successor.complete!
post :toggle_check, xhr: true, params: { :id => predecessor.id, :_source_view => 'todo' }
predecessor.reload
successor.reload
assert !predecessor.active?
assert !successor.active?
assert predecessor.completed?
assert successor.completed?
end
private
def create_todo(params={})
defaults = { source_view: 'todo',
context_name: "library", project_name: "Build a working time machine",
notes: "note", description: "a new todo", due: nil, tag_list: "a,b,c"}
params=params.reverse_merge(defaults)
put :create, params: { _source_view: params[:_source_view],
context_name: params[:context_name], project_name: params[:project_name], tag_list: params[:tag_list],
todo: {notes: params[:notes], description: params[:description], due: params[:due], show_from: params[:show_from]} }
2013-06-03 15:21:19 +02:00
end
end