From 1d72f53d6e13e106bcf5059a012b64a73f3a4bf3 Mon Sep 17 00:00:00 2001 From: maniSHarma7575 Date: Mon, 22 Apr 2024 13:26:38 +0530 Subject: [PATCH] [FIX] Sqlite3 Should create db for missing parent directories as well --- .../connection_adapters/sqlite3_adapter.rb | 10 +++------- .../cases/adapters/sqlite3/sqlite3_adapter_test.rb | 12 +++++++++++- 2 files changed, 14 insertions(+), 8 deletions(-) diff --git a/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb b/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb index 90a16aacc1ad6..fc172fee00d32 100644 --- a/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb +++ b/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb @@ -112,13 +112,9 @@ def initialize(...) dirname = File.dirname(@config[:database]) unless File.directory?(dirname) begin - Dir.mkdir(dirname) - rescue Errno::ENOENT => error - if error.message.include?("No such file or directory") - raise ActiveRecord::NoDatabaseError.new(connection_pool: @pool) - else - raise - end + FileUtils.mkdir_p(dirname) + rescue SystemCallError + raise ActiveRecord::NoDatabaseError.new(connection_pool: @pool) end end end diff --git a/activerecord/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb b/activerecord/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb index 42d853f512487..c0b73034586c6 100644 --- a/activerecord/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb +++ b/activerecord/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb @@ -25,12 +25,22 @@ def setup def test_bad_connection error = assert_raise ActiveRecord::NoDatabaseError do - connection = SQLite3Adapter.new(adapter: "sqlite3", database: "/tmp/should/_not/_exist/-cinco-dog.db") + connection = SQLite3Adapter.new(adapter: "sqlite3", database: "/dev/test-dir/db.sqlite3") connection.drop_table "ex", if_exists: true end assert_kind_of ActiveRecord::ConnectionAdapters::NullPool, error.connection_pool end + def test_database_should_get_created_when_missing_parent_directories_for_database_path + dir = Dir.mktmpdir + db_path = File.join(dir, "_not_exist/-cinco-dog.sqlite3") + assert_nothing_raised do + connection = SQLite3Adapter.new(adapter: "sqlite3", database: db_path) + connection.drop_table "ex", if_exists: true + end + assert SQLite3Adapter.database_exists?(adapter: "sqlite3", database: db_path) + end + def test_database_exists_returns_false_when_the_database_does_not_exist assert_not SQLite3Adapter.database_exists?(adapter: "sqlite3", database: "non_extant_db"), "expected non_extant_db to not exist"