if defined? JRUBY_VERSION require "activerecord-jdbc-adapter" error_classes = [ActiveRecord::JDBCError] else require "pg" error_classes = [PGError] end error_classes << ActiveRecord::NoDatabaseError if defined? ActiveRecord::NoDatabaseError begin database_user = if ENV["TRAVIS"] "postgres" else ENV["USER"] end ActiveRecord::Base.establish_connection(:adapter => 'postgresql', :database => 'pg_search_test', :username => database_user, :min_messages => 'warning') connection = ActiveRecord::Base.connection connection.execute("SELECT 1") rescue *error_classes => exception at_exit do puts "-" * 80 puts "Unable to connect to database. Please run:" puts puts " createdb pg_search_test" puts "-" * 80 end raise exception end if ENV["LOGGER"] require "logger" ActiveRecord::Base.logger = Logger.new(STDOUT) end def install_extension(name) connection = ActiveRecord::Base.connection extension = connection.execute "SELECT * FROM pg_catalog.pg_extension WHERE extname = '#{name}';" return unless extension.none? connection.execute "CREATE EXTENSION #{name};" rescue => exception at_exit do puts "-" * 80 puts "Please install the #{name} extension" puts "-" * 80 end raise exception end def install_extension_if_missing(name, query, expected_result) result = ActiveRecord::Base.connection.select_value(query) raise "Unexpected output for #{query}: #{result.inspect}" unless result.downcase == expected_result.downcase rescue install_extension(name) end install_extension_if_missing("pg_trgm", "SELECT 'abcdef' % 'cdef'", "t") install_extension_if_missing("unaccent", "SELECT unaccent('foo')", "foo") install_extension_if_missing("fuzzystrmatch", "SELECT dmetaphone('foo')", "f") def load_sql(filename) connection = ActiveRecord::Base.connection file_contents = File.read(File.join(File.dirname(__FILE__), '..', '..', 'sql', filename)) connection.execute(file_contents) end load_sql("dmetaphone.sql")