summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2022-02-25 16:30:40 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2022-02-25 16:30:40 +0000
commitb485c8c3723dc5aaba15ab9fa258010d1ec66d61 (patch)
tree36cd2260b2f31bc77ad313b644e5784160ce9104 /spec
parent479d579719c36f1b8706165c20f4525bc32bb451 (diff)
downloadgitlab-ce-b485c8c3723dc5aaba15ab9fa258010d1ec66d61.tar.gz
Add latest changes from gitlab-org/security/gitlab@14-8-stable-ee
Diffstat (limited to 'spec')
-rw-r--r--spec/lib/banzai/filter/math_filter_spec.rb8
-rw-r--r--spec/services/members/create_service_spec.rb24
2 files changed, 29 insertions, 3 deletions
diff --git a/spec/lib/banzai/filter/math_filter_spec.rb b/spec/lib/banzai/filter/math_filter_spec.rb
index 6d22fa3a001..128f8532d39 100644
--- a/spec/lib/banzai/filter/math_filter_spec.rb
+++ b/spec/lib/banzai/filter/math_filter_spec.rb
@@ -126,4 +126,12 @@ RSpec.describe Banzai::Filter::MathFilter do
expect(before.to_s).to eq '$'
expect(after.to_s).to eq '$'
end
+
+ it 'limits how many elements can be marked as math' do
+ stub_const('Banzai::Filter::MathFilter::RENDER_NODES_LIMIT', 2)
+
+ doc = filter('$<code>2+2</code>$ + $<code>3+3</code>$ + $<code>4+4</code>$')
+
+ expect(doc.search('.js-render-math').count).to eq(2)
+ end
end
diff --git a/spec/services/members/create_service_spec.rb b/spec/services/members/create_service_spec.rb
index 4d9e69719b4..4396a0d3ec3 100644
--- a/spec/services/members/create_service_spec.rb
+++ b/spec/services/members/create_service_spec.rb
@@ -11,19 +11,37 @@ RSpec.describe Members::CreateService, :aggregate_failures, :clean_gitlab_redis_
let(:additional_params) { { invite_source: '_invite_source_' } }
let(:params) { { user_ids: user_ids, access_level: access_level }.merge(additional_params) }
+ let(:current_user) { user }
- subject(:execute_service) { described_class.new(user, params.merge({ source: source })).execute }
+ subject(:execute_service) { described_class.new(current_user, params.merge({ source: source })).execute }
before do
- if source.is_a?(Project)
+ case source
+ when Project
source.add_maintainer(user)
OnboardingProgress.onboard(source.namespace)
- else
+ when Group
source.add_owner(user)
OnboardingProgress.onboard(source)
end
end
+ context 'when the current user does not have permission to create members' do
+ let(:current_user) { create(:user) }
+
+ it 'raises a Gitlab::Access::AccessDeniedError' do
+ expect { execute_service }.to raise_error(Gitlab::Access::AccessDeniedError)
+ end
+ end
+
+ context 'when passing an invalid source' do
+ let_it_be(:source) { Object.new }
+
+ it 'raises a RuntimeError' do
+ expect { execute_service }.to raise_error(RuntimeError, 'Unknown source type: Object!')
+ end
+ end
+
context 'when passing valid parameters' do
it 'adds a user to members' do
expect(execute_service[:status]).to eq(:success)