Sha256: d0ceefa7c069c29059638f490a3334f2d5939a5eb38a5c36b6d59642dcc45282

Contents?: true

Size: 1.94 KB

Versions: 3

Compression:

Stored size: 1.94 KB

Contents

require 'daru/io/sql_data_source'
require 'sqlite3'
require 'dbi'
require 'active_record'

RSpec.describe Daru::IO::SqlDataSource do
  include_context 'with accounts table in sqlite3 database'
  let(:dbi_handle) do
    DBI.connect("DBI:SQLite3:#{db_name}")
  end

  let(:active_record_connection) do
    ActiveRecord::Base.establish_connection("sqlite3:#{db_name}")
    ActiveRecord::Base.connection
  end

  let(:query) do
    'select * from accounts'
  end

  describe '.make_dataframe' do
    context 'with DBI::DatabaseHandle' do
      it 'returns a dataframe' do
        result = Daru::IO::SqlDataSource.make_dataframe(dbi_handle, query)
        expect(result).to be_a(Daru::DataFrame)
        expect(result.nrows).to eq(2)
        expect(result.row[0][:id]).to eq(1)
        expect(result.row[0][:name]).to eq('Homer')
      end

      context 'with an object not a string as a query' do
        it 'raises ArgumentError' do
          expect {
            Daru::IO::SqlDataSource.make_dataframe(dbi_handle, Object.new)
          }.to raise_error(ArgumentError)
        end
      end
    end

    context 'with ActiveRecord::Connection' do
      it 'returns a dataframe' do
        result = Daru::IO::SqlDataSource.make_dataframe(active_record_connection, query)
        expect(result).to be_a(Daru::DataFrame)
        expect(result.nrows).to eq(2)
        expect(result.row[0][:id]).to eq(1)
        expect(result.row[0][:name]).to eq('Homer')
      end

      context 'with an object not a string as a query' do
        it 'raises ArgumentError' do
          expect {
            Daru::IO::SqlDataSource.make_dataframe(active_record_connection, Object.new)
          }.to raise_error(ArgumentError)
        end
      end
    end

    context 'with an object not a database connection' do
      it 'raises ArgumentError' do
        expect {
          Daru::IO::SqlDataSource.make_dataframe(Object.new, query)
        }.to raise_error(ArgumentError)
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
daru-0.1.5 spec/io/sql_data_source_spec.rb
daru-0.1.4.1 spec/io/sql_data_source_spec.rb
daru-0.1.4 spec/io/sql_data_source_spec.rb