mirror of
https://github.com/internetee/registry.git
synced 2025-07-21 18:26:06 +02:00
Add test for email verification job
This commit is contained in:
parent
62acd8892a
commit
438a2e05ab
3 changed files with 73 additions and 1 deletions
|
@ -2,6 +2,11 @@ class VerifyEmailsJob < Que::Job
|
||||||
def run(verification_id)
|
def run(verification_id)
|
||||||
email_address_verification = run_condition(EmailAddressVerification.find(verification_id))
|
email_address_verification = run_condition(EmailAddressVerification.find(verification_id))
|
||||||
|
|
||||||
|
if email_address_verification.recently_verified?
|
||||||
|
destroy
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
ActiveRecord::Base.transaction do
|
ActiveRecord::Base.transaction do
|
||||||
email_address_verification.verify
|
email_address_verification.verify
|
||||||
log_success(email_address_verification)
|
log_success(email_address_verification)
|
||||||
|
@ -22,7 +27,7 @@ class VerifyEmailsJob < Que::Job
|
||||||
end
|
end
|
||||||
|
|
||||||
def logger
|
def logger
|
||||||
Rails.logger = Logger.new(STDOUT)
|
Rails.logger
|
||||||
end
|
end
|
||||||
|
|
||||||
def log_success(verification)
|
def log_success(verification)
|
||||||
|
|
8
test/fixtures/contacts.yml
vendored
8
test/fixtures/contacts.yml
vendored
|
@ -85,3 +85,11 @@ invalid:
|
||||||
auth_info: any
|
auth_info: any
|
||||||
registrar: bestnames
|
registrar: bestnames
|
||||||
uuid: bd80c0f9-26ee-49e0-a2cb-2311d931c433
|
uuid: bd80c0f9-26ee-49e0-a2cb-2311d931c433
|
||||||
|
|
||||||
|
invalid_email:
|
||||||
|
name: any
|
||||||
|
code: invalid_email
|
||||||
|
email: invalid@invalid.
|
||||||
|
auth_info: any
|
||||||
|
registrar: bestnames
|
||||||
|
uuid: fa8c4f51-a221-4628-b3c6-47995f4edea3
|
||||||
|
|
59
test/jobs/verify_emails_job_test.rb
Normal file
59
test/jobs/verify_emails_job_test.rb
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
require "test_helper"
|
||||||
|
|
||||||
|
class VerifyEmailsJobTest < ActiveSupport::TestCase
|
||||||
|
def setup
|
||||||
|
@contact = contacts(:john)
|
||||||
|
@invalid_contact = contacts(:invalid_email)
|
||||||
|
@contact_verification = @contact.email_verification
|
||||||
|
@invalid_contact_verification = @invalid_contact.email_verification
|
||||||
|
|
||||||
|
@default_whitelist = Truemail.configure.whitelisted_domains
|
||||||
|
@default_blacklist = Truemail.configure.blacklisted_domains
|
||||||
|
Truemail.configure.whitelisted_domains = whitelisted_domains
|
||||||
|
Truemail.configure.blacklisted_domains = blacklisted_domains
|
||||||
|
end
|
||||||
|
|
||||||
|
def teardown
|
||||||
|
Truemail.configure.whitelisted_domains = @default_whitelist
|
||||||
|
Truemail.configure.blacklisted_domains = @default_blacklist
|
||||||
|
end
|
||||||
|
|
||||||
|
def domain(email)
|
||||||
|
Mail::Address.new(email).domain
|
||||||
|
rescue Mail::Field::IncompleteParseError
|
||||||
|
nil
|
||||||
|
end
|
||||||
|
|
||||||
|
def whitelisted_domains
|
||||||
|
[domain(@contact.email)].reject(&:blank?)
|
||||||
|
end
|
||||||
|
|
||||||
|
def blacklisted_domains
|
||||||
|
[domain(@invalid_contact.email)].reject(&:blank?)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_job_checks_if_email_valid
|
||||||
|
VerifyEmailsJob.run(@contact_verification.id)
|
||||||
|
@contact_verification.reload
|
||||||
|
|
||||||
|
assert @contact_verification.success
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_job_checks_does_not_run_if_recent
|
||||||
|
old_verified_at = Time.zone.now - 10.days
|
||||||
|
@contact_verification.update(success: true, verified_at: old_verified_at)
|
||||||
|
assert @contact_verification.recently_verified?
|
||||||
|
|
||||||
|
VerifyEmailsJob.run(@contact_verification.id)
|
||||||
|
@contact_verification.reload
|
||||||
|
|
||||||
|
assert_in_delta @contact_verification.verified_at.to_i, old_verified_at.to_i, 1
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_job_checks_if_email_invalid
|
||||||
|
VerifyEmailsJob.run(@invalid_contact_verification.id)
|
||||||
|
@contact_verification.reload
|
||||||
|
|
||||||
|
refute @contact_verification.success
|
||||||
|
end
|
||||||
|
end
|
Loading…
Add table
Add a link
Reference in a new issue