From d590b5d9375eaba621a8bce933179ca3c55bde79 Mon Sep 17 00:00:00 2001 From: Maciej Szlosarczyk Date: Mon, 1 Apr 2019 10:24:54 +0300 Subject: [PATCH] On status update, create WHOIS records for domains in auction Should fix sporadic errors we are seeing with the integration --- app/controllers/api/v1/auctions_controller.rb | 5 ++++- test/integration/api/v1/auctions/update_test.rb | 15 ++++++++++++++- 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/app/controllers/api/v1/auctions_controller.rb b/app/controllers/api/v1/auctions_controller.rb index 5d896e1af5..558b801364 100644 --- a/app/controllers/api/v1/auctions_controller.rb +++ b/app/controllers/api/v1/auctions_controller.rb @@ -52,7 +52,10 @@ def serializable_hash_for_update_action(auction) end def update_whois_from_auction(auction) - whois_record = Whois::Record.find_by!(name: auction.domain) + whois_record = Whois::Record.find_or_create_by(name: auction.domain) do |record| + record.body = {} + end + whois_record.update_from_auction(auction) end end diff --git a/test/integration/api/v1/auctions/update_test.rb b/test/integration/api/v1/auctions/update_test.rb index 262b11cdfc..64b3a92f56 100644 --- a/test/integration/api/v1/auctions/update_test.rb +++ b/test/integration/api/v1/auctions/update_test.rb @@ -98,6 +98,19 @@ def test_updates_whois assert_equal Time.zone.parse('2010-07-05 10:00'), @whois_record.updated_at end + def test_creates_whois_record_if_does_not_exist + travel_to Time.zone.parse('2010-07-05 10:00') + assert_equal 'auction.test', @auction.domain + @whois_record.delete + + patch api_v1_auction_path(@auction.uuid), { status: Auction.statuses[:payment_received] } + .to_json, 'Content-Type' => Mime::JSON.to_s + + new_whois_record = Whois::Record.find_by(name: @auction.domain) + assert_equal Time.zone.parse('2010-07-05 10:00'), new_whois_record.updated_at + assert_equal ['PendingRegistration'], new_whois_record.json['status'] + end + def test_inaccessible_when_ip_address_is_not_allowed ENV['auction_api_allowed_ips'] = '' @@ -113,4 +126,4 @@ def test_auction_not_found 'Content-Type' => Mime::JSON.to_s end end -end \ No newline at end of file +end