1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Start rewriting some internal tests to use the new routing dsl

This commit is contained in:
Joshua Peek 2009-10-20 16:03:55 -05:00
parent 207d0483e5
commit a5c82a9dfb
13 changed files with 32 additions and 31 deletions

View file

@ -109,6 +109,10 @@ module ActionController
middleware_stack middleware_stack
end end
def self.call(env)
action(env['action_dispatch.request.path_parameters'][:action]).call(env)
end
# Return a rack endpoint for the given action. Memoize the endpoint, so # Return a rack endpoint for the given action. Memoize the endpoint, so
# multiple calls into MyController.action will return the same object # multiple calls into MyController.action will return the same object
# for the same action. # for the same action.

View file

@ -10,12 +10,12 @@ module Submodule
def public_action def public_action
render :nothing => true render :nothing => true
end end
hide_action :hidden_action hide_action :hidden_action
def hidden_action def hidden_action
raise "Noooo!" raise "Noooo!"
end end
def another_hidden_action def another_hidden_action
end end
hide_action :another_hidden_action hide_action :another_hidden_action
@ -30,25 +30,25 @@ class NonEmptyController < ActionController::Base
def public_action def public_action
render :nothing => true render :nothing => true
end end
hide_action :hidden_action hide_action :hidden_action
def hidden_action def hidden_action
end end
end end
class MethodMissingController < ActionController::Base class MethodMissingController < ActionController::Base
hide_action :shouldnt_be_called hide_action :shouldnt_be_called
def shouldnt_be_called def shouldnt_be_called
raise "NO WAY!" raise "NO WAY!"
end end
protected protected
def method_missing(selector) def method_missing(selector)
render :text => selector.to_s render :text => selector.to_s
end end
end end
class DefaultUrlOptionsController < ActionController::Base class DefaultUrlOptionsController < ActionController::Base
@ -79,7 +79,7 @@ class ControllerInstanceTests < Test::Unit::TestCase
@empty = EmptyController.new @empty = EmptyController.new
@contained = Submodule::ContainedEmptyController.new @contained = Submodule::ContainedEmptyController.new
@empty_controllers = [@empty, @contained, Submodule::SubclassedController.new] @empty_controllers = [@empty, @contained, Submodule::SubclassedController.new]
@non_empty_controllers = [NonEmptyController.new, @non_empty_controllers = [NonEmptyController.new,
Submodule::ContainedNonEmptyController.new] Submodule::ContainedNonEmptyController.new]
end end
@ -135,24 +135,24 @@ class PerformActionTest < ActionController::TestCase
rescue_action_in_public! rescue_action_in_public!
end end
def test_get_on_priv_should_show_selector def test_get_on_priv_should_show_selector
use_controller MethodMissingController use_controller MethodMissingController
get :shouldnt_be_called get :shouldnt_be_called
assert_response :success assert_response :success
assert_equal 'shouldnt_be_called', @response.body assert_equal 'shouldnt_be_called', @response.body
end end
def test_method_missing_is_not_an_action_name def test_method_missing_is_not_an_action_name
use_controller MethodMissingController use_controller MethodMissingController
assert ! @controller.__send__(:action_method?, 'method_missing') assert ! @controller.__send__(:action_method?, 'method_missing')
get :method_missing get :method_missing
assert_response :success assert_response :success
assert_equal 'method_missing', @response.body assert_equal 'method_missing', @response.body
end end
def test_get_on_hidden_should_fail def test_get_on_hidden_should_fail
use_controller NonEmptyController use_controller NonEmptyController
assert_raise(ActionController::UnknownAction) { get :hidden_action } assert_raise(ActionController::UnknownAction) { get :hidden_action }

View file

@ -390,7 +390,7 @@ class IntegrationProcessTest < ActionController::IntegrationTest
def with_test_route_set def with_test_route_set
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.connect "/:action", :controller => "integration_process_test/integration" match ':action', :to => IntegrationController
end end
yield yield
end end

View file

@ -343,9 +343,9 @@ class RescueTest < ActionController::IntegrationTest
def with_test_routing def with_test_routing
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.connect 'foo', :controller => "rescue_test/test", :action => 'foo' match 'foo', :to => TestController.action(:foo)
map.connect 'invalid', :controller => "rescue_test/test", :action => 'invalid' match 'invalid', :to => TestController.action(:invalid)
map.connect 'b00m', :controller => "rescue_test/test", :action => 'b00m' match 'b00m', :to => TestController.action(:b00m)
end end
yield yield
end end

View file

@ -224,9 +224,8 @@ class UrlWriterTests < ActionController::TestCase
def test_named_routes def test_named_routes
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.no_args '/this/is/verbose', :controller => 'home', :action => 'index' match 'this/is/verbose', :to => 'home#index', :as => :no_args
map.home '/home/sweet/home/:user', :controller => 'home', :action => 'index' match 'home/sweet/home/:user', :to => 'home#index', :as => :home
map.connect ':controller/:action/:id'
end end
# We need to create a new class in order to install the new named route. # We need to create a new class in order to install the new named route.
@ -264,7 +263,7 @@ class UrlWriterTests < ActionController::TestCase
def test_only_path def test_only_path
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.home '/home/sweet/home/:user', :controller => 'home', :action => 'index' match 'home/sweet/home/:user', :to => 'home#index', :as => :home
map.connect ':controller/:action/:id' map.connect ':controller/:action/:id'
end end
@ -334,7 +333,6 @@ class UrlWriterTests < ActionController::TestCase
set.draw do |map| set.draw do |map|
map.main '', :controller => 'posts', :format => nil map.main '', :controller => 'posts', :format => nil
map.resources :posts map.resources :posts
map.connect ':controller/:action/:id'
end end
# We need to create a new class in order to install the new named route. # We need to create a new class in order to install the new named route.

View file

@ -125,8 +125,8 @@ class VerificationTest < ActionController::TestCase
assert_not_deprecated do assert_not_deprecated do
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.foo '/foo', :controller => 'test', :action => 'foo' match 'foo', :to => 'test#foo', :as => :foo
map.connect ":controller/:action/:id" match 'verification_test/:action', :to => TestController
end end
get :guarded_one_for_named_route_test, :two => "not one" get :guarded_one_for_named_route_test, :two => "not one"
assert_redirected_to '/foo' assert_redirected_to '/foo'

View file

@ -57,7 +57,7 @@ class JsonParamsParsingTest < ActionController::IntegrationTest
def with_test_routing def with_test_routing
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.connect ':action', :controller => "json_params_parsing_test/test" match ':action', :to => TestController
end end
yield yield
end end

View file

@ -109,7 +109,7 @@ class QueryStringParsingTest < ActionController::IntegrationTest
def assert_parses(expected, actual) def assert_parses(expected, actual)
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.connect ':action', :controller => "query_string_parsing_test/test" match ':action', :to => TestController
end end
get "/parse", actual get "/parse", actual

View file

@ -130,7 +130,7 @@ class UrlEncodedParamsParsingTest < ActionController::IntegrationTest
def with_test_routing def with_test_routing
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.connect ':action', :controller => "url_encoded_params_parsing_test/test" match ':action', :to => TestController
end end
yield yield
end end

View file

@ -84,7 +84,7 @@ class XmlParamsParsingTest < ActionController::IntegrationTest
def with_test_routing def with_test_routing
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.connect ':action', :controller => "xml_params_parsing_test/test" match ':action', :to => TestController
end end
yield yield
end end

View file

@ -219,7 +219,7 @@ class CookieStoreTest < ActionController::IntegrationTest
def with_test_route_set(options = {}) def with_test_route_set(options = {})
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.connect "/:action", :controller => "cookie_store_test/test" match ':action', :to => TestController
end end
options = {:key => SessionKey, :secret => SessionSecret}.merge(options) options = {:key => SessionKey, :secret => SessionSecret}.merge(options)
@app = ActionDispatch::Session::CookieStore.new(set, options) @app = ActionDispatch::Session::CookieStore.new(set, options)

View file

@ -112,7 +112,7 @@ class MemCacheStoreTest < ActionController::IntegrationTest
def with_test_route_set def with_test_route_set
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.connect "/:action", :controller => "mem_cache_store_test/test" match ':action', :to => TestController
end end
@app = ActionDispatch::Session::MemCacheStore.new(set, :key => '_session_id') @app = ActionDispatch::Session::MemCacheStore.new(set, :key => '_session_id')
yield yield

View file

@ -48,8 +48,7 @@ class PeopleHelperTest < ActionView::TestCase
def with_test_route_set def with_test_route_set
with_routing do |set| with_routing do |set|
set.draw do |map| set.draw do |map|
map.people 'people', :controller => 'people', :action => 'index' match 'people', :to => 'people#index', :as => :people
map.connect ':controller/:action/:id'
end end
yield yield
end end