Do not send notification email on EPP contact:update if contact does not

act as a registrant

Fixes #1161
This commit is contained in:
Artur Beljajev 2019-04-11 18:10:59 +03:00
parent 6a61d7de5b
commit 6fbadaf7f8
4 changed files with 62 additions and 3 deletions

View file

@ -50,7 +50,7 @@ class EppContactUpdateBaseTest < ActionDispatch::IntegrationTest
def test_notifies_contact_by_email_when_email_is_changed
assert_equal 'john-001', @contact.code
assert_not_equal 'new@inbox.test', @contact.email
assert_not_equal 'john-new@inbox.test', @contact.email
# https://github.com/internetee/registry/issues/415
@contact.update_columns(code: @contact.code.upcase)
@ -63,7 +63,7 @@ class EppContactUpdateBaseTest < ActionDispatch::IntegrationTest
<contact:update xmlns:contact="https://epp.tld.ee/schema/contact-ee-1.1.xsd">
<contact:id>john-001</contact:id>
<contact:chg>
<contact:email>new@inbox.test</contact:email>
<contact:email>john-new@inbox.test</contact:email>
</contact:chg>
</contact:update>
</update>
@ -104,6 +104,37 @@ class EppContactUpdateBaseTest < ActionDispatch::IntegrationTest
assert_no_emails
end
def test_skips_notifying_a_contact_when_a_contact_is_not_a_registrant
assert_equal 'john-001', @contact.code
assert_not_equal 'john-new@inbox.test', @contact.email
make_contact_free_of_domains_where_it_acts_as_a_registrant(@contact)
assert_not @contact.registrant?
# https://github.com/internetee/registry/issues/415
@contact.update_columns(code: @contact.code.upcase)
request_xml = <<-XML
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<epp xmlns="https://epp.tld.ee/schema/epp-ee-1.0.xsd">
<command>
<update>
<contact:update xmlns:contact="https://epp.tld.ee/schema/contact-ee-1.1.xsd">
<contact:id>john-001</contact:id>
<contact:chg>
<contact:email>john-new@inbox.test</contact:email>
</contact:chg>
</contact:update>
</update>
</command>
</epp>
XML
post '/epp/command/update', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames'
assert_no_emails
end
def test_non_existing_contact
assert_nil Contact.find_by(code: 'non-existing')
@ -130,4 +161,12 @@ class EppContactUpdateBaseTest < ActionDispatch::IntegrationTest
response_xml = Nokogiri::XML(response.body)
assert_equal '2303', response_xml.at_css('result')[:code]
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)
end
end