From 87f1cb3d546530a071e60f4107efd86694579fb2 Mon Sep 17 00:00:00 2001 From: Nick Charlton Date: Fri, 16 Dec 2016 21:56:10 +0000 Subject: [PATCH] Avoid writing to routes.rb when no models exist. This closes: #502, #516, #555, #649, #583, #601, #613. --- lib/generators/administrate/routes/routes_generator.rb | 10 +++++++++- spec/generators/routes_generator_spec.rb | 10 ++++++++++ 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/lib/generators/administrate/routes/routes_generator.rb b/lib/generators/administrate/routes/routes_generator.rb index cf7b45e3aa..090cbbaabf 100644 --- a/lib/generators/administrate/routes/routes_generator.rb +++ b/lib/generators/administrate/routes/routes_generator.rb @@ -8,7 +8,7 @@ class RoutesGenerator < Rails::Generators::Base source_root File.expand_path("../templates", __FILE__) def insert_dashboard_routes - unless File.read(rails_routes_file_path).include?(dashboard_routes) + if should_route_dashboard? route(dashboard_routes) end end @@ -66,6 +66,10 @@ def dashboard_routes ERB.new(File.read(routes_file_path)).result(binding) end + def routes_includes_resources? + File.read(rails_routes_file_path).include?(dashboard_routes) + end + def rails_routes_file_path Rails.root.join("config/routes.rb") end @@ -73,6 +77,10 @@ def rails_routes_file_path def routes_file_path File.expand_path(find_in_source_paths("routes.rb.erb")) end + + def should_route_dashboard? + routes_includes_resources? || valid_dashboard_models.any? + end end end end diff --git a/spec/generators/routes_generator_spec.rb b/spec/generators/routes_generator_spec.rb index 3dd17f5770..0075224180 100644 --- a/spec/generators/routes_generator_spec.rb +++ b/spec/generators/routes_generator_spec.rb @@ -17,6 +17,16 @@ expect(routes).not_to contain("Delayed::Backend::ActiveRecord::Job") end + it "does not populate routes when no models exist" do + stub_generator_dependencies + routes = file("config/routes.rb") + allow(ActiveRecord::Base).to receive(:descendants).and_return([]) + + run_generator + + expect(routes).not_to contain("namespace :admin") + end + it "skips namespaced models with a warning" do stub_generator_dependencies routes = file("config/routes.rb")