diff options
| author | Jon Moss <me@jonathanmoss.me> | 2016-06-04 11:40:11 -0400 | 
|---|---|---|
| committer | Jon Moss <me@jonathanmoss.me> | 2016-06-07 17:20:13 -0400 | 
| commit | 20ab1bf4f707096ff0bd765e7248f9c3a6b2c520 (patch) | |
| tree | 3e9e5decc3b48422cbe1ea534625236be79817e1 /actionpack | |
| parent | 5eea500ecf5858048ec69dbecb70d3f90f2a1024 (diff) | |
| download | rails-20ab1bf4f707096ff0bd765e7248f9c3a6b2c520.tar.gz rails-20ab1bf4f707096ff0bd765e7248f9c3a6b2c520.tar.bz2 rails-20ab1bf4f707096ff0bd765e7248f9c3a6b2c520.zip | |
Prevent `{ internal: true }` from being stored in the router
Forgotten followup to #23669 :grimacing:
If you went to an internal route (e.g. `/rails/info/routes`), you would
previously see the following in your logger:
```bash
Processing by Rails::InfoController#routes as HTML
  Parameters: {"internal"=>true}
  Rendering /Users/jon/code/rails/rails/railties/lib/rails/templates/rails/info/routes.html.erb within layouts/application
  Rendered collection of /Users/jon/code/rails/rails/actionpack/lib/action_dispatch/middleware/templates/routes/_route.html.erb [2 times] (10.5ms)
  Rendered /Users/jon/code/rails/rails/actionpack/lib/action_dispatch/middleware/templates/routes/_table.html.erb (2.5ms)
  Rendered /Users/jon/code/rails/rails/railties/lib/rails/templates/rails/info/routes.html.erb within layouts/application (23.5ms)
Completed 200 OK in 50ms (Views: 35.1ms | ActiveRecord: 0.0ms)
```
Now, with this change, you would see:
```bash
Processing by Rails::InfoController#routes as HTML
  Rendering /Users/jon/code/rails/rails/railties/lib/rails/templates/rails/info/routes.html.erb within layouts/application
  Rendered collection of /Users/jon/code/rails/rails/actionpack/lib/action_dispatch/middleware/templates/routes/_route.html.erb [2 times] (1.6ms)
  Rendered /Users/jon/code/rails/rails/actionpack/lib/action_dispatch/middleware/templates/routes/_table.html.erb (10.2ms)
  Rendered /Users/jon/code/rails/rails/railties/lib/rails/templates/rails/info/routes.html.erb within layouts/application (17.4ms)
Completed 200 OK in 44ms (Views: 28.0ms | ActiveRecord: 0.0ms)
```
Diffstat (limited to 'actionpack')
| -rw-r--r-- | actionpack/lib/action_dispatch/routing/mapper.rb | 2 | ||||
| -rw-r--r-- | actionpack/test/dispatch/routing_test.rb | 30 | 
2 files changed, 31 insertions, 1 deletions
| diff --git a/actionpack/lib/action_dispatch/routing/mapper.rb b/actionpack/lib/action_dispatch/routing/mapper.rb index 8ff3b42a40..40b6500553 100644 --- a/actionpack/lib/action_dispatch/routing/mapper.rb +++ b/actionpack/lib/action_dispatch/routing/mapper.rb @@ -106,7 +106,7 @@ module ActionDispatch            @ast                = ast            @anchor             = anchor            @via                = via -          @internal           = options[:internal] +          @internal           = options.delete(:internal)            path_params = ast.find_all(&:symbol?).map(&:to_sym) diff --git a/actionpack/test/dispatch/routing_test.rb b/actionpack/test/dispatch/routing_test.rb index ade4b0c381..75fdc9469f 100644 --- a/actionpack/test/dispatch/routing_test.rb +++ b/actionpack/test/dispatch/routing_test.rb @@ -4795,3 +4795,33 @@ class TestPathParameters < ActionDispatch::IntegrationTest      assert_equal "/ar | /ar/about", @response.body    end  end + +class TestInternalRoutingParams < ActionDispatch::IntegrationTest +  Routes = ActionDispatch::Routing::RouteSet.new.tap do |app| +    app.draw do +      get '/test_internal/:internal' => 'internal#internal' +    end +  end + +  class ::InternalController < ActionController::Base +    def internal +      head :ok +    end +  end + +  APP = build_app Routes + +  def app +    APP +  end + +  def test_paths_with_partial_dynamic_segments_are_recognised +    get '/test_internal/123' +    assert_equal 200, response.status + +    assert_equal( +      { controller: 'internal', action: 'internal', internal: '123' }, +      request.path_parameters +    ) +  end +end | 
