mirror of
https://github.com/discourse/discourse.git
synced 2024-11-30 19:15:32 +08:00
427d54b2b0
Zeitwerk simplifies working with dependencies in dev and makes it easier reloading class chains. We no longer need to use Rails "require_dependency" anywhere and instead can just use standard Ruby patterns to require files. This is a far reaching change and we expect some followups here.
66 lines
2.3 KiB
Ruby
66 lines
2.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
describe Jobs::InvalidateInactiveAdmins do
|
|
fab!(:active_admin) { Fabricate(:admin, last_seen_at: 1.hour.ago) }
|
|
before { active_admin.email_tokens.update_all(confirmed: true) }
|
|
|
|
subject { Jobs::InvalidateInactiveAdmins.new.execute({}) }
|
|
|
|
it "does nothing when all admins have been seen recently" do
|
|
SiteSetting.invalidate_inactive_admin_email_after_days = 365
|
|
subject
|
|
expect(active_admin.reload.active).to eq(true)
|
|
expect(active_admin.email_tokens.where(confirmed: true).exists?).to eq(true)
|
|
end
|
|
|
|
context "with an admin who hasn't been seen recently" do
|
|
fab!(:not_seen_admin) { Fabricate(:admin, last_seen_at: 370.days.ago) }
|
|
before { not_seen_admin.email_tokens.update_all(confirmed: true) }
|
|
|
|
context 'invalidate_inactive_admin_email_after_days = 365' do
|
|
before do
|
|
SiteSetting.invalidate_inactive_admin_email_after_days = 365
|
|
end
|
|
|
|
it 'marks email tokens as unconfirmed' do
|
|
subject
|
|
expect(not_seen_admin.reload.email_tokens.where(confirmed: true).exists?).to eq(false)
|
|
end
|
|
|
|
it 'makes the user as not active' do
|
|
subject
|
|
expect(not_seen_admin.reload.active).to eq(false)
|
|
end
|
|
|
|
context 'with social logins' do
|
|
before do
|
|
GithubUserInfo.create!(user_id: not_seen_admin.id, screen_name: 'bob', github_user_id: 100)
|
|
UserAssociatedAccount.create!(provider_name: "google_oauth2", user_id: not_seen_admin.id, provider_uid: 100, info: { email: "bob@google.account.com" })
|
|
end
|
|
|
|
it 'removes the social logins' do
|
|
subject
|
|
expect(GithubUserInfo.where(user_id: not_seen_admin.id).exists?).to eq(false)
|
|
expect(UserAssociatedAccount.where(user_id: not_seen_admin.id).exists?).to eq(false)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'invalidate_inactive_admin_email_after_days = 0 to disable this feature' do
|
|
before do
|
|
SiteSetting.invalidate_inactive_admin_email_after_days = 0
|
|
end
|
|
|
|
it 'does nothing' do
|
|
subject
|
|
expect(active_admin.reload.active).to eq(true)
|
|
expect(active_admin.email_tokens.where(confirmed: true).exists?).to eq(true)
|
|
expect(not_seen_admin.reload.active).to eq(true)
|
|
expect(not_seen_admin.email_tokens.where(confirmed: true).exists?).to eq(true)
|
|
end
|
|
end
|
|
end
|
|
end
|