debian-mirror-gitlab/spec/services/service_response_spec.rb

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

218 lines
6.4 KiB
Ruby
Raw Normal View History

2019-07-31 22:56:46 +05:30
# frozen_string_literal: true
require 'fast_spec_helper'
2022-07-23 23:45:48 +05:30
require 're2'
2021-10-27 15:23:28 +05:30
require_relative '../../app/services/service_response'
2022-07-23 23:45:48 +05:30
require_relative '../../lib/gitlab/error_tracking'
2019-07-31 22:56:46 +05:30
2023-05-27 22:25:52 +05:30
RSpec.describe ServiceResponse, feature_category: :shared do
2019-07-31 22:56:46 +05:30
describe '.success' do
it 'creates a successful response without a message' do
expect(described_class.success).to be_success
end
it 'creates a successful response with a message' do
response = described_class.success(message: 'Good orange')
expect(response).to be_success
expect(response.message).to eq('Good orange')
end
2019-09-30 21:07:59 +05:30
it 'creates a successful response with payload' do
response = described_class.success(payload: { good: 'orange' })
expect(response).to be_success
expect(response.payload).to eq(good: 'orange')
end
2019-12-04 20:38:33 +05:30
it 'creates a successful response with default HTTP status' do
response = described_class.success
expect(response).to be_success
expect(response.http_status).to eq(:ok)
end
it 'creates a successful response with custom HTTP status' do
response = described_class.success(http_status: 204)
expect(response).to be_success
expect(response.http_status).to eq(204)
end
2019-07-31 22:56:46 +05:30
end
describe '.error' do
2022-10-11 01:57:18 +05:30
it 'creates an error response without HTTP status' do
2019-07-31 22:56:46 +05:30
response = described_class.error(message: 'Bad apple')
expect(response).to be_error
expect(response.message).to eq('Bad apple')
end
2022-10-11 01:57:18 +05:30
it 'creates an error response with HTTP status' do
2019-07-31 22:56:46 +05:30
response = described_class.error(message: 'Bad apple', http_status: 400)
expect(response).to be_error
expect(response.message).to eq('Bad apple')
expect(response.http_status).to eq(400)
end
2019-09-30 21:07:59 +05:30
2022-10-11 01:57:18 +05:30
it 'creates an error response with payload' do
2019-09-30 21:07:59 +05:30
response = described_class.error(message: 'Bad apple',
payload: { bad: 'apple' })
expect(response).to be_error
expect(response.message).to eq('Bad apple')
expect(response.payload).to eq(bad: 'apple')
end
2022-10-11 01:57:18 +05:30
it 'creates an error response with a reason' do
response = described_class.error(message: 'Bad apple',
reason: :permission_denied)
expect(response).to be_error
expect(response.message).to eq('Bad apple')
expect(response.reason).to eq(:permission_denied)
end
2019-07-31 22:56:46 +05:30
end
describe '#success?' do
it 'returns true for a successful response' do
expect(described_class.success.success?).to eq(true)
end
it 'returns false for a failed response' do
expect(described_class.error(message: 'Bad apple').success?).to eq(false)
end
end
describe '#error?' do
it 'returns false for a successful response' do
expect(described_class.success.error?).to eq(false)
end
it 'returns true for a failed response' do
expect(described_class.error(message: 'Bad apple').error?).to eq(true)
end
end
2020-06-23 00:09:42 +05:30
describe '#errors' do
it 'returns an empty array for a successful response' do
expect(described_class.success.errors).to be_empty
end
it 'returns an array with a correct message for an error response' do
expect(described_class.error(message: 'error message').errors).to eq(['error message'])
end
end
2022-07-23 23:45:48 +05:30
describe '#track_and_raise_exception' do
context 'when successful' do
let(:response) { described_class.success }
it 'returns self' do
expect(response.track_and_raise_exception).to be response
end
end
context 'when an error' do
let(:response) { described_class.error(message: 'bang') }
it 'tracks and raises' do
expect(::Gitlab::ErrorTracking).to receive(:track_and_raise_exception)
.with(StandardError.new('bang'), {})
response.track_and_raise_exception
end
it 'allows specification of error class' do
error = Class.new(StandardError)
expect(::Gitlab::ErrorTracking).to receive(:track_and_raise_exception)
.with(error.new('bang'), {})
response.track_and_raise_exception(as: error)
end
it 'allows extra data for tracking' do
expect(::Gitlab::ErrorTracking).to receive(:track_and_raise_exception)
.with(StandardError.new('bang'), { foo: 1, bar: 2 })
response.track_and_raise_exception(foo: 1, bar: 2)
end
end
end
describe '#track_exception' do
context 'when successful' do
let(:response) { described_class.success }
it 'returns self' do
expect(response.track_exception).to be response
end
end
context 'when an error' do
let(:response) { described_class.error(message: 'bang') }
it 'tracks' do
expect(::Gitlab::ErrorTracking).to receive(:track_exception)
.with(StandardError.new('bang'), {})
expect(response.track_exception).to be response
end
it 'allows specification of error class' do
error = Class.new(StandardError)
expect(::Gitlab::ErrorTracking).to receive(:track_exception)
.with(error.new('bang'), {})
expect(response.track_exception(as: error)).to be response
end
it 'allows extra data for tracking' do
expect(::Gitlab::ErrorTracking).to receive(:track_exception)
.with(StandardError.new('bang'), { foo: 1, bar: 2 })
expect(response.track_exception(foo: 1, bar: 2)).to be response
end
end
end
2023-03-17 16:20:25 +05:30
describe '#log_and_raise_exception' do
context 'when successful' do
let(:response) { described_class.success }
it 'returns self' do
expect(response.log_and_raise_exception).to be response
end
end
context 'when an error' do
let(:response) { described_class.error(message: 'bang') }
it 'logs' do
expect(::Gitlab::ErrorTracking).to receive(:log_and_raise_exception)
.with(StandardError.new('bang'), {})
response.log_and_raise_exception
end
it 'allows specification of error class' do
error = Class.new(StandardError)
expect(::Gitlab::ErrorTracking).to receive(:log_and_raise_exception)
.with(error.new('bang'), {})
response.log_and_raise_exception(as: error)
end
it 'allows extra data for tracking' do
expect(::Gitlab::ErrorTracking).to receive(:log_and_raise_exception)
.with(StandardError.new('bang'), { foo: 1, bar: 2 })
response.log_and_raise_exception(foo: 1, bar: 2)
end
end
end
2019-07-31 22:56:46 +05:30
end