# frozen_string_literal: true require 'spec_helper' RSpec.describe BulkImports::NetworkError, :clean_gitlab_redis_cache do let(:tracker) { double(id: 1, stage: 2, entity: double(id: 3)) } describe '.new' do it 'requires either a message or a HTTP response' do expect { described_class.new } .to raise_error(ArgumentError, 'message or response required') end end describe '#retriable?' do it 'returns true for MAX_RETRIABLE_COUNT times when cause if one of RETRIABLE_EXCEPTIONS' do raise described_class::RETRIABLE_EXCEPTIONS.sample rescue StandardError => cause begin raise described_class, cause rescue StandardError => exception described_class::MAX_RETRIABLE_COUNT.times do expect(exception.retriable?(tracker)).to eq(true) end expect(exception.retriable?(tracker)).to eq(false) end end it 'returns true for MAX_RETRIABLE_COUNT times when response is one of RETRIABLE_CODES' do exception = described_class.new(response: double(code: 429)) described_class::MAX_RETRIABLE_COUNT.times do expect(exception.retriable?(tracker)).to eq(true) end expect(exception.retriable?(tracker)).to eq(false) end it 'returns false for other exceptions' do raise StandardError rescue StandardError => cause begin raise described_class, cause rescue StandardError => exception expect(exception.retriable?(tracker)).to eq(false) end end end describe '#retry_delay' do it 'returns the default value when there is not a rate limit error' do exception = described_class.new('foo') expect(exception.retry_delay).to eq(described_class::DEFAULT_RETRY_DELAY_SECONDS.seconds) end context 'when the exception is a rate limit error' do it 'returns the "Retry-After"' do exception = described_class.new(response: double(code: 429, headers: { 'Retry-After' => 20 })) expect(exception.retry_delay).to eq(20.seconds) end it 'returns the default value when there is no "Retry-After" header' do exception = described_class.new(response: double(code: 429, headers: {})) expect(exception.retry_delay).to eq(described_class::DEFAULT_RETRY_DELAY_SECONDS.seconds) end end end end