forked from rails/rails
-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Make
schema_dump
, query_cache
, replica
and database_tasks
con…
…figurable via `DATABASE_URL` Fix: rails#50745 I went a bit farther and handled all the boolean configs, not just `schema_cache`. Co-Authored-By: Mike Coutermarsh <coutermarsh.mike@gmail.com>
- Loading branch information
1 parent
fc7befc
commit 63631e2
Showing
3 changed files
with
82 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
53 changes: 53 additions & 0 deletions
53
activerecord/test/cases/database_configurations/url_config_test.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
# frozen_string_literal: true | ||
|
||
require "cases/helper" | ||
|
||
module ActiveRecord | ||
class DatabaseConfigurations | ||
class UrlConfigTest < ActiveRecord::TestCase | ||
def test_schema_dump_parsing | ||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?schema_dump=false", {}) | ||
assert_nil config.schema_dump | ||
|
||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?schema_dump=db/foo_schema.rb", {}) | ||
assert_equal "db/foo_schema.rb", config.schema_dump | ||
|
||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo", {}) | ||
assert_equal "schema.rb", config.schema_dump | ||
end | ||
|
||
def test_query_cache_parsing | ||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?query_cache=false", {}) | ||
assert_equal false, config.query_cache | ||
|
||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?query_cache=42", {}) | ||
assert_equal "42", config.query_cache | ||
end | ||
|
||
def test_replica_parsing | ||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo", {}) | ||
assert_nil config.replica? | ||
|
||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?replica=true", {}) | ||
assert_equal true, config.replica? | ||
|
||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?replica=false", {}) | ||
assert_equal false, config.replica? | ||
|
||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?replica=random", {}) | ||
assert_equal true, config.replica? | ||
end | ||
|
||
def test_database_tasks_parsing | ||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo", {}) | ||
assert_equal true, config.database_tasks? | ||
|
||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?database_tasks=random", {}) | ||
assert_equal true, config.database_tasks? | ||
|
||
config = UrlConfig.new("default_env", "primary", "postgres://localhost/foo?database_tasks=false", {}) | ||
assert_equal false, config.database_tasks? | ||
end | ||
end | ||
end | ||
end |