# frozen_string_literal: true require 'spec_helpers/client' RSpec.describe FinApps::REST::PortfoliosConsumers do include SpecHelpers::Client subject { FinApps::REST::PortfoliosConsumers.new(client) } describe '#list' do let(:list) { subject.list(portfolio_id, params) } let(:results) { list[RESULTS] } let(:errors) { list[ERROR_MESSAGES] } context 'when missing id' do let(:portfolio_id) { nil } let(:params) { nil } it { expect { list }.to raise_error(FinAppsCore::MissingArgumentsError) } end context 'when invalid params are provided' do let(:portfolio_id) { 'valid_id' } let(:params) { %w[this is an array] } it { expect { list }.to raise_error(FinAppsCore::InvalidArgumentsError) } end context 'when valid id is provided w/o params' do let(:portfolio_id) { 'valid_id' } let(:params) { nil } it { expect { list }.not_to raise_error } it('returns an array') { expect(list).to be_a(Array) } it('performs a get and returns the response') do expect(results).to have_key(:records) end it('returns no error messages') { expect(errors).to be_empty } end context 'when valid id is provided w/ valid params' do let(:portfolio_id) { 'valid_id' } let(:params) { { page: 2, sort: '-created_date', requested: 25 } } it { expect { list }.not_to raise_error } it('returns an array') { expect(list).to be_a(Array) } it('performs a get and returns the response') do expect(results).to have_key(:records) end it('returns no error messages') { expect(errors).to be_empty } it 'builds query and sends proper request' do list url = "#{versioned_api_path}/portfolios/#{portfolio_id}/consumers?page=2&" \ 'requested=25&sort=-created_date' expect(WebMock).to have_requested(:get, url) end end context 'when invalid id is provided' do let(:portfolio_id) { 'invalid_id' } let(:params) { nil } it { expect { list }.not_to raise_error } it('results is nil') { expect(results).to be_nil } it('error messages array is populated') do expect(errors.first.downcase).to eq('resource not found') end end end describe '#create' do let(:create) { subject.create(portfolio_id, params) } let(:results) { create[RESULTS] } let(:errors) { create[ERROR_MESSAGES] } context 'when missing portfolio_id' do let(:portfolio_id) { nil } let(:params) { 'valid_id' } it do expect { create }.to raise_error(FinAppsCore::MissingArgumentsError) end end context 'when missing params' do let(:portfolio_id) { 'valid_id' } let(:params) { nil } it do expect { create }.to raise_error(FinAppsCore::MissingArgumentsError) end end context 'for bulk subscribe' do context 'when valid id and params are provided' do let(:portfolio_id) { 'valid_id' } let(:params) { %w[id1 id2 id3] } it { expect { create }.not_to raise_error } it('returns an array') { expect(create).to be_a(Array) } it('results is nil') { expect(results).to be_nil } it('returns no error messages') { expect(errors).to be_empty } it('builds correct url') do create url = "#{versioned_api_path}/portfolios/#{portfolio_id}/consumers" expect(WebMock).to have_requested(:post, url) end end context 'when invalid id and params are provided' do let(:portfolio_id) { 'invalid_id' } let(:params) { %w[id1 id2 id3] } it { expect { create }.not_to raise_error } it('results is nil') { expect(results).to be_nil } it('error messages array is populated') do # this will break when client is fixed to expect new array error response expect(errors.first.downcase).to eq( 'the server responded with status 400' ) end end end context 'for single subscribe' do context 'when valid ids are provided' do let(:portfolio_id) { 'valid_id' } let(:params) { portfolio_id } it { expect { create }.not_to raise_error } it('returns an array') { expect(create).to be_a(Array) } it('results is nil') { expect(results).to be_nil } it('returns no error messages') { expect(errors).to be_empty } it('builds correct url') do create url = "#{versioned_api_path}/portfolios/#{portfolio_id}/consumers/#{params}" expect(WebMock).to have_requested(:post, url) end end context 'when invalid ids are provided' do let(:portfolio_id) { 'invalid_id' } let(:params) { portfolio_id } it { expect { create }.not_to raise_error } it('results is nil') { expect(results).to be_nil } it('error messages array is populated') do expect(errors.first.downcase).to eq( 'consumer not eligible, no completed orders.' ) end end end end describe '#destroy' do let(:destroy) { subject.destroy(portfolio_id, consumer_id) } let(:results) { destroy[RESULTS] } let(:errors) { destroy[ERROR_MESSAGES] } context 'when missing portfolio_id' do let(:portfolio_id) { nil } let(:consumer_id) { 'valid_id' } it do expect { destroy }.to raise_error(FinAppsCore::MissingArgumentsError) end end context 'when missing consumer_id' do let(:portfolio_id) { 'valid_id' } let(:consumer_id) { nil } it do expect { destroy }.to raise_error(FinAppsCore::MissingArgumentsError) end end context 'when valid ids are provided' do let(:portfolio_id) { 'valid_id' } let(:consumer_id) { portfolio_id } it { expect { destroy }.not_to raise_error } it('returns an array') { expect(destroy).to be_a(Array) } it('results is nil') { expect(results).to be_nil } it('returns no error messages') { expect(errors).to be_empty } end context 'when invalid ids are provided' do let(:portfolio_id) { 'invalid_id' } let(:consumer_id) { portfolio_id } it { expect { destroy }.not_to raise_error } it('results is nil') { expect(results).to be_nil } it('error messages array is populated') do expect(errors.first.downcase).to eq('resource not found') end end end end