1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Merge pull request #34181 from gmcgibbon/db_schema_cache_dump_and_clear_multi_db

Db schema cache dump and clear multi db
This commit is contained in:
Eileen M. Uchitelle 2018-11-07 14:53:03 -05:00 committed by GitHub
commit fc2684c9c0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 57 additions and 5 deletions

View file

@ -1,3 +1,7 @@
Adds support for multiple databases to `rails db:schema:cache:dump` and `rails db:schema:cache:clear`.
*Gannon McGibbon*
* `update_columns` now correctly raises `ActiveModel::MissingAttributeError` * `update_columns` now correctly raises `ActiveModel::MissingAttributeError`
if the attribute does not exist. if the attribute does not exist.

View file

@ -300,15 +300,22 @@ db_namespace = namespace :db do
namespace :cache do namespace :cache do
desc "Creates a db/schema_cache.yml file." desc "Creates a db/schema_cache.yml file."
task dump: :load_config do task dump: :load_config do
conn = ActiveRecord::Base.connection ActiveRecord::Base.configurations.configs_for(env_name: Rails.env).each do |db_config|
filename = File.join(ActiveRecord::Tasks::DatabaseTasks.db_dir, "schema_cache.yml") ActiveRecord::Base.establish_connection(db_config.config)
ActiveRecord::Tasks::DatabaseTasks.dump_schema_cache(conn, filename) filename = ActiveRecord::Tasks::DatabaseTasks.cache_dump_filename(db_config.spec_name)
ActiveRecord::Tasks::DatabaseTasks.dump_schema_cache(
ActiveRecord::Base.connection,
filename,
)
end
end end
desc "Clears a db/schema_cache.yml file." desc "Clears a db/schema_cache.yml file."
task clear: :load_config do task clear: :load_config do
filename = File.join(ActiveRecord::Tasks::DatabaseTasks.db_dir, "schema_cache.yml") ActiveRecord::Base.configurations.configs_for(env_name: Rails.env).each do |db_config|
rm_f filename, verbose: false filename = ActiveRecord::Tasks::DatabaseTasks.cache_dump_filename(db_config.spec_name)
rm_f filename, verbose: false
end
end end
end end
end end

View file

@ -313,6 +313,16 @@ module ActiveRecord
ENV["SCHEMA"] || File.join(ActiveRecord::Tasks::DatabaseTasks.db_dir, filename) ENV["SCHEMA"] || File.join(ActiveRecord::Tasks::DatabaseTasks.db_dir, filename)
end end
def cache_dump_filename(namespace)
filename = if namespace == "primary"
"schema_cache.yml"
else
"#{namespace}_schema_cache.yml"
end
ENV["SCHEMA_CACHE"] || File.join(ActiveRecord::Tasks::DatabaseTasks.db_dir, filename)
end
def load_schema_current(format = ActiveRecord::Base.schema_format, file = nil, environment = env) def load_schema_current(format = ActiveRecord::Base.schema_format, file = nil, environment = env)
each_current_configuration(environment) { |configuration, spec_name, env| each_current_configuration(environment) { |configuration, spec_name, env|
load_schema(configuration, format, file, env, spec_name) load_schema(configuration, format, file, env, spec_name)

View file

@ -65,6 +65,27 @@ module ApplicationTests
end end
end end
def db_migrate_and_schema_cache_dump
Dir.chdir(app_path) do
generate_models_for_animals
rails "db:migrate"
rails "db:schema:cache:dump"
assert File.exist?("db/schema_cache.yml")
assert File.exist?("db/animals_schema_cache.yml")
end
end
def db_migrate_and_schema_cache_dump_and_schema_cache_clear
Dir.chdir(app_path) do
generate_models_for_animals
rails "db:migrate"
rails "db:schema:cache:dump"
rails "db:schema:cache:clear"
assert_not File.exist?("db/schema_cache.yml")
assert_not File.exist?("db/animals_schema_cache.yml")
end
end
def db_migrate_and_schema_dump_and_load(format) def db_migrate_and_schema_dump_and_load(format)
Dir.chdir(app_path) do Dir.chdir(app_path) do
generate_models_for_animals generate_models_for_animals
@ -194,6 +215,16 @@ module ApplicationTests
db_migrate_status_namespaced db_config.spec_name, db_config.config["database"] db_migrate_status_namespaced db_config.spec_name, db_config.config["database"]
end end
end end
test "db:schema:cache:dump works on all databases" do
require "#{app_path}/config/environment"
db_migrate_and_schema_cache_dump
end
test "db:schema:cache:clear works on all databases" do
require "#{app_path}/config/environment"
db_migrate_and_schema_cache_dump_and_schema_cache_clear
end
end end
end end
end end