2019-01-21 11:24:56 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
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 eq('password')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'is possible to set the password' do
|
|
|
|
subject.password = 'secret'
|
|
|
|
|
|
|
|
expect(subject.password).to eq('secret')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#name' do
|
2019-10-15 11:06:07 -04:00
|
|
|
it 'defaults to a name based on the username' do
|
|
|
|
expect(subject.name).to match(/#{subject.username.tr('-', ' ')}/i)
|
2019-01-21 11:24:56 -05:00
|
|
|
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
|
|
|
|
end
|