257 lines
5.9 KiB
Ruby
257 lines
5.9 KiB
Ruby
# Copyright (C) 2012-2022 Zammad Foundation, https://zammad-foundation.org/
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe 'KnowledgeBase attachments', type: :request, authenticated_as: :current_user do
|
|
include_context 'basic Knowledge Base'
|
|
|
|
let(:attachment) do
|
|
attachment_file = File.open 'spec/fixtures/upload/hello_world.txt'
|
|
|
|
Store.add(
|
|
object: object.class.to_s,
|
|
o_id: object.id,
|
|
data: attachment_file.read,
|
|
filename: 'hello_world.txt',
|
|
preferences: {},
|
|
created_by_id: 1,
|
|
)
|
|
end
|
|
|
|
let(:endpoint) { "/api/v1/attachments/#{attachment.id}" }
|
|
let(:current_user) { create(user_identifier) if defined?(user_identifier) }
|
|
|
|
describe 'visible when attached to' do
|
|
shared_examples 'a visible resource' do
|
|
it 'and returns correct status code' do
|
|
get endpoint
|
|
expect(response).to have_http_status(:ok)
|
|
end
|
|
end
|
|
|
|
shared_examples 'a non-existent resource' do
|
|
it 'and returns correct status code' do
|
|
get endpoint
|
|
expect(response).to have_http_status(:not_found)
|
|
end
|
|
end
|
|
|
|
describe 'draft answer' do
|
|
let(:object) { draft_answer }
|
|
|
|
describe 'as agent' do
|
|
let(:user_identifier) { :agent }
|
|
|
|
it_behaves_like 'a non-existent resource'
|
|
end
|
|
|
|
context 'as admin' do
|
|
let(:user_identifier) { :admin }
|
|
|
|
it_behaves_like 'a visible resource'
|
|
end
|
|
|
|
context 'as customer' do
|
|
let(:user_identifier) { :customer }
|
|
|
|
it_behaves_like 'a non-existent resource'
|
|
end
|
|
|
|
context 'as guest' do
|
|
it_behaves_like 'a non-existent resource'
|
|
end
|
|
end
|
|
|
|
describe 'internal answer' do
|
|
let(:object) { internal_answer }
|
|
|
|
describe 'as agent' do
|
|
let(:user_identifier) { :agent }
|
|
|
|
it_behaves_like 'a visible resource'
|
|
end
|
|
|
|
context 'as admin' do
|
|
let(:user_identifier) { :admin }
|
|
|
|
it_behaves_like 'a visible resource'
|
|
end
|
|
|
|
context 'as customer' do
|
|
let(:user_identifier) { :customer }
|
|
|
|
it_behaves_like 'a non-existent resource'
|
|
end
|
|
|
|
context 'as guest' do
|
|
it_behaves_like 'a non-existent resource'
|
|
end
|
|
end
|
|
|
|
describe 'published answer' do
|
|
let(:object) { published_answer }
|
|
|
|
describe 'as agent' do
|
|
let(:user_identifier) { :agent }
|
|
|
|
it_behaves_like 'a visible resource'
|
|
end
|
|
|
|
context 'as admin' do
|
|
let(:user_identifier) { :admin }
|
|
|
|
it_behaves_like 'a visible resource'
|
|
end
|
|
|
|
context 'as customer' do
|
|
let(:user_identifier) { :customer }
|
|
|
|
it_behaves_like 'a visible resource'
|
|
end
|
|
|
|
context 'as guest' do
|
|
it_behaves_like 'a visible resource'
|
|
end
|
|
end
|
|
|
|
describe 'archived answer' do
|
|
let(:object) { archived_answer }
|
|
|
|
describe 'as agent' do
|
|
let(:user_identifier) { :agent }
|
|
|
|
it_behaves_like 'a non-existent resource'
|
|
end
|
|
|
|
context 'as admin' do
|
|
let(:user_identifier) { :admin }
|
|
|
|
it_behaves_like 'a visible resource'
|
|
end
|
|
|
|
context 'as customer' do
|
|
let(:user_identifier) { :customer }
|
|
|
|
it_behaves_like 'a non-existent resource'
|
|
end
|
|
|
|
context 'as guest' do
|
|
it_behaves_like 'a non-existent resource'
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'deletable when attached to' do
|
|
shared_examples 'a deletable resource' do
|
|
it { expect { delete endpoint }.to change { Store.exists? attachment.id }.from(true).to(false) }
|
|
end
|
|
|
|
shared_examples 'a non-deletable resource' do
|
|
it { expect { delete endpoint }.not_to change { Store.exists? attachment.id }.from(true) }
|
|
end
|
|
|
|
describe 'draft answer' do
|
|
let(:object) { draft_answer }
|
|
|
|
describe 'as agent' do
|
|
let(:user_identifier) { :agent }
|
|
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
|
|
context 'as admin' do
|
|
let(:user_identifier) { :admin }
|
|
|
|
it_behaves_like 'a deletable resource'
|
|
end
|
|
|
|
context 'as customer' do
|
|
let(:user_identifier) { :customer }
|
|
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
|
|
context 'as guest' do
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
end
|
|
|
|
describe 'internal answer' do
|
|
let(:object) { internal_answer }
|
|
|
|
describe 'as agent' do
|
|
let(:user_identifier) { :agent }
|
|
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
|
|
context 'as admin' do
|
|
let(:user_identifier) { :admin }
|
|
|
|
it_behaves_like 'a deletable resource'
|
|
end
|
|
|
|
context 'as customer' do
|
|
let(:user_identifier) { :customer }
|
|
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
|
|
context 'as guest' do
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
end
|
|
|
|
describe 'published answer' do
|
|
let(:object) { published_answer }
|
|
|
|
describe 'as agent' do
|
|
let(:user_identifier) { :agent }
|
|
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
|
|
context 'as admin' do
|
|
let(:user_identifier) { :admin }
|
|
|
|
it_behaves_like 'a deletable resource'
|
|
end
|
|
|
|
context 'as customer' do
|
|
let(:user_identifier) { :customer }
|
|
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
|
|
context 'as guest' do
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
end
|
|
|
|
describe 'archived answer' do
|
|
let(:object) { archived_answer }
|
|
|
|
describe 'as agent' do
|
|
let(:user_identifier) { :agent }
|
|
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
|
|
context 'as admin' do
|
|
let(:user_identifier) { :admin }
|
|
|
|
it_behaves_like 'a deletable resource'
|
|
end
|
|
|
|
context 'as customer' do
|
|
let(:user_identifier) { :customer }
|
|
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
|
|
context 'as guest' do
|
|
it_behaves_like 'a non-deletable resource'
|
|
end
|
|
end
|
|
end
|
|
end
|