1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/railties/test
Piotr Sarnacki 5b3bb61f3f Fix handling SCRIPT_NAME from within mounted engine's
When you mount your application at a path, for example /myapp, server
should set SCRIPT_NAME to /myapp. With such information, rails
application knows that it's mounted at /myapp path and it should generate
routes relative to that path.

Before this patch, rails handled SCRIPT_NAME correctly only for regular
apps, but it failed to do it for mounted engines. The solution was to
hardcode default_url_options[:script_name], which is not the best answer
- it will work only when application is mounted at a fixed path.

This patch fixes the situation by respecting original value of
SCRIPT_NAME when generating application's routes from engine and the
other way round - when you generate engine's routes from application.

This is done by using one of 2 pieces of information in env - current
SCRIPT_NAME or SCRIPT_NAME for a corresponding router. This is because
we have 2 cases to handle:

- generating engine's route from application: in this situation
  SCRIPT_NAME is basically SCRIPT_NAME set by the server and it
  indicates the place where application is mounted, so we can just pass
  it as :original_script_name in url_options. :original_script_name is
  used because if we use :script_name, router will ignore generating
  prefix for engine

- generating application's route from engine: in this situation we
  already lost information about the SCRIPT_NAME that server used. For
  example if application is mounted at /myapp and engine is mounted at
  /blog, at this point SCRIPT_NAME is equal /myapp/blog. Because of that
  we need to keep reference to /myapp SCRIPT_NAME by binding it to the
  current router. Later on we can extract it and use when generating url

Please note that starting from now you *should not* use
default_url_options[:script_name] explicitly if your server already
passes correct SCRIPT_NAME to rack env.

(closes #6933)
2012-08-11 00:21:46 +02:00
..
application make assertions easier to track down 2012-08-07 10:54:47 -07:00
commands Set RACK_ENV to nil in the dbconsole test 2012-05-30 23:29:47 -03:00
configuration using __method__ for the command method calls 2012-05-21 16:20:40 -07:00
fixtures treat USAGE as an ERB template 2011-11-02 09:00:18 -04:00
generators remove some artifacts of dependent_restrict_raises that I missed 2012-08-10 18:12:26 +01:00
isolation remove some artifacts of dependent_restrict_raises that I missed 2012-08-10 18:12:26 +01:00
queueing adding Rails::Queueing::Container 2012-07-19 12:09:39 -07:00
railties Fix handling SCRIPT_NAME from within mounted engine's 2012-08-11 00:21:46 +02:00
abstract_unit.rb Ensure that Rails.env is equal to "test" by default when running tests. 2012-05-06 21:36:59 -07:00
backtrace_cleaner_test.rb Gem cont presence checking has been removed 2012-05-02 13:56:13 +03:00
engine_test.rb Remove another missing test related to draw external routes 2012-06-29 14:55:09 -03:00
generators_test.rb Fix class_eval without __FILE__ and __LINE__. 2012-07-18 01:16:55 +09:00
initializable_test.rb :group => :assets should only run in the assets environment. 2011-10-02 22:08:33 +02:00
paths_test.rb Fix failing test related to persist glob when replacing a path 2012-07-01 13:56:11 -03:00
rails_info_controller_test.rb Rails::InfoController tests passing 2012-05-24 12:50:16 -05:00
rails_info_test.rb Updated/changed useless tr/gsubs 2012-04-03 15:16:09 +02:00
script_rails_loader_test.rb Deletes trailing whitespaces (over text files only find * -type f -exec sed 's/[ \t]*$//' -i {} \;) 2010-08-14 04:12:33 -03:00