Use should_route in routing tests.

git-svn-id: http://svn.redmine.org/redmine/trunk@13608 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang
2014-11-16 14:23:32 +00:00
parent d72e1f95ba
commit ecda1c7a4f
46 changed files with 539 additions and 1808 deletions

View File

@@ -17,173 +17,59 @@
require File.expand_path('../../../test_helper', __FILE__)
class RoutingTimelogsTest < ActionDispatch::IntegrationTest
class RoutingTimelogsTest < Redmine::RoutingTest
def test_timelogs_global
assert_routing(
{ :method => 'get', :path => "/time_entries" },
{ :controller => 'timelog', :action => 'index' }
)
assert_routing(
{ :method => 'get', :path => "/time_entries.csv" },
{ :controller => 'timelog', :action => 'index', :format => 'csv' }
)
assert_routing(
{ :method => 'get', :path => "/time_entries.atom" },
{ :controller => 'timelog', :action => 'index', :format => 'atom' }
)
assert_routing(
{ :method => 'get', :path => "/time_entries/new" },
{ :controller => 'timelog', :action => 'new' }
)
assert_routing(
{ :method => 'get', :path => "/time_entries/22/edit" },
{ :controller => 'timelog', :action => 'edit', :id => '22' }
)
assert_routing(
{ :method => 'post', :path => "/time_entries" },
{ :controller => 'timelog', :action => 'create' }
)
assert_routing(
{ :method => 'put', :path => "/time_entries/22" },
{ :controller => 'timelog', :action => 'update', :id => '22' }
)
assert_routing(
{ :method => 'delete', :path => "/time_entries/55" },
{ :controller => 'timelog', :action => 'destroy', :id => '55' }
)
should_route 'GET /time_entries' => 'timelog#index'
should_route 'GET /time_entries.csv' => 'timelog#index', :format => 'csv'
should_route 'GET /time_entries.atom' => 'timelog#index', :format => 'atom'
should_route 'GET /time_entries/new' => 'timelog#new'
should_route 'POST /time_entries' => 'timelog#create'
should_route 'GET /time_entries/22/edit' => 'timelog#edit', :id => '22'
should_route 'PUT /time_entries/22' => 'timelog#update', :id => '22'
should_route 'DELETE /time_entries/22' => 'timelog#destroy', :id => '22'
end
def test_timelogs_scoped_under_project
assert_routing(
{ :method => 'get', :path => "/projects/567/time_entries" },
{ :controller => 'timelog', :action => 'index', :project_id => '567' }
)
assert_routing(
{ :method => 'get', :path => "/projects/567/time_entries.csv" },
{ :controller => 'timelog', :action => 'index', :project_id => '567',
:format => 'csv' }
)
assert_routing(
{ :method => 'get', :path => "/projects/567/time_entries.atom" },
{ :controller => 'timelog', :action => 'index', :project_id => '567',
:format => 'atom' }
)
assert_routing(
{ :method => 'get', :path => "/projects/567/time_entries/new" },
{ :controller => 'timelog', :action => 'new', :project_id => '567' }
)
assert_routing(
{ :method => 'get', :path => "/projects/567/time_entries/22/edit" },
{ :controller => 'timelog', :action => 'edit',
:id => '22', :project_id => '567' }
)
assert_routing(
{ :method => 'post', :path => "/projects/567/time_entries" },
{ :controller => 'timelog', :action => 'create',
:project_id => '567' }
)
assert_routing(
{ :method => 'put', :path => "/projects/567/time_entries/22" },
{ :controller => 'timelog', :action => 'update',
:id => '22', :project_id => '567' }
)
assert_routing(
{ :method => 'delete', :path => "/projects/567/time_entries/55" },
{ :controller => 'timelog', :action => 'destroy',
:id => '55', :project_id => '567' }
)
should_route 'GET /projects/foo/time_entries' => 'timelog#index', :project_id => 'foo'
should_route 'GET /projects/foo/time_entries.csv' => 'timelog#index', :project_id => 'foo', :format => 'csv'
should_route 'GET /projects/foo/time_entries.atom' => 'timelog#index', :project_id => 'foo', :format => 'atom'
should_route 'GET /projects/foo/time_entries/new' => 'timelog#new', :project_id => 'foo'
should_route 'POST /projects/foo/time_entries' => 'timelog#create', :project_id => 'foo'
# TODO: unused?
should_route 'GET /projects/foo/time_entries/22/edit' => 'timelog#edit', :project_id => 'foo', :id => '22'
should_route 'PUT /projects/foo/time_entries/22' => 'timelog#update', :project_id => 'foo', :id => '22'
should_route 'DELETE /projects/foo/time_entries/22' => 'timelog#destroy', :project_id => 'foo', :id => '22'
end
def test_timelogs_scoped_under_issues
assert_routing(
{ :method => 'get', :path => "/issues/234/time_entries" },
{ :controller => 'timelog', :action => 'index', :issue_id => '234' }
)
assert_routing(
{ :method => 'get', :path => "/issues/234/time_entries.csv" },
{ :controller => 'timelog', :action => 'index', :issue_id => '234',
:format => 'csv' }
)
assert_routing(
{ :method => 'get', :path => "/issues/234/time_entries.atom" },
{ :controller => 'timelog', :action => 'index', :issue_id => '234',
:format => 'atom' }
)
assert_routing(
{ :method => 'get', :path => "/issues/234/time_entries/new" },
{ :controller => 'timelog', :action => 'new', :issue_id => '234' }
)
assert_routing(
{ :method => 'get', :path => "/issues/234/time_entries/22/edit" },
{ :controller => 'timelog', :action => 'edit', :id => '22',
:issue_id => '234' }
)
assert_routing(
{ :method => 'post', :path => "/issues/234/time_entries" },
{ :controller => 'timelog', :action => 'create', :issue_id => '234' }
)
assert_routing(
{ :method => 'put', :path => "/issues/234/time_entries/22" },
{ :controller => 'timelog', :action => 'update', :id => '22',
:issue_id => '234' }
)
assert_routing(
{ :method => 'delete', :path => "/issues/234/time_entries/55" },
{ :controller => 'timelog', :action => 'destroy', :id => '55',
:issue_id => '234' }
)
should_route 'GET /issues/234/time_entries' => 'timelog#index', :issue_id => '234'
should_route 'GET /issues/234/time_entries.csv' => 'timelog#index', :issue_id => '234', :format => 'csv'
should_route 'GET /issues/234/time_entries.atom' => 'timelog#index', :issue_id => '234', :format => 'atom'
should_route 'GET /issues/234/time_entries/new' => 'timelog#new', :issue_id => '234'
should_route 'POST /issues/234/time_entries' => 'timelog#create', :issue_id => '234'
# TODO: unused?
should_route 'GET /issues/234/time_entries/22/edit' => 'timelog#edit', :issue_id => '234', :id => '22'
should_route 'PUT /issues/234/time_entries/22' => 'timelog#update', :issue_id => '234', :id => '22'
should_route 'DELETE /issues/234/time_entries/22' => 'timelog#destroy', :issue_id => '234', :id => '22'
end
def test_timelogs_report
assert_routing(
{ :method => 'get',
:path => "/time_entries/report" },
{ :controller => 'timelog', :action => 'report' }
)
assert_routing(
{ :method => 'get',
:path => "/time_entries/report.csv" },
{ :controller => 'timelog', :action => 'report', :format => 'csv' }
)
assert_routing(
{ :method => 'get',
:path => "/issues/234/time_entries/report" },
{ :controller => 'timelog', :action => 'report', :issue_id => '234' }
)
assert_routing(
{ :method => 'get',
:path => "/issues/234/time_entries/report.csv" },
{ :controller => 'timelog', :action => 'report', :issue_id => '234',
:format => 'csv' }
)
assert_routing(
{ :method => 'get',
:path => "/projects/567/time_entries/report" },
{ :controller => 'timelog', :action => 'report', :project_id => '567' }
)
assert_routing(
{ :method => 'get',
:path => "/projects/567/time_entries/report.csv" },
{ :controller => 'timelog', :action => 'report', :project_id => '567',
:format => 'csv' }
)
should_route 'GET /time_entries/report' => 'timelog#report'
should_route 'GET /time_entries/report.csv' => 'timelog#report', :format => 'csv'
should_route 'GET /projects/foo/time_entries/report' => 'timelog#report', :project_id => 'foo'
should_route 'GET /projects/foo/time_entries/report.csv' => 'timelog#report', :project_id => 'foo', :format => 'csv'
should_route 'GET /issues/234/time_entries/report' => 'timelog#report', :issue_id => '234'
should_route 'GET /issues/234/time_entries/report.csv' => 'timelog#report', :issue_id => '234', :format => 'csv'
end
def test_timelogs_bulk_edit
assert_routing(
{ :method => 'delete',
:path => "/time_entries/destroy" },
{ :controller => 'timelog', :action => 'destroy' }
)
assert_routing(
{ :method => 'post',
:path => "/time_entries/bulk_update" },
{ :controller => 'timelog', :action => 'bulk_update' }
)
assert_routing(
{ :method => 'get',
:path => "/time_entries/bulk_edit" },
{ :controller => 'timelog', :action => 'bulk_edit' }
)
should_route 'GET /time_entries/bulk_edit' => 'timelog#bulk_edit'
should_route 'POST /time_entries/bulk_update' => 'timelog#bulk_update'
should_route 'DELETE /time_entries/destroy' => 'timelog#destroy'
end
end