From 97a792995538ce2032af995813c617b20ab62a6d Mon Sep 17 00:00:00 2001 From: Jason Frey Date: Tue, 19 Nov 2019 12:59:02 -0500 Subject: [PATCH] Remove seed on rails server start in development. In a production setting, evmserverd will be resposible for seeding the database. In a development setting, we should not be seeding when we start the UI. Developers should instead be encouraged to use bin/update or call db:seed directly when changes are made. Since most developers need to call bin/update before starting a rails server, in order to build the UI assets, this is part of the normal workflow. This change should eliminate about 1 second at rails server boot in development. --- .../mixins/miq_web_server_worker_mixin.rb | 1 + lib/evm_database.rb | 20 +++++++++- lib/vmdb/initializer.rb | 3 -- spec/lib/evm_database_spec.rb | 40 +++++++++++++++++++ 4 files changed, 60 insertions(+), 4 deletions(-) diff --git a/app/models/mixins/miq_web_server_worker_mixin.rb b/app/models/mixins/miq_web_server_worker_mixin.rb index da0eefe20b1b..82c50d49a44c 100644 --- a/app/models/mixins/miq_web_server_worker_mixin.rb +++ b/app/models/mixins/miq_web_server_worker_mixin.rb @@ -23,6 +23,7 @@ def preload_for_console end def preload_for_worker_role + raise "Expected database to be seeded via `rake db:seed`." unless EvmDatabase.seeded_primordially? configure_secret_token end diff --git a/lib/evm_database.rb b/lib/evm_database.rb index a9c84f51d991..b47594f63711 100644 --- a/lib/evm_database.rb +++ b/lib/evm_database.rb @@ -77,8 +77,26 @@ def self.seed_rest seed(OTHER_SEEDABLE_CLASSES) end + # Returns whether or not a primordial seed has completed. + def self.seeded_primordially? + # While not technically accurate, as someone could just insert a record + # directly, this is the simplest check at the moment to guess whether or not + # a primordial seed has completed. + MiqDatabase.any? && MiqRegion.in_my_region.any? + end + + # Returns whether or not a full seed has completed. + def self.seeded? + # While not technically accurate, as someone could just insert a record + # directly, this is the simplest check at the moment to guess whether or not + # a full seed has completed. + # + # MiqAction was chosen because it cannot be added by a user directly. + seeded_primordially? && MiqAction.in_my_region.any? + end + def self.skip_seeding? - ENV['SKIP_SEEDING'] && MiqDatabase.any? + ENV['SKIP_SEEDING'] && seeded_primordially? end private_class_method :skip_seeding? diff --git a/lib/vmdb/initializer.rb b/lib/vmdb/initializer.rb index 1f1e7c08faa1..4556bd98ea85 100644 --- a/lib/vmdb/initializer.rb +++ b/lib/vmdb/initializer.rb @@ -7,9 +7,6 @@ def self.init # * command line(rails server) # * debugger if defined?(Rails::Server) - # preload_for_worker_role depends on seeding, principally MiqDatabase - EvmDatabase.seed_primordial - MiqUiWorker.preload_for_worker_role MiqServer.my_server.starting_server_record MiqServer.my_server.update(:status => "started") diff --git a/spec/lib/evm_database_spec.rb b/spec/lib/evm_database_spec.rb index d8e305e6441d..94775098aafe 100644 --- a/spec/lib/evm_database_spec.rb +++ b/spec/lib/evm_database_spec.rb @@ -73,6 +73,46 @@ end end + describe ".seeded_primordially?" do + it "when not seeded" do + expect(EvmDatabase.seeded_primordially?).to be false + end + + it "when seeded primordially" do + # Simulate part of a primordial seed + described_class.seed(["MiqDatabase", "MiqRegion"]) + + expect(EvmDatabase.seeded_primordially?).to be true + end + + it "when fully seeded" do + # Simulate part of a primordial seed and part of a full seed + described_class.seed(["MiqDatabase", "MiqRegion", "MiqAction"]) + + expect(EvmDatabase.seeded_primordially?).to be true + end + end + + describe ".seeded?" do + it "when not seeded" do + expect(EvmDatabase.seeded?).to be false + end + + it "when seeded primordially" do + # Simulate part of a primordial seed + described_class.seed(["MiqDatabase", "MiqRegion"]) + + expect(EvmDatabase.seeded?).to be false + end + + it "when fully seeded" do + # Simulate part of a primordial seed and part of a full seed + described_class.seed(["MiqDatabase", "MiqRegion", "MiqAction"]) + + expect(EvmDatabase.seeded?).to be true + end + end + describe ".skip_seeding? (private)" do it "will not skip when SKIP_SEEDING is not set" do expect(ENV).to receive(:[]).with("SKIP_SEEDING").and_return(nil)