130c369aa7
Improve the Project factory to make `creator` defaults to `namespace.owner` See merge request !13412
78 lines
1.7 KiB
Ruby
78 lines
1.7 KiB
Ruby
FactoryGirl.define do
|
|
factory :user, aliases: [:author, :assignee, :recipient, :owner, :resource_owner] do
|
|
email { generate(:email) }
|
|
name { generate(:name) }
|
|
username { generate(:username) }
|
|
password "12345678"
|
|
confirmed_at { Time.now }
|
|
confirmation_token { nil }
|
|
can_create_group true
|
|
|
|
after(:stub) do |user|
|
|
user.notification_email = user.email
|
|
end
|
|
|
|
before(:create) do |user|
|
|
user.ensure_rss_token
|
|
end
|
|
|
|
trait :admin do
|
|
admin true
|
|
end
|
|
|
|
trait :blocked do
|
|
after(:build) { |user, _| user.block! }
|
|
end
|
|
|
|
trait :external do
|
|
external true
|
|
end
|
|
|
|
trait :two_factor do
|
|
two_factor_via_otp
|
|
end
|
|
|
|
trait :ghost do
|
|
ghost true
|
|
after(:build) { |user, _| user.block! }
|
|
end
|
|
|
|
trait :with_avatar do
|
|
avatar { File.open(Rails.root.join('spec/fixtures/dk.png')) }
|
|
end
|
|
|
|
trait :two_factor_via_otp do
|
|
before(:create) do |user|
|
|
user.otp_required_for_login = true
|
|
user.otp_secret = User.generate_otp_secret(32)
|
|
user.otp_grace_period_started_at = Time.now
|
|
user.generate_otp_backup_codes!
|
|
end
|
|
end
|
|
|
|
trait :two_factor_via_u2f do
|
|
transient { registrations_count 5 }
|
|
|
|
after(:create) do |user, evaluator|
|
|
create_list(:u2f_registration, evaluator.registrations_count, user: user)
|
|
end
|
|
end
|
|
|
|
factory :omniauth_user do
|
|
transient do
|
|
extern_uid '123456'
|
|
provider 'ldapmain'
|
|
end
|
|
|
|
after(:create) do |user, evaluator|
|
|
user.identities << create(
|
|
:identity,
|
|
provider: evaluator.provider,
|
|
extern_uid: evaluator.extern_uid
|
|
)
|
|
end
|
|
end
|
|
|
|
factory :admin, traits: [:admin]
|
|
end
|
|
end
|