mirror of
https://github.com/internetee/registry.git
synced 2025-06-05 12:17:30 +02:00
363 lines
10 KiB
Ruby
363 lines
10 KiB
Ruby
require 'test_helper'
|
||
|
||
class ContactTest < ActiveJob::TestCase
|
||
setup do
|
||
@contact = contacts(:john)
|
||
@old_validation_type = Truemail.configure.default_validation_type
|
||
end
|
||
|
||
teardown do
|
||
Truemail.configure.default_validation_type = @old_validation_type
|
||
end
|
||
|
||
def test_valid_contact_fixture_is_valid
|
||
assert valid_contact.valid?, proc { valid_contact.errors.full_messages }
|
||
end
|
||
|
||
def test_invalid_fixture_is_invalid
|
||
assert contacts(:invalid).invalid?
|
||
end
|
||
|
||
def test_private_entity
|
||
assert_equal 'priv', Contact::PRIV
|
||
end
|
||
|
||
def test_legal_entity
|
||
assert_equal 'org', Contact::ORG
|
||
end
|
||
|
||
def test_invalid_without_name
|
||
contact = valid_contact
|
||
contact.name = ''
|
||
assert contact.invalid?
|
||
end
|
||
|
||
def test_allowed_and_disallowed_symbols_for_name
|
||
contact = valid_contact
|
||
contact.name = 'MARY ÄNN O’CONNEŽ-ŠUSLIK'
|
||
assert contact.valid?
|
||
contact.name = 'Boğaçhan Çağlayan'
|
||
assert contact.valid?
|
||
contact.name = '# "¤ #" ¤ "?'
|
||
assert contact.invalid?
|
||
|
||
contact.country_code = 'FI'
|
||
contact.ident_type = Contact::ORG
|
||
contact.ident = '1234'
|
||
assert contact.valid?
|
||
end
|
||
|
||
def test_validates_code_format
|
||
contact = valid_contact.dup
|
||
max_length = 100
|
||
|
||
contact.code = '!invalid'
|
||
assert contact.invalid?
|
||
|
||
contact.code = 'a' * max_length.next
|
||
assert contact.invalid?
|
||
|
||
contact.code = 'foo:bar'
|
||
assert contact.valid?
|
||
|
||
contact.code = 'a' * max_length
|
||
assert contact.valid?
|
||
end
|
||
|
||
def test_invalid_when_code_is_already_taken
|
||
another_contact = valid_contact
|
||
contact = another_contact.dup
|
||
|
||
contact.code = another_contact.code
|
||
assert contact.invalid?
|
||
|
||
contact.regenerate_code
|
||
assert contact.valid?
|
||
end
|
||
|
||
def test_invalid_without_email
|
||
contact = valid_contact
|
||
contact.email = ''
|
||
assert contact.invalid?
|
||
end
|
||
|
||
def test_email_verification_valid
|
||
contact = valid_contact
|
||
contact.email = 'info@internet.ee'
|
||
assert contact.valid?
|
||
end
|
||
|
||
def test_email_verification_regex_error
|
||
Truemail.configure.default_validation_type = :regex
|
||
|
||
contact = valid_contact
|
||
contact.email = '`@internet.ee'
|
||
assert contact.invalid?
|
||
assert_equal I18n.t('activerecord.errors.models.contact.attributes.email.email_regex_check_error'), contact.errors.messages[:email].first
|
||
end
|
||
|
||
def test_invalid_without_phone
|
||
contact = valid_contact
|
||
contact.phone = ''
|
||
assert contact.invalid?
|
||
end
|
||
|
||
# https://en.wikipedia.org/wiki/E.164
|
||
def test_validates_phone_format
|
||
contact = valid_contact
|
||
|
||
contact.phone = '+.1'
|
||
assert contact.invalid?
|
||
|
||
contact.phone = '+123.'
|
||
assert contact.invalid?
|
||
|
||
contact.phone = '+1.123456789123456'
|
||
assert contact.invalid?
|
||
|
||
contact.phone = '+134.1234567891234'
|
||
assert contact.invalid?
|
||
|
||
contact.phone = '+000.1'
|
||
assert contact.invalid?
|
||
|
||
contact.phone = '+123.0'
|
||
assert contact.invalid?
|
||
|
||
contact.phone = '+1.2'
|
||
assert contact.valid?
|
||
|
||
contact.phone = '+123.4'
|
||
assert contact.valid?
|
||
|
||
contact.phone = '+1.12345678912345'
|
||
assert contact.valid?
|
||
|
||
contact.phone = '+134.123456789123'
|
||
assert contact.valid?
|
||
end
|
||
|
||
def test_valid_without_address_when_address_processing_id_disabled
|
||
contact = valid_contact
|
||
|
||
contact.street = ''
|
||
contact.city = ''
|
||
contact.zip = ''
|
||
contact.country_code = ''
|
||
|
||
assert contact.valid?
|
||
end
|
||
|
||
def test_address
|
||
Setting.address_processing = true
|
||
|
||
address = Contact::Address.new('new street', '83746', 'new city', 'new state', 'EE')
|
||
@contact.address = address
|
||
@contact.save!
|
||
@contact.reload
|
||
|
||
assert_equal 'new street', @contact.street
|
||
assert_equal '83746', @contact.zip
|
||
assert_equal 'new city', @contact.city
|
||
assert_equal 'new state', @contact.state
|
||
assert_equal 'EE', @contact.country_code
|
||
assert_equal address, @contact.address
|
||
end
|
||
|
||
def test_returns_registrant_user_direct_contacts
|
||
assert_equal Contact::PRIV, @contact.ident_type
|
||
assert_equal '1234', @contact.ident
|
||
assert_equal 'US', @contact.ident_country_code
|
||
registrant_user = RegistrantUser.new(registrant_ident: 'US-1234')
|
||
|
||
registrant_user.stub(:companies, []) do
|
||
assert_equal [@contact], Contact.registrant_user_contacts(registrant_user)
|
||
assert_equal [@contact], Contact.registrant_user_direct_contacts(registrant_user)
|
||
end
|
||
end
|
||
|
||
def test_returns_registrant_user_indirect_contacts
|
||
@contact.update!(ident_type: Contact::ORG, ident: '1234321')
|
||
assert_equal 'US', @contact.ident_country_code
|
||
registrant_user = RegistrantUser.new(registrant_ident: 'US-1234321')
|
||
|
||
registrant_user.stub(:companies, [OpenStruct.new(registration_number: '1234321')]) do
|
||
assert_equal registrant_user.contacts, Contact.registrant_user_contacts(registrant_user)
|
||
end
|
||
end
|
||
|
||
def test_contact_is_a_registrant
|
||
assert_equal @contact.becomes(Registrant), domains(:shop).registrant
|
||
assert @contact.registrant?
|
||
|
||
make_contact_free_of_domains_where_it_acts_as_a_registrant(@contact)
|
||
assert_not @contact.registrant?
|
||
end
|
||
|
||
def test_linked_when_in_use_as_registrant
|
||
Domain.update_all(registrant_id: @contact.id)
|
||
DomainContact.delete_all
|
||
|
||
assert @contact.linked?
|
||
end
|
||
|
||
def test_linked_when_in_use_as_domain_contact
|
||
Domain.update_all(registrant_id: contacts(:william).id)
|
||
DomainContact.first.update(contact_id: @contact.id)
|
||
|
||
assert @contact.linked?
|
||
end
|
||
|
||
def test_unlinked_when_not_in_use_as_either_registrant_or_domain_contact
|
||
contact = unlinked_contact
|
||
assert_not contact.linked?
|
||
end
|
||
|
||
def test_managed_when_identity_codes_match
|
||
contact = Contact.new(ident: '1234')
|
||
user = RegistrantUser.new(registrant_ident: 'US-1234')
|
||
assert contact.managed_by?(user)
|
||
end
|
||
|
||
def test_unmanaged_when_identity_codes_do_not_match
|
||
contact = Contact.new(ident: '1234')
|
||
user = RegistrantUser.new(registrant_ident: 'US-12345')
|
||
assert_not contact.managed_by?(user)
|
||
end
|
||
|
||
def test_deletable_when_not_linked
|
||
contact = unlinked_contact
|
||
assert contact.deletable?
|
||
end
|
||
|
||
def test_undeletable_when_linked
|
||
assert @contact.linked?
|
||
assert_not @contact.deletable?
|
||
end
|
||
|
||
def test_linked_scope_returns_contact_that_acts_as_registrant
|
||
domains(:shop).update!(registrant: @contact.becomes(Registrant))
|
||
assert Contact.linked.include?(@contact), 'Contact should be included'
|
||
end
|
||
|
||
def test_linked_scope_returns_contact_that_acts_as_admin_contact
|
||
domains(:shop).admin_contacts = [@contact]
|
||
assert Contact.linked.include?(@contact), 'Contact should be included'
|
||
end
|
||
|
||
def test_linked_scope_returns_contact_that_acts_as_tech_contact
|
||
domains(:shop).tech_contacts = [@contact]
|
||
assert Contact.linked.include?(@contact), 'Contact should be included'
|
||
end
|
||
|
||
def test_linked_scope_skips_unlinked_contact
|
||
contact = unlinked_contact
|
||
assert_not Contact.linked.include?(contact), 'Contact should be excluded'
|
||
end
|
||
|
||
def test_unlinked_scope_returns_unlinked_contact
|
||
contact = unlinked_contact
|
||
assert Contact.unlinked.include?(contact), 'Contact should be included'
|
||
end
|
||
|
||
def test_unlinked_scope_skips_contact_that_is_linked_as_registrant
|
||
contact = unlinked_contact
|
||
domains(:shop).update_columns(registrant_id: contact.becomes(Registrant).id)
|
||
|
||
assert Contact.unlinked.exclude?(contact), 'Contact should be excluded'
|
||
end
|
||
|
||
def test_unlinked_scope_skips_contact_that_is_linked_as_admin_contact
|
||
contact = unlinked_contact
|
||
domains(:shop).admin_contacts = [contact]
|
||
|
||
assert Contact.unlinked.exclude?(contact), 'Contact should be excluded'
|
||
end
|
||
|
||
def test_unlinked_scope_skips_contact_that_is_linked_as_tech_contact
|
||
contact = unlinked_contact
|
||
domains(:shop).tech_contacts = [contact]
|
||
|
||
assert Contact.unlinked.exclude?(contact), 'Contact should be excluded'
|
||
end
|
||
|
||
def test_normalizes_country_code
|
||
Setting.address_processing = true
|
||
contact = Contact.new(country_code: 'us')
|
||
contact.validate
|
||
assert_equal 'US', contact.country_code
|
||
end
|
||
|
||
def test_linked_scope_returns_contact_that_acts_as_admin_contact
|
||
domains(:shop).admin_contacts = [@contact]
|
||
assert Contact.linked.include?(@contact), 'Contact should be included'
|
||
end
|
||
|
||
def test_linked_scope_returns_contact_that_acts_as_tech_contact
|
||
domains(:shop).tech_contacts = [@contact]
|
||
assert Contact.linked.include?(@contact), 'Contact should be included'
|
||
end
|
||
|
||
def test_linked_scope_skips_unlinked_contact
|
||
contact = unlinked_contact
|
||
assert_not Contact.linked.include?(contact), 'Contact should be excluded'
|
||
end
|
||
|
||
def test_unlinked_scope_returns_unlinked_contact
|
||
contact = unlinked_contact
|
||
assert Contact.unlinked.include?(contact), 'Contact should be included'
|
||
end
|
||
|
||
def test_unlinked_scope_skips_contact_that_is_linked_as_registrant
|
||
contact = unlinked_contact
|
||
domains(:shop).update_columns(registrant_id: contact.becomes(Registrant).id)
|
||
|
||
assert Contact.unlinked.exclude?(contact), 'Contact should be excluded'
|
||
end
|
||
|
||
def test_unlinked_scope_skips_contact_that_is_linked_as_admin_contact
|
||
contact = unlinked_contact
|
||
domains(:shop).admin_contacts = [contact]
|
||
|
||
assert Contact.unlinked.exclude?(contact), 'Contact should be excluded'
|
||
end
|
||
|
||
def test_unlinked_scope_skips_contact_that_is_linked_as_tech_contact
|
||
contact = unlinked_contact
|
||
domains(:shop).tech_contacts = [contact]
|
||
|
||
assert Contact.unlinked.exclude?(contact), 'Contact should be excluded'
|
||
end
|
||
|
||
def test_whois_gets_updated_after_contact_save
|
||
@contact.name = 'SomeReallyWeirdRandomTestName'
|
||
domain = @contact.registrant_domains.first
|
||
|
||
perform_enqueued_jobs do
|
||
@contact.save!
|
||
end
|
||
|
||
assert_equal domain.whois_record.try(:json).try(:[], 'registrant'), @contact.name
|
||
end
|
||
|
||
private
|
||
|
||
def make_contact_free_of_domains_where_it_acts_as_a_registrant(contact)
|
||
other_contact = contacts(:william)
|
||
assert_not_equal other_contact, contact
|
||
Domain.update_all(registrant_id: other_contact.id)
|
||
end
|
||
|
||
def unlinked_contact
|
||
other_contact = contacts(:william)
|
||
assert_not_equal @contact, other_contact
|
||
Domain.update_all(registrant_id: other_contact.id)
|
||
DomainContact.delete_all
|
||
|
||
@contact
|
||
end
|
||
|
||
def valid_contact
|
||
contacts(:john)
|
||
end
|
||
end
|