Module: SchemaDev::Rspec::Db
Defined Under Namespace
Modules: Helpers
Instance Method Summary collapse
- #configuration(db: nil) ⇒ Object
- #connect ⇒ Object
- #database ⇒ Object
- #infer_db ⇒ Object
- #logroot ⇒ Object
- #set_logger ⇒ Object
- #setup ⇒ Object
- #tmproot ⇒ Object
Instance Method Details
#configuration(db: nil) ⇒ Object
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# File 'lib/schema_dev/rspec/db.rb', line 57 def configuration(db: nil) case db || infer_db when 'mysql' { 'adapter' => 'mysql', 'database' => database, 'host' => ENV['MYSQL_DB_HOST'], 'username' => ENV.fetch('MYSQL_DB_USER', 'schema_plus'), 'password' => ENV['MYSQL_DB_PASS'], 'encoding' => 'utf8', 'min_messages' => 'warning' } when 'mysql2' { 'adapter' => 'mysql2', 'database' => database, 'host' => ENV['MYSQL_DB_HOST'], 'username' => ENV.fetch('MYSQL_DB_USER', 'schema_plus'), 'password' => ENV['MYSQL_DB_PASS'], 'encoding' => 'utf8', 'min_messages' => 'warning' } when 'postgresql' { 'adapter' => 'postgresql', 'database' => database, 'host' => ENV['POSTGRESQL_DB_HOST'], 'username' => ENV['POSTGRESQL_DB_USER'], 'password' => ENV['POSTGRESQL_DB_PASS'], 'min_messages' => 'warning' } when 'sqlite3' { 'adapter' => 'sqlite3', 'database' => tmproot.join("#{database}.sqlite3").to_s } else raise "Unknown db adapter #{db.inspect}" end.compact end |
#connect ⇒ Object
102 103 104 105 106 107 108 109 |
# File 'lib/schema_dev/rspec/db.rb', line 102 def connect ActiveRecord::Base.configurations = { 'schema_dev' => configuration } ActiveRecord::Base.establish_connection :schema_dev case infer_db when 'sqlite3' ActiveRecord::Base.connection.execute 'PRAGMA synchronous = OFF' end end |
#database ⇒ Object
52 53 54 55 |
# File 'lib/schema_dev/rspec/db.rb', line 52 def database @database ||= 'schema_plus_test' # @database ||= (Dir["*.gemspec"].first || "schema_dev_test").sub(/\.gemspec$/, '') + "_test" end |
#infer_db ⇒ Object
98 99 100 |
# File 'lib/schema_dev/rspec/db.rb', line 98 def infer_db @infer_db ||= GemfileSelector.infer_db end |
#logroot ⇒ Object
48 49 50 |
# File 'lib/schema_dev/rspec/db.rb', line 48 def logroot @logroot ||= Pathname.new('log').tap(&:mkpath) end |
#set_logger ⇒ Object
111 112 113 114 115 |
# File 'lib/schema_dev/rspec/db.rb', line 111 def set_logger ruby = "#{RUBY_ENGINE}#{RUBY_VERSION}" activerecord = "activerecord#{ActiveRecord.version}" ActiveRecord::Base.logger = Logger.new(logroot.join("#{ruby}-#{activerecord}-#{infer_db}.log").open('w')) end |
#setup ⇒ Object
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
# File 'lib/schema_dev/rspec/db.rb', line 12 def setup set_logger connect RSpec.configure do |config| config.include Helpers config.filter_run_excluding postgresql: -> (v) { if Helpers.postgresql? case v when String version = ActiveRecord::Base.connection.select_value("SHOW server_version").match(/(\d+\.\d+)/)[1] postgresql_version = Gem::Version.new(version) test = Gem::Requirement.new(v) !test.satisfied_by?(postgresql_version) else v == :skip end else v == :only end } config.filter_run_excluding mysql: :only unless Helpers.mysql? config.filter_run_excluding mysql: :skip if Helpers.mysql? config.filter_run_excluding sqlite3: :only unless Helpers.sqlite3? config.filter_run_excluding sqlite3: :skip if Helpers.sqlite3? config.filter_run_excluding rails: -> (v) { rails_version = Gem::Version.new(ActiveRecord::VERSION::STRING) test = Gem::Requirement.new(v) !test.satisfied_by?(rails_version) } end end |
#tmproot ⇒ Object
44 45 46 |
# File 'lib/schema_dev/rspec/db.rb', line 44 def tmproot @tmproot ||= Pathname.new('tmp').tap(&:mkpath) end |