require "cases/helper" module ActiveRecord module ConnectionAdapters class ConnectionSpecification class ResolverTest < ActiveRecord::TestCase def resolve(spec, config={}) Resolver.new(config).resolve(spec) end def spec(spec, config={}) Resolver.new(config).spec(spec) end def test_url_invalid_adapter error = assert_raises(LoadError) do spec 'ridiculous://foo?encoding=utf8' end assert_match "Could not load 'active_record/connection_adapters/ridiculous_adapter'", error.message end # The abstract adapter is used simply to bypass the bit of code that # checks that the adapter file can be required in. def test_url_from_environment spec = resolve :production, 'production' => 'abstract://foo?encoding=utf8' assert_equal({ "adapter" => "abstract", "host" => "foo", "encoding" => "utf8" }, spec) end def test_url_sub_key spec = resolve :production, 'production' => {"url" => 'abstract://foo?encoding=utf8'} assert_equal({ "adapter" => "abstract", "host" => "foo", "encoding" => "utf8" }, spec) end def test_url_sub_key_merges_correctly hash = {"url" => 'abstract://foo?encoding=utf8&', "adapter" => "sqlite3", "host" => "bar", "pool" => "3"} spec = resolve :production, 'production' => hash assert_equal({ "adapter" => "abstract", "host" => "foo", "encoding" => "utf8", "pool" => "3" }, spec) end def test_url_host_no_db spec = resolve 'abstract://foo?encoding=utf8' assert_equal({ "adapter" => "abstract", "host" => "foo", "encoding" => "utf8" }, spec) end def test_url_missing_scheme spec = resolve 'foo' assert_equal({ "database" => "foo" }, spec) end def test_url_host_db spec = resolve 'abstract://foo/bar?encoding=utf8' assert_equal({ "adapter" => "abstract", "database" => "bar", "host" => "foo", "encoding" => "utf8" }, spec) end def test_url_port spec = resolve 'abstract://foo:123?encoding=utf8' assert_equal({ "adapter" => "abstract", "port" => 123, "host" => "foo", "encoding" => "utf8" }, spec) end def test_encoded_password password = 'am@z1ng_p@ssw0rd#!' encoded_password = URI.encode_www_form_component(password) spec = resolve "abstract://foo:#{encoded_password}@localhost/bar" assert_equal password, spec["password"] end def test_url_with_authority_for_sqlite3 spec = resolve 'sqlite3:///foo_test' assert_equal('/foo_test', spec["database"]) end def test_url_absolute_path_for_sqlite3 spec = resolve 'sqlite3:/foo_test' assert_equal('/foo_test', spec["database"]) end def test_url_relative_path_for_sqlite3 spec = resolve 'sqlite3:foo_test' assert_equal('foo_test', spec["database"]) end def test_url_memory_db_for_sqlite3 spec = resolve 'sqlite3::memory:' assert_equal(':memory:', spec["database"]) end def test_url_sub_key_for_sqlite3 spec = resolve :production, 'production' => {"url" => 'sqlite3:foo?encoding=utf8'} assert_equal({ "adapter" => "sqlite3", "database" => "foo", "encoding" => "utf8" }, spec) end def test_spec_id_on_key_lookup spec = spec(:readonly, 'readonly' => {'adapter' => 'sqlite3'}) assert_equal "readonly", spec.id end def test_spec_id_with_inline_config spec = spec({'adapter' => 'sqlite3'}) assert_equal "primary", spec.id, "should default to primary id" end end end end end