mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2024-12-28 11:14:24 +08:00
112 lines
3.2 KiB
Ruby
112 lines
3.2 KiB
Ruby
# 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 }
|
|
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
|
|
let(:action) do
|
|
delete :destroy, params: { repository_id: repository.id, team_id: team.id, id: team_repository.id }
|
|
end
|
|
|
|
it 'renders 204' do
|
|
action
|
|
|
|
expect(response).to have_http_status(204)
|
|
end
|
|
|
|
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
|