Ответ 1
test_routes = []
Rails.application.routes.routes.each do |route|
route = route.path.spec.to_s
test_routes << route if route.starts_with?('/admin')
end
Как я могу получить список всех маршрутов в моем пространстве имен Admin
, чтобы я мог использовать его в одном из моих тестов?
Я часто делаю ошибку при наследовании от ApplicationController
вместо AdminController
при создании новых контроллеров в моем пространстве имен Admin
. Итак, я хочу написать тест, который посещает все маршруты в моем пространстве имен Admin
и проверяет, что каждый из них требует зарегистрированного пользователя.
test_routes = []
Rails.application.routes.routes.each do |route|
route = route.path.spec.to_s
test_routes << route if route.starts_with?('/admin')
end
Если кто-то еще хочет проверить, что для всех маршрутов в пространстве имен требуется зарегистрированный пользователь, вот как я это сделал:
ROUTES = Rails.application.routes.routes.map do |route|
# Turn route path spec into string; use "1" for all params
path = route.path.spec.to_s.gsub(/\(\.:format\)/, "").gsub(/:[a-zA-Z_]+/, "1")
verb = %W{ GET POST PUT PATCH DELETE }.grep(route.verb).first.downcase.to_sym
{ path: path, verb: verb }
end
test "admin routes should redirect to admin login page when no admin user is logged in" do
admin_routes = ROUTES.select { |route| route[:path].starts_with? "/admin" }
unprotected_routes = []
admin_routes.each do |route|
begin
reset!
request_via_redirect(route[:verb], route[:path])
unprotected_routes << "#{route[:verb]} #{route[:path]}" unless path == admin_login_path
rescue ActiveRecord::RecordNotFound
unprotected_routes << "#{route[:verb]} #{route[:path]}" unless path == admin_login_path
rescue AbstractController::ActionNotFound
end
end
assert unprotected_routes.empty?,
"The following routes are not secure: \n\t#{unprotected_routes.uniq.join("\n\t")}"
end
end
Я приветствую улучшения.