blob: 8349ee6ee2548bd80744af4360d5f4129f846ff3 (
plain) (
tree)
|
|
# frozen_string_literal: true
require "cases/helper"
require "support/schema_dumping_helper"
class PostgresqlLtreeTest < ActiveRecord::PostgreSQLTestCase
include SchemaDumpingHelper
class Ltree < ActiveRecord::Base
self.table_name = "ltrees"
end
def setup
@connection = ActiveRecord::Base.connection
enable_extension!("ltree", @connection)
@connection.transaction do
@connection.create_table("ltrees") do |t|
t.ltree "path"
end
end
rescue ActiveRecord::StatementInvalid
skip "do not test on PG without ltree"
end
teardown do
@connection.drop_table "ltrees", if_exists: true
end
def test_column
column = Ltree.columns_hash["path"]
assert_equal :ltree, column.type
assert_equal "ltree", column.sql_type
assert_not_predicate column, :array?
type = Ltree.type_for_attribute("path")
assert_not_predicate type, :binary?
end
def test_write
ltree = Ltree.new(path: "1.2.3.4")
assert ltree.save!
end
def test_select
@connection.execute "insert into ltrees (path) VALUES ('1.2.3')"
ltree = Ltree.first
assert_equal "1.2.3", ltree.path
end
def test_schema_dump_with_shorthand
output = dump_table_schema("ltrees")
assert_match %r[t\.ltree "path"], output
end
end
|