Sha256: 1e9bd99e6cc4a079a39a3431bc02bbf050bdd25f9cfcae27b843cbaa9070d7ea

Contents?: true

Size: 1.54 KB

Versions: 4

Compression:

Stored size: 1.54 KB

Contents

require File.join(File.dirname(__FILE__), '_lib.rb')

class MoSQL::Test::Functional::SQLTest < MoSQL::Test::Functional
  before do
    sequel.drop_table?(:test_upsert)
    sequel.create_table?(:test_upsert) do
      column :_id, 'INTEGER'
      column :color, 'TEXT'
      column :quantity, 'INTEGER'
      column :numbers, 'INTEGER ARRAY'
      primary_key [:_id]
    end

    @adapter = MoSQL::SQLAdapter.new(nil, sql_test_uri)
    @table = sequel[:test_upsert]
  end

  describe 'upsert' do
    it 'inserts new items' do
      @adapter.upsert!(@table, ['_id'], {'_id' => 0, 'color' => 'red', 'quantity' => 10, 'numbers' => Sequel.pg_array([1, 2, 3], :integer)})
      @adapter.upsert!(@table, ['_id'], {'_id' => 1, 'color' => 'blue', 'quantity' => 5, 'numbers' => Sequel.pg_array([], :integer)})
      assert_equal(2, @table.count)
      assert_equal('red',  @table[:_id => 0][:color])
      assert_equal(10,     @table[:_id => 0][:quantity])
      assert_equal('blue', @table[:_id => 1][:color])
      assert_equal(5,      @table[:_id => 1][:quantity])
      assert_equal([1, 2, 3], @table[:_id => 0][:numbers])
      assert_equal([], @table[:_id => 1][:numbers])
    end

    it 'updates items' do
      @adapter.upsert!(@table, ['_id'], {'_id' => 0, 'color' => 'red', 'quantity' => 10})
      assert_equal(1, @table.count)
      assert_equal('red',  @table[:_id => 0][:color])

      @adapter.upsert!(@table, ['_id'], {'_id' => 0, 'color' => 'blue', 'quantity' => 5})
      assert_equal(1, @table.count)
      assert_equal('blue', @table[:_id => 0][:color])
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
mosql-0.4.3 test/functional/sql.rb
mosql-0.4.2 test/functional/sql.rb
mosql-0.4.1 test/functional/sql.rb
mosql-0.4.0 test/functional/sql.rb