scinote-web/spec/controllers/team_repositories_controller_spec.rb

113 lines
3.2 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require 'rails_helper'
describe TeamRepositoriesController, type: :controller do
login_user
include_context 'reference_project_structure'
let(:repository) { create :repository, team: team, created_by: user }
2023-11-13 16:34:38 +08:00
let(:target_team) { create :team, created_by: user }
describe 'DELETE destroy' do
let(:second_team) { create :team, created_by: user }
let(:team_repository) { create :team_shared_object, :read, team: second_team, shared_object: repository }
context 'when resource can be deleted' do
2019-07-16 18:21:20 +08:00
let(:action) do
2023-11-13 16:34:38 +08:00
delete :destroy, params: { repository_id: repository.id, team_id: team.id, id: team_repository.id }
2019-07-16 18:21:20 +08:00
end
it 'renders 204' do
action
expect(response).to have_http_status(204)
end
2019-07-16 18:21:20 +08:00
it 'calls create activity for deleting inventory' do
expect(Activities::CreateActivityService)
.to(receive(:call)
.with(hash_including(activity_type: :unshare_inventory)))
action
end
it 'adds activity in DB' do
expect { action }.to(change { Activity.count })
end
end
context 'when resource is not found' do
it 'renders 422' do
delete :destroy, params: { repository_id: repository.id, team_id: team.id, id: -1 }
expect(response).to have_http_status(422)
end
end
context 'when user do not have access to inventory' do
it 'renders 404' do
repository.user_assignments.update(user_role: viewer_role)
delete :destroy, params: { repository_id: repository.id, team_id: team.id, id: team_repository.id }
expect(response).to have_http_status(403)
end
end
end
describe 'POST update' do
context 'when have valid params' do
before do
service = double('success_service')
allow(service).to(receive(:succeed?)).and_return(true)
allow(service).to(receive(:warnings)).and_return([])
allow_any_instance_of(Repositories::MultipleShareUpdateService).to(receive(:call)).and_return(service)
end
let(:params) do
{
repository_id: repository.id,
team_id: team.id,
permission_changes: '{"5":true}',
share_team_ids: %w(1 2 3),
write_permissions: %w(3)
}
end
it 'renders status ok' do
post :update, params: params
expect(response).to have_http_status(200)
end
end
context 'when have invalid params' do
before do
service = double('unsuccess_service')
allow(service).to(receive(:succeed?)).and_return(false)
allow(service).to(receive(:errors)).and_return({})
allow_any_instance_of(Repositories::MultipleShareUpdateService).to(receive(:call)).and_return(service)
end
let(:new_repository) { create :repository }
let(:params) do
{
repository_id: repository.id,
team_id: team.id,
permission_changes: '{"5":true}',
share_team_ids: %w(1 2 3),
write_permissions: %w(3)
}
end
it 'renders status 422' do
post :update, params: params
expect(response).to have_http_status(422)
end
end
end
end