summaryrefslogtreecommitdiff
path: root/spec/controllers/groups
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2022-11-17 21:09:08 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2022-11-17 21:09:08 +0000
commit496e357721b6b807573a35490ab2487dfa299cab (patch)
treeb40b5252a3f3a8339e70f88b84c9ab5c1c6b44c6 /spec/controllers/groups
parentb9b3924a96ef04cf1aa1b7570e2f69bfd8904602 (diff)
downloadgitlab-ce-496e357721b6b807573a35490ab2487dfa299cab.tar.gz
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/controllers/groups')
-rw-r--r--spec/controllers/groups/application_controller_spec.rb45
1 files changed, 45 insertions, 0 deletions
diff --git a/spec/controllers/groups/application_controller_spec.rb b/spec/controllers/groups/application_controller_spec.rb
new file mode 100644
index 00000000000..46908fdb26a
--- /dev/null
+++ b/spec/controllers/groups/application_controller_spec.rb
@@ -0,0 +1,45 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+RSpec.describe Groups::ApplicationController do
+ let_it_be(:user) { create(:user) }
+ let_it_be(:group) { create(:group) }
+
+ describe '#respond_to_missing?' do
+ it 'returns true if the method matches the name structure' do
+ expect(controller.respond_to?(:authorize_read_usage_quotas!)).to eq(true)
+ end
+
+ it 'returns false if the method does not match the name structure' do
+ expect(controller.respond_to?(:does_not_exist)).to eq(false)
+ end
+ end
+
+ describe '#method_missing' do
+ controller do
+ before_action :authorize_read_usage_quotas!
+
+ def index
+ head :ok
+ end
+ end
+
+ it 'calls authorize_action! with the policy and renders not_found when user not authorized' do
+ group.add_maintainer(user)
+ sign_in(user)
+ get :index, params: { group_id: group.to_param }
+
+ expect(response).to have_gitlab_http_status(:not_found)
+ expect(response.headers['X-GitLab-Custom-Error']).to eq '1'
+ end
+
+ it 'calls authorize_action! with the policy and renders OK when user is authorized' do
+ group.add_owner(user)
+ sign_in(user)
+ get :index, params: { group_id: group.to_param }
+
+ expect(response).to have_gitlab_http_status(:ok)
+ end
+ end
+end