mirror of
https://github.com/internetee/registry.git
synced 2025-07-21 10:16:01 +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)
|
||||
email_address_verification = run_condition(EmailAddressVerification.find(verification_id))
|
||||
|
||||
if email_address_verification.recently_verified?
|
||||
destroy
|
||||
return
|
||||
end
|
||||
|
||||
ActiveRecord::Base.transaction do
|
||||
email_address_verification.verify
|
||||
log_success(email_address_verification)
|
||||
|
@ -22,7 +27,7 @@ class VerifyEmailsJob < Que::Job
|
|||
end
|
||||
|
||||
def logger
|
||||
Rails.logger = Logger.new(STDOUT)
|
||||
Rails.logger
|
||||
end
|
||||
|
||||
def log_success(verification)
|
||||
|
|
8
test/fixtures/contacts.yml
vendored
8
test/fixtures/contacts.yml
vendored
|
@ -85,3 +85,11 @@ invalid:
|
|||
auth_info: any
|
||||
registrar: bestnames
|
||||
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