debian-mirror-gitlab/elasticsearch-rails/elasticsearch-model/spec/elasticsearch/model/response/base_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

91 lines
1.8 KiB
Ruby
Raw Normal View History

2020-03-13 15:44:24 +05:30
require 'spec_helper'
describe Elasticsearch::Model::Response::Base do
before(:all) do
class DummyBaseClass
include Elasticsearch::Model::Response::Base
end
class OriginClass
def self.index_name; 'foo'; end
def self.document_type; 'bar'; end
end
end
after(:all) do
remove_classes(DummyBaseClass, OriginClass)
end
let(:response_document) do
{ 'hits' => { 'total' => 123, 'max_score' => 456, 'hits' => [] } }
end
let(:search) do
Elasticsearch::Model::Searching::SearchRequest.new(OriginClass, '*').tap do |request|
allow(request).to receive(:execute!).and_return(response_document)
end
end
let(:response) do
Elasticsearch::Model::Response::Response.new(OriginClass, search)
end
let(:response_base) do
DummyBaseClass.new(OriginClass, response)
end
describe '#klass' do
it 'returns the class' do
expect(response.klass).to be(OriginClass)
end
end
describe '#response' do
it 'returns the response object' do
expect(response_base.response).to eq(response)
end
end
describe 'response document' do
it 'returns the response document' do
expect(response_base.response.response).to eq(response_document)
end
end
describe '#total' do
it 'returns the total' do
expect(response_base.total).to eq(123)
end
end
describe '#max_score' do
it 'returns the total' do
expect(response_base.max_score).to eq(456)
end
end
describe '#results' do
it 'raises a NotImplemented error' do
expect {
response_base.results
}.to raise_exception(Elasticsearch::Model::NotImplemented)
end
end
describe '#records' do
it 'raises a NotImplemented error' do
expect {
response_base.records
}.to raise_exception(Elasticsearch::Model::NotImplemented)
end
end
end