diff options
author | Piotr Sarnacki <drogus@gmail.com> | 2010-07-08 23:27:49 +0200 |
---|---|---|
committer | Piotr Sarnacki <drogus@gmail.com> | 2010-09-03 22:59:05 +0200 |
commit | b1e5e233fabe8f75ebd06e7e08c15f0eeddbae79 (patch) | |
tree | f59d1b5bf566da18969c5dde1710064ac6250aae | |
parent | eedbf87d15b99a7cae38b0d8894fc39f1e70a81e (diff) | |
download | rails-b1e5e233fabe8f75ebd06e7e08c15f0eeddbae79.tar.gz rails-b1e5e233fabe8f75ebd06e7e08c15f0eeddbae79.tar.bz2 rails-b1e5e233fabe8f75ebd06e7e08c15f0eeddbae79.zip |
Refactored tests for prefix generation and added test for url generation in regular class with default_url_options[:script_name] set
-rw-r--r-- | actionpack/test/dispatch/prefix_generation_test.rb | 43 |
1 files changed, 32 insertions, 11 deletions
diff --git a/actionpack/test/dispatch/prefix_generation_test.rb b/actionpack/test/dispatch/prefix_generation_test.rb index 49c5c82ad6..6ceb07a4f1 100644 --- a/actionpack/test/dispatch/prefix_generation_test.rb +++ b/actionpack/test/dispatch/prefix_generation_test.rb @@ -2,6 +2,9 @@ require 'abstract_unit' module TestGenerationPrefix class WithMountedEngine < ActionDispatch::IntegrationTest + require 'rack/test' + include Rack::Test::Methods + class BlogEngine def self.routes @routes ||= begin @@ -30,6 +33,7 @@ module TestGenerationPrefix mount BlogEngine => "/blog" end match "/generate", :to => "outside_engine_generating#index" + root :to => "outside_engine_generating#index" end routes @@ -77,25 +81,39 @@ module TestGenerationPrefix end end + class Bar + include ActionDispatch::Routing::UrlFor + include RailsApplication.routes.url_helpers + + def bar + root_path + end + end RailsApplication.routes # force draw include BlogEngine.routes.url_helpers + def app + RailsApplication + end + + def setup + RailsApplication.routes.default_url_options = {} + end + test "generating URL with prefix" do assert_equal "/awesome/blog/posts/1", post_path(:id => 1) end test "use SCRIPT_NAME inside the engine" do - env = Rack::MockRequest.env_for("/pure-awesomness/blog/posts/1") - response = ActionDispatch::Response.new(*RailsApplication.call(env)) - assert_equal "/pure-awesomness/blog/posts/1", response.body + get "/pure-awesomness/blog/posts/1" + assert_equal "/pure-awesomness/blog/posts/1", last_response.body end test "prepend prefix outside the engine" do - env = Rack::MockRequest.env_for("/generate") - env["SCRIPT_NAME"] = "/something" # it could be set by passenger - response = ActionDispatch::Response.new(*RailsApplication.call(env)) - assert_equal "/something/awesome/blog/posts/1", response.body + RailsApplication.routes.default_url_options = {:script_name => "/something"} + get "/generate", {}, 'SCRIPT_NAME' => "/something" + assert_equal "/something/awesome/blog/posts/1", last_response.body end test "generating urls with options for both prefix and named_route" do @@ -112,11 +130,14 @@ module TestGenerationPrefix end test "passing :routes to url_for to change current routes" do - env = Rack::MockRequest.env_for("/pure-awesomness/blog/bare_url_for") - env["SCRIPT_NAME"] = "/something" RailsApplication.routes.default_url_options = {:script_name => "/something"} - response = ActionDispatch::Response.new(*RailsApplication.call(env)) - assert_equal "/something/generate", response.body + get "/pure-awesomness/blog/bare_url_for", {}, 'SCRIPT_NAME' => "/something" + assert_equal "/something/generate", last_response.body + end + + test "using default_url_options[:script_name] in regular classes" do + RailsApplication.routes.default_url_options = {:script_name => "/something"} + assert_equal "/something/", Bar.new.bar end end end |