debian-mirror-gitlab/qa/spec/resource/user_spec.rb
2023-03-04 22:38:38 +05:30

169 lines
5.1 KiB
Ruby

# frozen_string_literal: true
RSpec.describe QA::Resource::User do
let(:api_resource) do
{
name: "GitLab QA",
username: "gitlab-qa",
web_url: "https://staging.gitlab.com/gitlab-qa",
public_email: "1614863-gitlab-qa@users.noreply.staging.gitlab.com"
}
end
describe '#username' do
it 'generates a default username' do
expect(subject.username).to match(/qa-user-\w+/)
end
it 'is possible to set the username' do
subject.username = 'johndoe'
expect(subject.username).to eq('johndoe')
end
end
describe '#password' do
it 'generates a default password' do
expect(subject.password).to match('Pa$$w0rd')
end
it 'is possible to set the password' do
new_password = "21c7a808"
subject.password = new_password
expect(subject.password).to eq(new_password)
end
end
describe '#name' do
it 'defaults to a name based on the username' do
expect(subject.name).to match(/#{subject.username.tr('-', ' ')}/i)
end
it 'retrieves the name from the api_resource if present' do
subject.__send__(:api_resource=, api_resource)
expect(subject.name).to eq(api_resource[:name])
end
it 'is possible to set the name' do
subject.name = 'John Doe'
expect(subject.name).to eq('John Doe')
end
end
describe '#email' do
it 'defaults to the <username>@example.com' do
expect(subject.email).to eq("#{subject.username}@example.com")
end
it 'is possible to set the email' do
subject.email = 'johndoe@example.org'
expect(subject.email).to eq('johndoe@example.org')
end
end
describe '#public_email' do
it 'defaults to QA::Runtime::User.default_email' do
expect(subject.public_email).to eq(QA::Runtime::User.default_email)
end
it 'retrieves the public_email from the api_resource if present' do
subject.__send__(:api_resource=, api_resource)
expect(subject.public_email).to eq(api_resource[:public_email])
end
it 'defaults to QA::Runtime::User.default_email if the public_email from the api_resource is blank' do
subject.__send__(:api_resource=, api_resource.merge(public_email: ''))
expect(subject.public_email).to eq(QA::Runtime::User.default_email)
end
end
describe '#credentials_given?' do
it 'returns false when username and email have not been overridden' do
expect(subject).not_to be_credentials_given
end
it 'returns false even after username and email have been called' do
# Call #username and #password to ensure this doesn't set their respective
# instance variable.
subject.username
subject.password
expect(subject).not_to be_credentials_given
end
it 'returns false if only the username has been overridden' do
subject.username = 'johndoe'
expect(subject).not_to be_credentials_given
end
it 'returns false if only the password has been overridden' do
subject.password = 'secret'
expect(subject).not_to be_credentials_given
end
it 'returns true if both the username and password have been overridden' do
subject.username = 'johndoe'
subject.password = 'secret'
expect(subject).to be_credentials_given
end
end
describe '#has_user?' do
let(:index_mock) do
instance_double(QA::Page::Admin::Overview::Users::Index)
end
users = [
['foo', true],
['bar', false]
]
users.each do |(username, found)|
it "returns #{found} when has_username returns #{found}" do
subject.username = username
allow(QA::Flow::Login).to receive(:while_signed_in_as_admin).and_yield
allow(QA::Page::Main::Menu).to receive(:perform)
allow(QA::Page::Admin::Menu).to receive(:perform)
allow(QA::Page::Admin::Overview::Users::Index).to receive(:perform).and_yield(index_mock)
expect(index_mock).to receive(:search_user).with(username)
expect(index_mock).to receive(:has_username?).with(username).and_return(found)
expect(subject.has_user?(subject)).to eq(found)
end
end
end
describe '#fabricate_or_use' do
# Signup Disabled, Personal Access Tokens disabled, method used, method that is not used
[
[true, false, :fabricate_via_api!, :fabricate!],
[false, false, :fabricate!, :fabricate_via_api!],
[false, true, :fabricate!, :fabricate_via_api!],
[true, true, :fabricate!, :fabricate_via_api!]
].each do |signup_disabled, personal_access_tokens_disabled, method_used, method_not_used|
it "when signup_disabled is #{signup_disabled}, "\
"personal_access_tokens_disabled is #{personal_access_tokens_disabled}, "\
"calls #{method_used}, does not call #{method_not_used}" do
allow(QA::Runtime::Env).to receive(:signup_disabled?).and_return(signup_disabled)
allow(QA::Runtime::Env).to receive(:personal_access_tokens_disabled?)
.and_return(personal_access_tokens_disabled)
expect(described_class).to receive(method_used)
expect(described_class).not_to receive(method_not_used)
described_class.fabricate_or_use
end
end
end
end