diff options
Diffstat (limited to 'spec/lib/bulk_imports/common/extractors/rest_extractor_spec.rb')
-rw-r--r-- | spec/lib/bulk_imports/common/extractors/rest_extractor_spec.rb | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/spec/lib/bulk_imports/common/extractors/rest_extractor_spec.rb b/spec/lib/bulk_imports/common/extractors/rest_extractor_spec.rb new file mode 100644 index 00000000000..721dacbe3f4 --- /dev/null +++ b/spec/lib/bulk_imports/common/extractors/rest_extractor_spec.rb @@ -0,0 +1,31 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe BulkImports::Common::Extractors::RestExtractor do + let(:http_client) { instance_double(BulkImports::Clients::Http) } + let(:options) { { query: double(to_h: { resource: nil, query: nil }) } } + let(:response) { double(parsed_response: { 'data' => { 'foo' => 'bar' } }, headers: { 'x-next-page' => '2' }) } + + subject { described_class.new(options) } + + describe '#extract' do + before do + allow(subject).to receive(:http_client).and_return(http_client) + allow(http_client).to receive(:get).and_return(response) + end + + it 'returns instance of ExtractedData' do + entity = create(:bulk_import_entity) + tracker = create(:bulk_import_tracker, entity: entity) + context = BulkImports::Pipeline::Context.new(tracker) + + extracted_data = subject.extract(context) + + expect(extracted_data).to be_instance_of(BulkImports::Pipeline::ExtractedData) + expect(extracted_data.data).to contain_exactly(response.parsed_response) + expect(extracted_data.next_page).to eq(response.headers['x-next-page']) + expect(extracted_data.has_next_page?).to eq(true) + end + end +end |