Sha256: d67aafcd00e0a890c2f103ef7581f1578269b0c2d73f61242b9027cb5f9710e7

Contents?: true

Size: 1.84 KB

Versions: 6

Compression:

Stored size: 1.84 KB

Contents

require 'spec_helper'

describe ThinkingSphinx::ActiveRecord::DatabaseAdapters::PostgreSQLAdapter do
  let(:adapter) {
    ThinkingSphinx::ActiveRecord::DatabaseAdapters::PostgreSQLAdapter.new(model)
  }
  let(:model)   { double('model') }

  describe '#boolean_value' do
    it "returns 'TRUE' for true" do
      adapter.boolean_value(true).should == 'TRUE'
    end

    it "returns 'FALSE' for false" do
      adapter.boolean_value(false).should == 'FALSE'
    end
  end

  describe '#cast_to_string' do
    it "casts the clause to characters" do
      adapter.cast_to_string('foo').should == 'foo::varchar'
    end
  end

  describe '#cast_to_timestamp' do
    it "converts to int unix timestamps" do
      adapter.cast_to_timestamp('created_at').
        should == 'extract(epoch from created_at)::int'
    end

    it "converts to bigint unix timestamps" do
      ThinkingSphinx::Configuration.instance.settings['64bit_timestamps'] = true

      adapter.cast_to_timestamp('created_at').
        should == 'extract(epoch from created_at)::bigint'
    end
  end

  describe '#concatenate' do
    it "concatenates with the given separator" do
      adapter.concatenate('foo, bar, baz', ',').
        should == "COALESCE(foo, '') || ',' || COALESCE(bar, '') || ',' || COALESCE(baz, '')"
    end
  end

  describe '#convert_nulls' do
    it "translates arguments to a COALESCE SQL call" do
      adapter.convert_nulls('id', 5).should == 'COALESCE(id, 5)'
    end
  end

  describe '#convert_blank' do
    it "translates arguments to a COALESCE NULLIF SQL call" do
      adapter.convert_blank('id', 5).should == "COALESCE(NULLIF(id, ''), 5)"
    end
  end

  describe '#group_concatenate' do
    it "group concatenates the clause with the given separator" do
      adapter.group_concatenate('foo', ',').
        should == "array_to_string(array_agg(DISTINCT foo), ',')"
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
thinking-sphinx-3.2.0 spec/thinking_sphinx/active_record/database_adapters/postgresql_adapter_spec.rb
thinking-sphinx-3.1.4 spec/thinking_sphinx/active_record/database_adapters/postgresql_adapter_spec.rb
thinking-sphinx-3.1.3 spec/thinking_sphinx/active_record/database_adapters/postgresql_adapter_spec.rb
thinking-sphinx-3.1.2 spec/thinking_sphinx/active_record/database_adapters/postgresql_adapter_spec.rb
thinking-sphinx-3.1.1 spec/thinking_sphinx/active_record/database_adapters/postgresql_adapter_spec.rb
thinking-sphinx-3.1.0 spec/thinking_sphinx/active_record/database_adapters/postgresql_adapter_spec.rb