未验证 提交 11b884e5 编写于 作者: E Eileen M. Uchitelle 提交者: GitHub

Merge pull request #32396 from eugeneius/database_configurations_url

Fix two-level database configurations with URLs
......@@ -43,7 +43,7 @@ def self.configs_for(env, configs = ActiveRecord::Base.configurations, &blk) # :
# Given an env, spec and config creates DatabaseConfig structs with
# each attribute set.
def self.walk_configs(env_name, spec_name, config) # :nodoc:
if config["database"] || env_name == "default"
if config["database"] || config["url"] || env_name == "default"
DatabaseConfig.new(env_name, spec_name, config)
else
config.each_pair.map do |sub_spec_name, sub_config|
......
......@@ -179,7 +179,7 @@ def setup
@configurations = {
"development" => { "database" => "dev-db" },
"test" => { "database" => "test-db" },
"production" => { "database" => "prod-db" }
"production" => { "url" => "prod-db-url" }
}
ActiveRecord::Base.stubs(:configurations).returns(@configurations)
......@@ -188,7 +188,16 @@ def setup
def test_creates_current_environment_database
ActiveRecord::Tasks::DatabaseTasks.expects(:create).
with("database" => "prod-db")
with("database" => "test-db")
ActiveRecord::Tasks::DatabaseTasks.create_current(
ActiveSupport::StringInquirer.new("test")
)
end
def test_creates_current_environment_database_with_url
ActiveRecord::Tasks::DatabaseTasks.expects(:create).
with("url" => "prod-db-url")
ActiveRecord::Tasks::DatabaseTasks.create_current(
ActiveSupport::StringInquirer.new("production")
......@@ -237,7 +246,7 @@ def setup
@configurations = {
"development" => { "primary" => { "database" => "dev-db" }, "secondary" => { "database" => "secondary-dev-db" } },
"test" => { "primary" => { "database" => "test-db" }, "secondary" => { "database" => "secondary-test-db" } },
"production" => { "primary" => { "database" => "prod-db" }, "secondary" => { "database" => "secondary-prod-db" } }
"production" => { "primary" => { "url" => "prod-db-url" }, "secondary" => { "url" => "secondary-prod-db-url" } }
}
ActiveRecord::Base.stubs(:configurations).returns(@configurations)
......@@ -246,10 +255,22 @@ def setup
def test_creates_current_environment_database
ActiveRecord::Tasks::DatabaseTasks.expects(:create).
with("database" => "prod-db")
with("database" => "test-db")
ActiveRecord::Tasks::DatabaseTasks.expects(:create).
with("database" => "secondary-test-db")
ActiveRecord::Tasks::DatabaseTasks.create_current(
ActiveSupport::StringInquirer.new("test")
)
end
def test_creates_current_environment_database_with_url
ActiveRecord::Tasks::DatabaseTasks.expects(:create).
with("url" => "prod-db-url")
ActiveRecord::Tasks::DatabaseTasks.expects(:create).
with("database" => "secondary-prod-db")
with("url" => "secondary-prod-db-url")
ActiveRecord::Tasks::DatabaseTasks.create_current(
ActiveSupport::StringInquirer.new("production")
......@@ -374,7 +395,7 @@ def setup
@configurations = {
"development" => { "database" => "dev-db" },
"test" => { "database" => "test-db" },
"production" => { "database" => "prod-db" }
"production" => { "url" => "prod-db-url" }
}
ActiveRecord::Base.stubs(:configurations).returns(@configurations)
......@@ -382,7 +403,16 @@ def setup
def test_drops_current_environment_database
ActiveRecord::Tasks::DatabaseTasks.expects(:drop).
with("database" => "prod-db")
with("database" => "test-db")
ActiveRecord::Tasks::DatabaseTasks.drop_current(
ActiveSupport::StringInquirer.new("test")
)
end
def test_drops_current_environment_database_with_url
ActiveRecord::Tasks::DatabaseTasks.expects(:drop).
with("url" => "prod-db-url")
ActiveRecord::Tasks::DatabaseTasks.drop_current(
ActiveSupport::StringInquirer.new("production")
......@@ -421,7 +451,7 @@ def setup
@configurations = {
"development" => { "primary" => { "database" => "dev-db" }, "secondary" => { "database" => "secondary-dev-db" } },
"test" => { "primary" => { "database" => "test-db" }, "secondary" => { "database" => "secondary-test-db" } },
"production" => { "primary" => { "database" => "prod-db" }, "secondary" => { "database" => "secondary-prod-db" } }
"production" => { "primary" => { "url" => "prod-db-url" }, "secondary" => { "url" => "secondary-prod-db-url" } }
}
ActiveRecord::Base.stubs(:configurations).returns(@configurations)
......@@ -429,10 +459,22 @@ def setup
def test_drops_current_environment_database
ActiveRecord::Tasks::DatabaseTasks.expects(:drop).
with("database" => "prod-db")
with("database" => "test-db")
ActiveRecord::Tasks::DatabaseTasks.expects(:drop).
with("database" => "secondary-test-db")
ActiveRecord::Tasks::DatabaseTasks.drop_current(
ActiveSupport::StringInquirer.new("test")
)
end
def test_drops_current_environment_database_with_url
ActiveRecord::Tasks::DatabaseTasks.expects(:drop).
with("url" => "prod-db-url")
ActiveRecord::Tasks::DatabaseTasks.expects(:drop).
with("database" => "secondary-prod-db")
with("url" => "secondary-prod-db-url")
ActiveRecord::Tasks::DatabaseTasks.drop_current(
ActiveSupport::StringInquirer.new("production")
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册