Sha256: 33d3f46adf0332dfd13f25e32b495c0b61bc55501677cc9e05e43e59788928eb

Contents?: true

Size: 1.12 KB

Versions: 1

Compression:

Stored size: 1.12 KB

Contents

require 'spec_helper'
require_relative 'query'
require_relative 'config_helper'

describe Query do
  include RSpec::Hive::WithHiveConnection

  subject { described_class.new }

  describe 'hive query' do
    let(:input_data) do
      [
        ['Mikolaj', 'Cos', 1.23],
        ['Wojtek', 'Cos', 3.76]
      ]
    end

    before do
      connection.execute(subject.table_schema.create_table_statement)
      connection.load_into_table(subject.table_schema, input_data)
    end

    it 'query returns one row' do
      query = "SELECT * FROM `#{subject.table_name}` WHERE amount > 3.2"
      query_result = connection.fetch(query).first.values
      expect(query_result).to contain_exactly(
        a_string_matching('Wojtek'),
        a_string_matching('Cos'),
        a_string_matching(/3\.7.*/))
    end

    it 'query returns one row 2' do
      query = "SELECT * FROM `#{subject.table_name}` WHERE amount < 3.2"
      query_result = connection.fetch(query).first.values
      expect(query_result).to contain_exactly(
        a_string_matching('Mikolaj'),
        a_string_matching('Cos'),
        a_string_matching(/1\.2.*/))
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
rspec-hive-0.1.0 examples/query_spec.rb