2020-02-13 10:08:52 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 11:08:50 -04:00
|
|
|
RSpec.describe Users::BlockService do
|
2020-02-13 10:08:52 -05:00
|
|
|
let(:current_user) { create(:admin) }
|
|
|
|
|
|
|
|
subject(:service) { described_class.new(current_user) }
|
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
subject(:operation) { service.execute(user) }
|
|
|
|
|
|
|
|
context 'when successful' do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
|
|
|
it { is_expected.to eq(status: :success) }
|
|
|
|
|
|
|
|
it "change the user's state" do
|
|
|
|
expect { operation }.to change { user.state }.to('blocked')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when failed' do
|
|
|
|
let(:user) { create(:user, :blocked) }
|
|
|
|
|
|
|
|
it 'returns error result' do
|
|
|
|
aggregate_failures 'error result' do
|
|
|
|
expect(operation[:status]).to eq(:error)
|
|
|
|
expect(operation[:message]).to match(/State cannot transition/)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not change the user's state" do
|
|
|
|
expect { operation }.not_to change { user.state }
|
|
|
|
end
|
|
|
|
end
|
2020-10-13 02:09:09 -04:00
|
|
|
|
|
|
|
context 'when internal user' do
|
|
|
|
let(:user) { create(:user, :bot) }
|
|
|
|
|
|
|
|
it 'returns error result' do
|
|
|
|
expect(operation[:status]).to eq(:error)
|
|
|
|
expect(operation[:message]).to eq('An internal user cannot be blocked')
|
|
|
|
expect(operation[:http_status]).to eq(403)
|
|
|
|
end
|
|
|
|
end
|
2020-02-13 10:08:52 -05:00
|
|
|
end
|
|
|
|
end
|