2022-05-07 20:08:51 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Users::SavedReplies::UpdateService do
|
|
|
|
describe '#execute' do
|
|
|
|
let_it_be(:current_user) { create(:user) }
|
|
|
|
let_it_be(:saved_reply) { create(:saved_reply, user: current_user) }
|
|
|
|
let_it_be(:other_saved_reply) { create(:saved_reply, user: current_user) }
|
|
|
|
let_it_be(:saved_reply_from_other_user) { create(:saved_reply) }
|
|
|
|
|
2022-06-21 17:19:12 +05:30
|
|
|
subject { described_class.new(saved_reply: saved_reply, name: name, content: content).execute }
|
2022-05-07 20:08:51 +05:30
|
|
|
|
|
|
|
context 'when update fails' do
|
|
|
|
let(:name) { other_saved_reply.name }
|
|
|
|
let(:content) { '' }
|
|
|
|
|
|
|
|
it { is_expected.not_to be_success }
|
|
|
|
|
|
|
|
it 'returns error messages' do
|
|
|
|
expect(subject.errors).to match_array(["Content can't be blank", "Name has already been taken"])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when update succeeds' do
|
|
|
|
let(:name) { saved_reply_from_other_user.name }
|
|
|
|
let(:content) { 'New content for Saved Reply' }
|
|
|
|
|
|
|
|
it { is_expected.to be_success }
|
|
|
|
|
|
|
|
it 'updates new Saved Reply in database' do
|
|
|
|
expect { subject }.not_to change(::Users::SavedReply, :count)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns saved reply' do
|
|
|
|
expect(subject[:saved_reply]).to eq(saved_reply)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|