Create tests for REPP bulk renew, fix lingvistic issues with errors

This commit is contained in:
Karl Erik Õunapuu 2020-12-21 13:30:30 +02:00
parent 240da481e5
commit 66114aa648
No known key found for this signature in database
GPG key ID: C9DD647298A34764
4 changed files with 106 additions and 12 deletions

View file

@ -2,26 +2,40 @@ module Repp
module V1
module Domains
class RenewsController < BaseController
before_action :validate_renew_period, only: [:bulk_renew]
before_action :select_renewable_domains, only: [: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 ||= []
if bulk_renew_params[:domains].instance_of?(Array)
domains = bulk_renew_domains
@domains = bulk_renew_domains
else
@epp_errors << { code: 2005, msg: 'Domains attribute must be an array' }
end
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
private
def run_bulk_renew_task(domains, period)
::Domains::BulkRenew::Start.run(domains: domains, period_element: period,
registrar: current_user.registrar)
@ -38,7 +52,7 @@ module Repp
@epp_errors ||= []
domains = []
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
@epp_errors << { code: 2304, msg: "Object does not exist: #{idn}" } unless domain
end