mirror of
https://github.com/internetee/registry.git
synced 2025-07-24 19:48:28 +02:00
Create tests for REPP bulk renew, fix lingvistic issues with errors
This commit is contained in:
parent
240da481e5
commit
66114aa648
4 changed files with 106 additions and 12 deletions
|
@ -2,26 +2,40 @@ module Repp
|
||||||
module V1
|
module V1
|
||||||
module Domains
|
module Domains
|
||||||
class RenewsController < BaseController
|
class RenewsController < BaseController
|
||||||
|
before_action :validate_renew_period, only: [:bulk_renew]
|
||||||
|
before_action :select_renewable_domains, only: [:bulk_renew]
|
||||||
|
|
||||||
def bulk_renew
|
def bulk_renew
|
||||||
|
renew = run_bulk_renew_task(@domains, bulk_renew_params[:renew_period])
|
||||||
|
return render_success(data: { updated_domains: @domains.map(&:name) }) if renew.valid?
|
||||||
|
|
||||||
|
@epp_errors << { code: 2304,
|
||||||
|
msg: renew.errors.keys.map { |k, _v| renew.errors[k] }.join(',') }
|
||||||
|
handle_errors
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def validate_renew_period
|
||||||
|
@epp_errors ||= []
|
||||||
|
periods = Depp::Domain::PERIODS.map { |p| p[1] }
|
||||||
|
return if periods.include? bulk_renew_params[:renew_period]
|
||||||
|
|
||||||
|
@epp_errors << { code: 2005, msg: "Invalid renew period" }
|
||||||
|
end
|
||||||
|
|
||||||
|
def select_renewable_domains
|
||||||
@epp_errors ||= []
|
@epp_errors ||= []
|
||||||
|
|
||||||
if bulk_renew_params[:domains].instance_of?(Array)
|
if bulk_renew_params[:domains].instance_of?(Array)
|
||||||
domains = bulk_renew_domains
|
@domains = bulk_renew_domains
|
||||||
else
|
else
|
||||||
@epp_errors << { code: 2005, msg: 'Domains attribute must be an array' }
|
@epp_errors << { code: 2005, msg: 'Domains attribute must be an array' }
|
||||||
end
|
end
|
||||||
|
|
||||||
return handle_errors if @epp_errors.any?
|
return handle_errors if @epp_errors.any?
|
||||||
|
|
||||||
renew = run_bulk_renew_task(domains, bulk_renew_params[:renew_period])
|
|
||||||
return render_success(data: { updated_domains: domains.map(&:name) }) if renew.valid?
|
|
||||||
|
|
||||||
@epp_errors << { code: 2304, msg: renew.errors.full_messages.join(',') }
|
|
||||||
handle_errors
|
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def run_bulk_renew_task(domains, period)
|
def run_bulk_renew_task(domains, period)
|
||||||
::Domains::BulkRenew::Start.run(domains: domains, period_element: period,
|
::Domains::BulkRenew::Start.run(domains: domains, period_element: period,
|
||||||
registrar: current_user.registrar)
|
registrar: current_user.registrar)
|
||||||
|
@ -38,7 +52,7 @@ module Repp
|
||||||
@epp_errors ||= []
|
@epp_errors ||= []
|
||||||
domains = []
|
domains = []
|
||||||
bulk_renew_params[:domains].each do |idn|
|
bulk_renew_params[:domains].each do |idn|
|
||||||
domain = Epp::Domain.find_by_idn(idn)
|
domain = Epp::Domain.find_by(name: idn)
|
||||||
domains << domain if domain
|
domains << domain if domain
|
||||||
@epp_errors << { code: 2304, msg: "Object does not exist: #{idn}" } unless domain
|
@epp_errors << { code: 2304, msg: "Object does not exist: #{idn}" } unless domain
|
||||||
end
|
end
|
||||||
|
|
|
@ -41,7 +41,7 @@ module Domains
|
||||||
end
|
end
|
||||||
|
|
||||||
def manage_errors(task)
|
def manage_errors(task)
|
||||||
errors.merge!(task.errors) unless task.valid?
|
task.errors.each { |k, v| errors.add(k, v) } unless task.valid?
|
||||||
errors.add(:domain, I18n.t('not_enough_funds')) unless task.result
|
errors.add(:domain, I18n.t('not_enough_funds')) unless task.result
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ module Depp
|
||||||
token = Base64.urlsafe_encode64("#{registrar.username}:#{registrar.plain_text_password}")
|
token = Base64.urlsafe_encode64("#{registrar.username}:#{registrar.plain_text_password}")
|
||||||
headers = { Authorization: "Basic #{token}" }
|
headers = { Authorization: "Basic #{token}" }
|
||||||
|
|
||||||
RestClient.post("#{ENV['repp_url']}domains/renew/bulk", payload, headers).response
|
RestClient.post("http://localhost:3000/repp/v1/domains/renew/bulk", payload, headers)
|
||||||
rescue RestClient::ExceptionWithResponse => e
|
rescue RestClient::ExceptionWithResponse => e
|
||||||
e.response
|
e.response
|
||||||
end
|
end
|
||||||
|
|
80
test/integration/repp/v1/domains/bulk_renew_test.rb
Normal file
80
test/integration/repp/v1/domains/bulk_renew_test.rb
Normal file
|
@ -0,0 +1,80 @@
|
||||||
|
require 'test_helper'
|
||||||
|
|
||||||
|
class ReppV1DomainsBulkRenewTest < ActionDispatch::IntegrationTest
|
||||||
|
def setup
|
||||||
|
travel_to Time.zone.parse('2010-07-05 10:30')
|
||||||
|
@user = users(:api_bestnames)
|
||||||
|
token = Base64.encode64("#{@user.username}:#{@user.plain_text_password}")
|
||||||
|
token = "Basic #{token}"
|
||||||
|
@domain = domains(:hospital)
|
||||||
|
|
||||||
|
@auth_headers = { 'Authorization' => token }
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_renews_domains
|
||||||
|
payload = {
|
||||||
|
"domains": [
|
||||||
|
'shop.test',
|
||||||
|
'airport.test',
|
||||||
|
'library.test'
|
||||||
|
],
|
||||||
|
"renew_period": "1y"
|
||||||
|
}
|
||||||
|
post "/repp/v1/domains/renew/bulk", headers: @auth_headers, params: payload
|
||||||
|
json = JSON.parse(response.body, symbolize_names: true)
|
||||||
|
|
||||||
|
assert_response :ok
|
||||||
|
assert_equal 1000, json[:code]
|
||||||
|
assert_equal 'Command completed successfully', json[:message]
|
||||||
|
assert json[:data][:updated_domains].include? 'shop.test'
|
||||||
|
assert json[:data][:updated_domains].include? 'airport.test'
|
||||||
|
assert json[:data][:updated_domains].include? 'library.test'
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_throws_error_when_domain_not_renewable
|
||||||
|
payload = {
|
||||||
|
"domains": [
|
||||||
|
'invalid.test',
|
||||||
|
],
|
||||||
|
"renew_period": "1y"
|
||||||
|
}
|
||||||
|
post "/repp/v1/domains/renew/bulk", headers: @auth_headers, params: payload
|
||||||
|
json = JSON.parse(response.body, symbolize_names: true)
|
||||||
|
|
||||||
|
assert_response :bad_request
|
||||||
|
assert_equal 2304, json[:code]
|
||||||
|
assert_equal 'Domain renew error for invalid.test', json[:message]
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_throws_error_when_not_enough_balance
|
||||||
|
billing_prices(:renew_one_year).update(price_cents: 99999999)
|
||||||
|
payload = {
|
||||||
|
"domains": [
|
||||||
|
'invalid.test',
|
||||||
|
],
|
||||||
|
"renew_period": "1y"
|
||||||
|
}
|
||||||
|
post "/repp/v1/domains/renew/bulk", headers: @auth_headers, params: payload
|
||||||
|
json = JSON.parse(response.body, symbolize_names: true)
|
||||||
|
|
||||||
|
assert_response :bad_request
|
||||||
|
assert_equal 2304, json[:code]
|
||||||
|
assert_equal 'Not enough funds for renew domains', json[:message]
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_throws_error_if_invalid_renew_period
|
||||||
|
payload = {
|
||||||
|
"domains": [
|
||||||
|
'shop.test'
|
||||||
|
],
|
||||||
|
"renew_period": "nope"
|
||||||
|
}
|
||||||
|
|
||||||
|
post "/repp/v1/domains/renew/bulk", headers: @auth_headers, params: payload
|
||||||
|
json = JSON.parse(response.body, symbolize_names: true)
|
||||||
|
|
||||||
|
assert_response :bad_request
|
||||||
|
assert_equal 2005, json[:code]
|
||||||
|
assert_equal 'Invalid renew period', json[:message]
|
||||||
|
end
|
||||||
|
end
|
Loading…
Add table
Add a link
Reference in a new issue