12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe Service::Ticket::SharedDraft::Start::Update do
- let(:group) { create(:group) }
- let(:content) { { content: Faker::Lorem.unique.sentence } }
- let(:form_id) { 123 }
- let(:shared_draft) { create(:ticket_shared_draft_start, group:, name: draft_name) }
- let(:draft_name) { 'initial draft name' }
- let(:user) do
- create(:agent)
- .tap { |elem| elem.user_groups.create!(group:, access: :create) }
- end
- context 'when user has access to the draft group' do
- it 'returns new object' do
- described_class
- .new(user, shared_draft, form_id, content:, group:)
- .execute
- expect(shared_draft.reload).to have_attributes(name: draft_name, content:, group:)
- end
- # name can be changed via REST api, but GraphQL mutation does not support it
- it 'changes name if given' do
- described_class
- .new(user, shared_draft, form_id, content:, group:, name: 'new name')
- .execute
- expect(shared_draft.reload).to have_attributes(name: 'new name')
- end
- it 'copies attachments from the given form' do
- create(:store, o_id: form_id)
- described_class
- .new(user, shared_draft, form_id, content:, group:)
- .execute
- expect(Store.list(object: shared_draft.class.name, o_id: shared_draft.id))
- .to contain_exactly(have_attributes(filename: 'test.txt'))
- end
- end
- context 'when user has insufficient access to the target draft group' do
- let(:new_group) { create(:group) }
- before do
- allow(user).to receive(:group_access?).with(new_group.id, :create).and_return(false)
- end
- it 'raises an error' do
- expect do
- described_class
- .new(user, shared_draft, form_id, content:, group: new_group)
- .execute
- end
- .to raise_error(Pundit::NotAuthorizedError)
- end
- end
- end
|