diff --git a/test/fixtures/billing/prices.yml b/test/fixtures/billing/prices.yml index 17e34d3f2..2237a72b4 100644 --- a/test/fixtures/billing/prices.yml +++ b/test/fixtures/billing/prices.yml @@ -4,7 +4,7 @@ create_one_month: operation_category: create valid_from: 2010-07-05 valid_to: 2010-07-05 - zone: test + zone: one renew_one_month: duration: 1 month @@ -12,15 +12,14 @@ renew_one_month: operation_category: renew valid_from: 2010-07-05 valid_to: 2010-07-05 - zone: test + zone: one create_one_year: duration: 1 year price_cents: 1000 operation_category: create valid_from: 2010-07-05 - valid_to: 2010-07-05 - zone: test + zone: one renew_one_year: duration: 1 year @@ -28,4 +27,4 @@ renew_one_year: operation_category: renew valid_from: 2010-07-05 valid_to: 2010-07-05 - zone: test + zone: one diff --git a/test/fixtures/blocked_domains.yml b/test/fixtures/blocked_domains.yml new file mode 100644 index 000000000..4bf0d0299 --- /dev/null +++ b/test/fixtures/blocked_domains.yml @@ -0,0 +1,2 @@ +one: + name: blocked.test diff --git a/test/fixtures/dns/zones.yml b/test/fixtures/dns/zones.yml index 40a8a289e..b826c9ef4 100644 --- a/test/fixtures/dns/zones.yml +++ b/test/fixtures/dns/zones.yml @@ -1,2 +1,4 @@ -test: +# https://github.com/rails/rails/issues/9516 requires this file to be under "dns" folder + +one: origin: test diff --git a/test/integration/epp/domain/check/base_test.rb b/test/integration/epp/domain/check/base_test.rb new file mode 100644 index 000000000..5d98b60ff --- /dev/null +++ b/test/integration/epp/domain/check/base_test.rb @@ -0,0 +1,135 @@ +require 'test_helper' + +class EppDomainCheckBaseTest < ApplicationIntegrationTest + def test_returns_valid_response + request_xml = <<-XML + + + + + + some.test + + + + + XML + + post '/epp/command/check', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal '1000', response_xml.at_css('result')[:code] + assert_equal 1, response_xml.css('result').size + assert_equal 'some.test', response_xml.at_xpath('//domain:name', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + end + + def test_domain_is_available_when_not_registered_blocked_nor_reserved + request_xml = <<-XML + + + + + + available.test + + + + + XML + + post '/epp/command/check', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal '1', response_xml.at_xpath('//domain:name', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd')['avail'] + assert_nil response_xml.at_xpath('//domain:reason', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd') + end + + def test_domain_is_unavailable_when_format_is_invalid + request_xml = <<-XML + + + + + + invalid + + + + + XML + + post '/epp/command/check', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal '0', response_xml.at_xpath('//domain:name', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd')['avail'] + assert_equal 'invalid format', response_xml.at_xpath('//domain:reason', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + end + + def test_domain_is_unavailable_when_registered + assert_equal 'shop.test', domains(:shop).name + + request_xml = <<-XML + + + + + + shop.test + + + + + XML + + post '/epp/command/check', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal '0', response_xml.at_xpath('//domain:name', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd')['avail'] + assert_equal 'in use', response_xml.at_xpath('//domain:reason', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + end + + def test_domain_is_unavailable_when_reserved + assert_equal 'reserved.test', reserved_domains(:one).name + + request_xml = <<-XML + + + + + + reserved.test + + + + + XML + + post '/epp/command/check', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal '0', response_xml.at_xpath('//domain:name', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd')['avail'] + assert_equal 'Domain name is reserved', response_xml.at_xpath('//domain:reason', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + end + + def test_multiple_domains + request_xml = <<-XML + + + + + + one.test + two.test + three.test + + + + + XML + + post '/epp/command/check', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal 3, response_xml.xpath('//domain:cd', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').size + end +end diff --git a/test/integration/epp/domain/create/base_test.rb b/test/integration/epp/domain/create/base_test.rb new file mode 100644 index 000000000..ff3a856df --- /dev/null +++ b/test/integration/epp/domain/create/base_test.rb @@ -0,0 +1,36 @@ +require 'test_helper' + +class EppDomainCreateBaseTest < ApplicationIntegrationTest + def test_domain_can_be_registered_with_required_attributes_only + request_xml = <<-XML + + + + + + new.test + john-001 + + + + + #{'test' * 2000} + + + + + XML + + assert_difference 'Domain.count' do + post '/epp/command/create', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + end + + domain = Domain.last + assert_equal 'new.test', domain.name + assert_equal contacts(:john).becomes(Registrant), domain.registrant + + response_xml = Nokogiri::XML(response.body) + assert_equal '1000', response_xml.at_css('result')[:code] + assert_equal 1, Nokogiri::XML(response.body).css('result').size + end +end diff --git a/test/integration/epp/domain/info/base_test.rb b/test/integration/epp/domain/info/base_test.rb new file mode 100644 index 000000000..a112ed840 --- /dev/null +++ b/test/integration/epp/domain/info/base_test.rb @@ -0,0 +1,109 @@ +require 'test_helper' + +class EppDomainInfoBaseTest < ApplicationIntegrationTest + def test_returns_valid_response + assert_equal 'john-001', contacts(:john).code + domains(:shop).update_columns(statuses: [DomainStatus::OK], + created_at: Time.zone.parse('2010-07-05'), + updated_at: Time.zone.parse('2010-07-06'), + valid_to: Time.zone.parse('2010-07-07')) + + request_xml = <<-XML + + + + + + shop.test + + + + + XML + + post '/epp/command/info', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal '1000', response_xml.at_css('result')[:code] + assert_equal 1, response_xml.css('result').size + assert_equal 'shop.test', response_xml.at_xpath('//domain:name', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + assert_equal 'ok', response_xml.at_xpath('//domain:status', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd')['s'] + assert_equal 'john-001', response_xml.at_xpath('//domain:registrant', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + assert_equal '2010-07-05T00:00:00+03:00', response_xml.at_xpath('//domain:crDate', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + assert_equal '2010-07-06T00:00:00+03:00', response_xml.at_xpath('//domain:upDate', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + assert_equal '2010-07-07T00:00:00+03:00', response_xml.at_xpath('//domain:exDate', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + end + + def test_reveals_transfer_code_when_domain_is_owned_by_current_user + assert_equal '65078d5', domains(:shop).transfer_code + + request_xml = <<-XML + + + + + + shop.test + + + + + XML + + post '/epp/command/info', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_bestnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal '65078d5', response_xml.at_xpath('//domain:authInfo/domain:pw', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + end + + # Transfer code is the only info we conceal from other registrars, hence a bit oddly-looking + # test name + def test_reveals_transfer_code_when_domain_is_not_owned_by_current_user_and_transfer_code_is_provided + assert_equal '65078d5', domains(:shop).transfer_code + + request_xml = <<-XML + + + + + + shop.test + + 65078d5 + + + + + + XML + + post '/epp/command/info', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_goodnames' + + response_xml = Nokogiri::XML(response.body) + assert_equal '65078d5', response_xml.at_xpath('//domain:authInfo/domain:pw', 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd').text + end + + def test_conceals_transfer_code_when_domain_is_not_owned_by_current_user + request_xml = <<-XML + + + + + + shop.test + + + + + + + + XML + + post '/epp/command/info', { frame: request_xml }, 'HTTP_COOKIE' => 'session=api_goodnames' + + response_xml = Nokogiri::XML(response.body) + assert_nil response_xml.at_xpath('//domain:authInfo/domain:pw', + 'domain' => 'https://epp.tld.ee/schema/domain-eis-1.0.xsd') + end +end