debian-mirror-gitlab/spec/controllers/groups/group_links_controller_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

166 lines
4.4 KiB
Ruby
Raw Normal View History

2019-12-26 22:10:19 +05:30
# frozen_string_literal: true
require 'spec_helper'
2020-06-23 00:09:42 +05:30
RSpec.describe Groups::GroupLinksController do
2019-12-26 22:10:19 +05:30
let(:shared_with_group) { create(:group, :private) }
let(:shared_group) { create(:group, :private) }
let(:user) { create(:user) }
2020-03-13 15:44:24 +05:30
let(:group_member) { create(:user) }
let!(:project) { create(:project, group: shared_group) }
2019-12-26 22:10:19 +05:30
before do
2021-04-29 21:17:54 +05:30
travel_to DateTime.new(2019, 4, 1)
2019-12-26 22:10:19 +05:30
sign_in(user)
2020-03-13 15:44:24 +05:30
shared_with_group.add_developer(group_member)
2019-12-26 22:10:19 +05:30
end
2021-04-29 21:17:54 +05:30
after do
travel_back
end
2021-01-03 14:25:43 +05:30
shared_examples 'placeholder is passed as `id` parameter' do |action|
it 'returns a 404' do
post(
action,
params: {
group_id: shared_group,
id: ':id'
},
format: :json
)
expect(response).to have_gitlab_http_status(:not_found)
end
end
2020-03-13 15:44:24 +05:30
describe '#update' do
let!(:link) do
create(:group_group_link, { shared_group: shared_group,
shared_with_group: shared_with_group })
end
let(:expiry_date) { 1.month.from_now.to_date }
subject do
2021-01-03 14:25:43 +05:30
post(
:update,
params: {
group_id: shared_group,
id: link.id,
group_link: { group_access: Gitlab::Access::GUEST, expires_at: expiry_date }
},
format: :json
)
2020-03-13 15:44:24 +05:30
end
context 'when user has admin access to the shared group' do
before do
shared_group.add_owner(user)
shared_with_group.refresh_members_authorized_projects
end
it 'updates existing link' do
expect(link.group_access).to eq(Gitlab::Access::DEVELOPER)
expect(link.expires_at).to be_nil
subject
link.reload
expect(link.group_access).to eq(Gitlab::Access::GUEST)
expect(link.expires_at).to eq(expiry_date)
end
2021-01-03 14:25:43 +05:30
context 'when `expires_at` is set' do
it 'returns correct json response' do
travel_to Time.now.utc.beginning_of_day
subject
2022-06-21 17:19:12 +05:30
expect(json_response).to eq({ "expires_in" => controller.helpers.time_ago_with_tooltip(expiry_date),
"expires_soon" => false })
2021-01-03 14:25:43 +05:30
end
end
context 'when `expires_at` is not set' do
let(:expiry_date) { nil }
it 'returns empty json response' do
subject
expect(json_response).to be_empty
end
end
2021-09-30 23:02:18 +05:30
it 'updates project permissions', :sidekiq_inline do
2020-03-13 15:44:24 +05:30
expect { subject }.to change { group_member.can?(:create_release, project) }.from(true).to(false)
end
end
context 'when user does not have admin access to the shared group' do
it 'renders 404' do
subject
expect(response).to have_gitlab_http_status(:not_found)
end
end
2021-01-03 14:25:43 +05:30
include_examples 'placeholder is passed as `id` parameter', :update
2020-03-13 15:44:24 +05:30
end
describe '#destroy' do
let!(:link) do
create(:group_group_link, { shared_group: shared_group,
shared_with_group: shared_with_group })
end
subject do
post(:destroy, params: { group_id: shared_group,
id: link.id })
end
context 'when user has admin access to the shared group' do
before do
shared_group.add_owner(user)
shared_with_group.refresh_members_authorized_projects
end
it 'deletes existing link' do
expect { subject }.to change(GroupGroupLink, :count).by(-1)
end
2022-08-13 15:12:31 +05:30
context 'with skip_group_share_unlink_auth_refresh feature flag disabled' do
before do
stub_feature_flags(skip_group_share_unlink_auth_refresh: false)
end
it 'updates project permissions', :sidekiq_inline do
expect { subject }.to change { group_member.can?(:create_release, project) }.from(true).to(false)
end
end
context 'with skip_group_share_unlink_auth_refresh feature flag enabled' do
before do
stub_feature_flags(skip_group_share_unlink_auth_refresh: true)
end
it 'maintains project authorization', :sidekiq_inline do
expect(Ability.allowed?(user, :read_project, project)).to be_truthy
end
2020-03-13 15:44:24 +05:30
end
end
context 'when user does not have admin access to the shared group' do
it 'renders 404' do
subject
expect(response).to have_gitlab_http_status(:not_found)
end
end
2021-01-03 14:25:43 +05:30
include_examples 'placeholder is passed as `id` parameter', :destroy
2019-12-26 22:10:19 +05:30
end
end