mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
20104ba13d
After @kamipo CR feedback we realized `Route#build` wasn't used. As it is also private API being able to create Routes both with `#new` and `#build` was redundant.
112 lines
4 KiB
Ruby
112 lines
4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "abstract_unit"
|
|
|
|
module ActionDispatch
|
|
module Journey
|
|
class TestRoute < ActiveSupport::TestCase
|
|
def test_initialize
|
|
app = Object.new
|
|
path = Path::Pattern.from_string "/:controller(/:action(/:id(.:format)))"
|
|
defaults = {}
|
|
route = Route.new(name: "name", app: app, path: path, defaults: defaults)
|
|
|
|
assert_equal app, route.app
|
|
assert_equal path, route.path
|
|
assert_same defaults, route.defaults
|
|
end
|
|
|
|
def test_route_adds_itself_as_memo
|
|
app = Object.new
|
|
path = Path::Pattern.from_string "/:controller(/:action(/:id(.:format)))"
|
|
route = Route.new(name: "name", app: app, path: path)
|
|
|
|
route.ast.grep(Nodes::Terminal).each do |node|
|
|
assert_equal route, node.memo
|
|
end
|
|
end
|
|
|
|
def test_path_requirements_override_defaults
|
|
path = Path::Pattern.build(":name", { name: /love/ }, "/", true)
|
|
defaults = { name: "tender" }
|
|
route = Route.new(name: "name", path: path, defaults: defaults)
|
|
assert_equal(/love/, route.requirements[:name])
|
|
end
|
|
|
|
def test_ip_address
|
|
path = Path::Pattern.from_string "/messages/:id(.:format)"
|
|
route = Route.new(name: "name", path: path, constraints: { ip: "192.168.1.1" },
|
|
defaults: { controller: "foo", action: "bar" })
|
|
assert_equal "192.168.1.1", route.ip
|
|
end
|
|
|
|
def test_default_ip
|
|
path = Path::Pattern.from_string "/messages/:id(.:format)"
|
|
route = Route.new(name: "name", path: path,
|
|
defaults: { controller: "foo", action: "bar" })
|
|
assert_equal(//, route.ip)
|
|
end
|
|
|
|
def test_format_with_star
|
|
path = Path::Pattern.from_string "/:controller/*extra"
|
|
route = Route.new(name: "name", path: path,
|
|
defaults: { controller: "foo", action: "bar" })
|
|
assert_equal "/foo/himom", route.format(
|
|
controller: "foo",
|
|
extra: "himom")
|
|
end
|
|
|
|
def test_connects_all_match
|
|
path = Path::Pattern.from_string "/:controller(/:action(/:id(.:format)))"
|
|
route = Route.new(name: "name", path: path, constraints: { action: "bar" },
|
|
defaults: { controller: "foo" })
|
|
|
|
assert_equal "/foo/bar/10", route.format(
|
|
controller: "foo",
|
|
action: "bar",
|
|
id: 10)
|
|
end
|
|
|
|
def test_extras_are_not_included_if_optional
|
|
path = Path::Pattern.from_string "/page/:id(/:action)"
|
|
route = Route.new(name: "name", path: path, defaults: { action: "show" })
|
|
|
|
assert_equal "/page/10", route.format(id: 10)
|
|
end
|
|
|
|
def test_extras_are_not_included_if_optional_with_parameter
|
|
path = Path::Pattern.from_string "(/sections/:section)/pages/:id"
|
|
route = Route.new(name: "name", path: path, defaults: { action: "show" })
|
|
|
|
assert_equal "/pages/10", route.format(id: 10)
|
|
end
|
|
|
|
def test_extras_are_not_included_if_optional_parameter_is_nil
|
|
path = Path::Pattern.from_string "(/sections/:section)/pages/:id"
|
|
route = Route.new(name: "name", path: path, defaults: { action: "show" })
|
|
|
|
assert_equal "/pages/10", route.format(id: 10, section: nil)
|
|
end
|
|
|
|
def test_score
|
|
defaults = { controller: "pages", action: "show" }
|
|
|
|
path = Path::Pattern.from_string "/page/:id(/:action)(.:format)"
|
|
specific = Route.new name: "name", path: path, required_defaults: [:controller, :action], defaults: defaults
|
|
|
|
path = Path::Pattern.from_string "/:controller(/:action(/:id))(.:format)"
|
|
generic = Route.new name: "name", path: path
|
|
|
|
knowledge = { "id" => true, "controller" => true, "action" => true }
|
|
|
|
routes = [specific, generic]
|
|
|
|
assert_not_equal specific.score(knowledge), generic.score(knowledge)
|
|
|
|
found = routes.sort_by { |r| r.score(knowledge) }.last
|
|
|
|
assert_equal specific, found
|
|
end
|
|
end
|
|
end
|
|
end
|