require 'test_helper' class ReppV1DomainsContactsTest < ActionDispatch::IntegrationTest def setup @user = users(:api_bestnames) @domain = domains(:shop) token = Base64.encode64("#{@user.username}:#{@user.plain_text_password}") token = "Basic #{token}" @auth_headers = { 'Authorization' => token } adapter = ENV["shunter_default_adapter"].constantize.new adapter&.clear! end def test_shows_existing_domain_contacts get "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers json = JSON.parse(response.body, symbolize_names: true) assert_response :ok assert_equal 1000, json[:code] assert_equal 'Command completed successfully', json[:message] assert_equal @domain.admin_contacts.length, json[:data][:admin_contacts].length assert_equal @domain.tech_contacts.length, json[:data][:tech_contacts].length end def test_returns_error_response_if_throttled ENV["shunter_default_threshold"] = '1' ENV["shunter_enabled"] = 'true' get "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers get "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers json = JSON.parse(response.body, symbolize_names: true) assert_response :bad_request assert_equal json[:code], 2502 assert response.body.include?(Shunter.default_error_message) ENV["shunter_default_threshold"] = '10000' ENV["shunter_enabled"] = 'false' end def test_can_add_new_admin_contacts new_contact = contacts(:john) refute @domain.admin_contacts.find_by(code: new_contact.code).present? payload = { contacts: [ { code: new_contact.code, type: 'admin' } ] } post "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :ok assert_equal 1000, json[:code] assert @domain.admin_contacts.find_by(code: new_contact.code).present? end def test_can_add_new_tech_contacts new_contact = contacts(:john) refute @domain.tech_contacts.find_by(code: new_contact.code).present? payload = { contacts: [ { code: new_contact.code, type: 'tech' } ] } post "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :ok assert_equal 1000, json[:code] @domain.reload assert @domain.tech_contacts.find_by(code: new_contact.code).present? end def test_can_remove_admin_contacts Spy.on_instance_method(Actions::DomainUpdate, :validate_email).and_return(true) contact = contacts(:john) payload = { contacts: [ { code: contact.code, type: 'admin' } ] } post "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload assert @domain.admin_contacts.find_by(code: contact.code).present? # Actually delete the contact delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :ok assert_equal 1000, json[:code] refute @domain.admin_contacts.find_by(code: contact.code).present? end def test_can_remove_tech_contacts Spy.on_instance_method(Actions::DomainUpdate, :validate_email).and_return(true) contact = contacts(:john) payload = { contacts: [ { code: contact.code, type: 'tech' } ] } post "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload assert @domain.tech_contacts.find_by(code: contact.code).present? # Actually delete the contact delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) @domain.reload contact.reload assert_response :ok assert_equal 1000, json[:code] refute @domain.tech_contacts.find_by(code: contact.code).present? end def test_can_remove_all_admin_contacts_for_private_registrant Spy.on_instance_method(Actions::DomainUpdate, :validate_email).and_return(true) @domain.registrant.update!(ident_type: 'priv') @domain.reload assert_not @domain.registrant.org? contact = @domain.admin_contacts.last payload = { contacts: [ { code: contact.code, type: 'admin' } ] } delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) @domain.reload assert_response :ok assert_equal 1000, json[:code] assert_empty @domain.admin_contacts end def test_can_not_remove_one_and_only_contact Spy.on_instance_method(Actions::DomainUpdate, :validate_email).and_return(true) @domain.registrant.update!(ident_type: 'org') @domain.reload contact = @domain.admin_contacts.last payload = { contacts: [ { code: contact.code, type: 'admin' } ] } delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) @domain.reload assert_response :bad_request assert_equal 2306, json[:code] assert @domain.admin_contacts.any? end def test_cannot_remove_admin_contact_for_legal_entity @domain.registrant.update!(ident_type: 'org') @domain.reload assert @domain.registrant.org? contact = @domain.admin_contacts.last payload = { contacts: [ { code: contact.code, type: 'admin' } ] } delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :bad_request assert_equal 2306, json[:code] assert @domain.admin_contacts.any? end def test_cannot_remove_admin_contact_for_underage_private_registrant @domain.registrant.update!( ident_type: 'birthday', ident: (Time.zone.now - 16.years).strftime('%Y-%m-%d') ) @domain.reload assert @domain.registrant.priv? contact = @domain.admin_contacts.last payload = { contacts: [ { code: contact.code, type: 'admin' } ] } delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :bad_request assert_equal 2306, json[:code] assert @domain.admin_contacts.any? end def test_can_remove_admin_contact_for_adult_private_registrant @domain.registrant.update!( ident_type: 'birthday', ident: (Time.zone.now - 20.years).strftime('%Y-%m-%d') ) @domain.reload assert @domain.registrant.priv? contact = @domain.admin_contacts.last payload = { contacts: [ { code: contact.code, type: 'admin' } ] } delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :ok assert_equal 1000, json[:code] assert_empty @domain.admin_contacts end def test_cannot_remove_admin_contact_for_underage_estonian_id @domain.registrant.update!( ident_type: 'priv', ident: '61203150222', ident_country_code: 'EE' ) @domain.reload assert @domain.registrant.priv? contact = @domain.admin_contacts.last payload = { contacts: [ { code: contact.code, type: 'admin' } ] } delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :bad_request assert_equal 2306, json[:code] assert @domain.admin_contacts.any? end def test_can_remove_admin_contact_for_adult_estonian_id @domain.registrant.update!( ident_type: 'priv', ident: '38903111310', ident_country_code: 'EE' ) @domain.reload assert @domain.registrant.priv? contact = @domain.admin_contacts.last payload = { contacts: [ { code: contact.code, type: 'admin' } ] } delete "/repp/v1/domains/#{@domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :ok assert_equal 1000, json[:code] assert_empty @domain.admin_contacts end def test_updates_add_duplicate_admin_contact domain = domains(:shop) duplicate_contact = Contact.create!( name: 'Partial Duplicate Test', code: 'duplicate-006', email: 'partial-duplicate@test.com', phone: '+123.6789012', ident: '12349X', ident_type: 'priv', ident_country_code: 'US', registrar: registrars(:bestnames) ) registrant = duplicate_contact.becomes(Registrant) new_admin = Contact.create!( name: duplicate_contact.name, code: 'duplicate-admin-006', email: duplicate_contact.email, phone: duplicate_contact.phone, ident: duplicate_contact.ident, ident_type: 'priv', ident_country_code: duplicate_contact.ident_country_code, registrar: registrars(:bestnames) ) domain.update(registrant: registrant) && domain.reload old_admin = domain.admin_contacts.first assert_includes domain.admin_contacts, old_admin payload = { contacts: [ { code: new_admin.code, type: 'admin' } ] } post "/repp/v1/domains/#{domain.name}/contacts", headers: @auth_headers, params: payload json = JSON.parse(response.body, symbolize_names: true) assert_response :ok assert_equal 1000, json[:code] domain.reload assert domain.admin_contacts.find_by(code: new_admin.code).present? end end