debian-mirror-gitlab/spec/services/users/build_service_spec.rb

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

134 lines
5.2 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-05-27 22:25:52 +05:30
RSpec.describe Users::BuildService, feature_category: :user_management do
2021-03-11 19:13:27 +05:30
using RSpec::Parameterized::TableSyntax
2017-08-17 22:00:37 +05:30
describe '#execute' do
2021-06-08 01:23:25 +05:30
let_it_be(:current_user) { nil }
2021-01-03 14:25:43 +05:30
2021-06-08 01:23:25 +05:30
let(:params) { build_stubbed(:user).slice(:first_name, :last_name, :username, :email, :password) }
let(:service) { described_class.new(current_user, params) }
2017-08-17 22:00:37 +05:30
2021-06-08 01:23:25 +05:30
context 'with nil current_user' do
subject(:user) { service.execute }
2021-09-04 01:27:46 +05:30
it_behaves_like 'common user build items'
it_behaves_like 'current user not admin build items'
2021-06-08 01:23:25 +05:30
end
context 'with non admin current_user' do
let_it_be(:current_user) { create(:user) }
2021-09-04 01:27:46 +05:30
it 'raises AccessDeniedError exception' do
expect { described_class.new(current_user, params).execute }.to raise_error Gitlab::Access::AccessDeniedError
2021-06-08 01:23:25 +05:30
end
end
context 'with an admin current_user' do
let_it_be(:current_user) { create(:admin) }
let(:params) { build_stubbed(:user).slice(:name, :username, :email, :password) }
let(:service) { described_class.new(current_user, ActionController::Parameters.new(params).permit!) }
subject(:user) { service.execute }
2021-09-04 01:27:46 +05:30
it_behaves_like 'common user build items'
2021-06-08 01:23:25 +05:30
context 'with allowed params' do
let(:params) do
{
access_level: 1,
admin: 1,
avatar: anything,
bio: 1,
can_create_group: 1,
color_scheme_id: 1,
email: 1,
external: 1,
force_random_password: 1,
hide_no_password: 1,
hide_no_ssh_key: 1,
linkedin: 1,
name: 1,
password: 1,
password_automatically_set: 1,
password_expires_at: 1,
projects_limit: 1,
remember_me: 1,
skip_confirmation: 1,
skype: 1,
theme_id: 1,
twitter: 1,
username: 1,
website_url: 1,
private_profile: 1,
organization: 1,
location: 1,
public_email: 1,
user_type: 'project_bot',
note: 1,
view_diffs_file_by_file: 1
}
end
it 'sets all allowed attributes' do
expect(User).to receive(:new).with(hash_including(params)).and_call_original
service.execute
2020-04-22 19:07:51 +05:30
end
end
2018-11-20 20:47:30 +05:30
context 'with "user_default_external" application setting' do
where(:user_default_external, :external, :email, :user_default_internal_regex, :result) do
true | nil | 'fl@example.com' | nil | true
true | true | 'fl@example.com' | nil | true
2021-06-08 01:23:25 +05:30
true | false | 'fl@example.com' | nil | false # admin difference
2018-11-20 20:47:30 +05:30
true | nil | 'fl@example.com' | '' | true
true | true | 'fl@example.com' | '' | true
2021-06-08 01:23:25 +05:30
true | false | 'fl@example.com' | '' | false # admin difference
2018-11-20 20:47:30 +05:30
2019-02-15 15:39:39 +05:30
true | nil | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
2021-06-08 01:23:25 +05:30
true | true | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | true # admin difference
2019-02-15 15:39:39 +05:30
true | false | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
2018-11-20 20:47:30 +05:30
true | nil | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
true | true | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
2021-06-08 01:23:25 +05:30
true | false | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false # admin difference
2018-11-20 20:47:30 +05:30
false | nil | 'fl@example.com' | nil | false
2021-06-08 01:23:25 +05:30
false | true | 'fl@example.com' | nil | true # admin difference
2018-11-20 20:47:30 +05:30
false | false | 'fl@example.com' | nil | false
false | nil | 'fl@example.com' | '' | false
2021-06-08 01:23:25 +05:30
false | true | 'fl@example.com' | '' | true # admin difference
2018-11-20 20:47:30 +05:30
false | false | 'fl@example.com' | '' | false
false | nil | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
2021-06-08 01:23:25 +05:30
false | true | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | true # admin difference
2018-11-20 20:47:30 +05:30
false | false | 'fl@example.com' | '^(?:(?!\.ext@).)*$\r?' | false
false | nil | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
2021-06-08 01:23:25 +05:30
false | true | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true # admin difference
2018-11-20 20:47:30 +05:30
false | false | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
end
with_them do
before do
stub_application_setting(user_default_external: user_default_external)
stub_application_setting(user_default_internal_regex: user_default_internal_regex)
params.merge!({ external: external, email: email }.compact)
end
it 'sets the value of Gitlab::CurrentSettings.user_default_external' do
expect(user.external).to eq(result)
end
end
end
2017-08-17 22:00:37 +05:30
end
end
end