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

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

118 lines
3.6 KiB
Ruby
Raw Normal View History

2019-07-31 22:56:46 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
require 'spec_helper'
2023-04-23 21:23:45 +05:30
RSpec.describe Groups::LabelsController, feature_category: :team_planning do
2019-12-21 20:55:43 +05:30
let_it_be(:group) { create(:group) }
let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project, namespace: group) }
2017-08-17 22:00:37 +05:30
before do
group.add_owner(user)
sign_in(user)
end
2018-03-27 19:54:05 +05:30
describe 'GET #index' do
2019-12-21 20:55:43 +05:30
let_it_be(:label_1) { create(:label, project: project, title: 'label_1') }
let_it_be(:group_label_1) { create(:group_label, group: group, title: 'group_label_1') }
2018-03-27 19:54:05 +05:30
it 'returns group and project labels by default' do
2019-02-15 15:39:39 +05:30
get :index, params: { group_id: group }, format: :json
2018-03-27 19:54:05 +05:30
2022-10-11 01:57:18 +05:30
label_ids = json_response.map { |label| label['title'] }
2018-03-27 19:54:05 +05:30
expect(label_ids).to match_array([label_1.title, group_label_1.title])
end
2019-10-12 21:52:04 +05:30
context 'with ancestor group' do
2019-12-21 20:55:43 +05:30
let_it_be(:subgroup) { create(:group, parent: group) }
let_it_be(:subgroup_label_1) { create(:group_label, group: subgroup, title: 'subgroup_label_1') }
2018-03-27 19:54:05 +05:30
before do
subgroup.add_owner(user)
end
2021-03-08 18:12:59 +05:30
it 'returns ancestor group labels' do
params = { group_id: subgroup, only_group_labels: true }
get :index, params: params, format: :json
2018-03-27 19:54:05 +05:30
2022-10-11 01:57:18 +05:30
label_ids = json_response.map { |label| label['title'] }
2021-03-08 18:12:59 +05:30
expect(label_ids).to match_array([group_label_1.title, subgroup_label_1.title])
2018-03-27 19:54:05 +05:30
end
end
2019-07-07 11:18:12 +05:30
context 'external authorization' do
subject { get :index, params: { group_id: group.to_param } }
it_behaves_like 'disabled when using an external authorization service'
end
2021-04-29 21:17:54 +05:30
context 'with views rendered' do
render_views
before do
get :index, params: { group_id: group.to_param }
end
2023-03-04 22:38:38 +05:30
it 'avoids N+1 queries', :use_clean_rails_redis_caching do
2021-04-29 21:17:54 +05:30
control = ActiveRecord::QueryRecorder.new(skip_cached: false) { get :index, params: { group_id: group.to_param } }
create_list(:group_label, 3, group: group)
# some n+1 queries still exist
expect { get :index, params: { group_id: group.to_param } }.not_to exceed_all_query_limit(control.count).with_threshold(10)
expect(assigns(:labels).count).to eq(4)
end
end
2018-03-27 19:54:05 +05:30
end
2017-08-17 22:00:37 +05:30
describe 'POST #toggle_subscription' do
it 'allows user to toggle subscription on group labels' do
label = create(:group_label, group: group)
2019-02-15 15:39:39 +05:30
post :toggle_subscription, params: { group_id: group.to_param, id: label.to_param }
2017-08-17 22:00:37 +05:30
2020-03-13 15:44:24 +05:30
expect(response).to have_gitlab_http_status(:ok)
2017-08-17 22:00:37 +05:30
end
end
2021-01-03 14:25:43 +05:30
describe 'DELETE #destroy' do
context 'when current user has ability to destroy the label' do
before do
sign_in(user)
end
it 'removes the label' do
label = create(:group_label, group: group)
delete :destroy, params: { group_id: group.to_param, id: label.to_param }
expect { label.reload }.to raise_error(ActiveRecord::RecordNotFound)
end
context 'when label is succesfuly destroyed' do
it 'redirects to the group labels page' do
label = create(:group_label, group: group)
delete :destroy, params: { group_id: group.to_param, id: label.to_param }
expect(response).to redirect_to(group_labels_path)
end
end
end
context 'when current_user does not have ability to destroy the label' do
let(:another_user) { create(:user) }
before do
sign_in(another_user)
end
it 'responds with status 404' do
label = create(:group_label, group: group)
delete :destroy, params: { group_id: group.to_param, id: label.to_param }
expect(response).to have_gitlab_http_status(:not_found)
end
end
end
2017-08-17 22:00:37 +05:30
end