Refactor registrars

- Reorganize views
- Improve database structure
- Use default translations
- Combine tests
This commit is contained in:
Artur Beljajev 2019-05-10 13:13:19 +03:00
parent 59e9b16dfa
commit efb63399b2
27 changed files with 287 additions and 353 deletions

View file

@ -58,12 +58,12 @@ module Admin
def registrar_params
params.require(:registrar).permit(:name,
:reg_no,
:street,
:city,
:state,
:zip,
:country_code,
:email,
:address_street,
:address_zip,
:address_city,
:address_state,
:address_country_code,
:phone,
:website,
:code,

View file

@ -13,7 +13,7 @@ class Registrar < ActiveRecord::Base
delegate :balance, to: :cash_account, allow_nil: true
validates :name, :reg_no, :country_code, :email, :code, presence: true
validates :name, :reg_no, :address_country_code, :email, :code, presence: true
validates :name, :code, uniqueness: true
validates :accounting_customer_code, presence: true
validates :language, presence: true
@ -73,11 +73,11 @@ class Registrar < ActiveRecord::Base
buyer: self,
buyer_name: name,
buyer_reg_no: reg_no,
buyer_country_code: country_code,
buyer_state: state,
buyer_street: street,
buyer_city: city,
buyer_zip: zip,
buyer_country_code: address_country_code,
buyer_state: address_state,
buyer_street: address_street,
buyer_city: address_city,
buyer_zip: address_zip,
buyer_phone: phone,
buyer_url: website,
buyer_email: email,
@ -104,7 +104,7 @@ class Registrar < ActiveRecord::Base
end
def address
[street, city, state, zip].reject(&:blank?).compact.join(', ')
[address_street, address_city, address_state, address_zip].reject(&:blank?).compact.join(', ')
end
def to_s
@ -112,7 +112,7 @@ class Registrar < ActiveRecord::Base
end
def country
Country.new(country_code)
Country.new(address_country_code)
end
def code=(code)

View file

@ -59,64 +59,7 @@
</div>
</div>
<div class="row">
<div class="col-md-8">
<div class="panel panel-default">
<div class="panel-heading clearfix">
<div class="pull-left">
<%= t(:address) %>
</div>
</div>
<div class="panel-body">
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :street %>
</div>
<div class="col-md-7">
<%= f.text_field(:street, class: 'form-control') %>
</div>
</div>
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :city %>
</div>
<div class="col-md-7">
<%= f.text_field(:city, class: 'form-control') %>
</div>
</div>
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :state %>
</div>
<div class="col-md-7">
<%= f.text_field(:state, class: 'form-control') %>
</div>
</div>
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :zip %>
</div>
<div class="col-md-7">
<%= f.text_field(:zip, class: 'form-control') %>
</div>
</div>
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :country_code, t(:country) %>
</div>
<div class="col-md-7">
<%= f.select(:country_code, SortedCountry.all_options(f.object.country_code), {}, class: 'form-control') %>
</div>
</div>
</div>
</div>
</div>
</div>
<%= render 'admin/registrars/form/address', f: f %>
<%= render 'admin/registrars/form/billing', f: f %>
<div class="row">

View file

@ -0,0 +1,59 @@
<div class="row">
<div class="col-md-8">
<div class="panel panel-default">
<div class="panel-heading clearfix">
<div class="pull-left">
<%= t '.header' %>
</div>
</div>
<div class="panel-body">
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :street %>
</div>
<div class="col-md-7">
<%= f.text_field :address_street, class: 'form-control' %>
</div>
</div>
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :city %>
</div>
<div class="col-md-7">
<%= f.text_field :address_city, class: 'form-control' %>
</div>
</div>
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :state %>
</div>
<div class="col-md-7">
<%= f.text_field :address_state, class: 'form-control' %>
</div>
</div>
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :zip %>
</div>
<div class="col-md-7">
<%= f.text_field :address_zip, class: 'form-control' %>
</div>
</div>
<div class="form-group">
<div class="col-md-4 control-label">
<%= f.label :address_country_code, t(:country) %>
</div>
<div class="col-md-7">
<%= f.select :address_country_code, SortedCountry.all_options(f.object.address_country_code), {}, class: 'form-control' %>
</div>
</div>
<p class="text-muted"><%= t '.hint' %></p>
</div>
</div>
</div>
</div>

View file

@ -28,23 +28,23 @@
<div class="row">
<div class="col-md-6">
<%= render 'details', registrar: @registrar %>
<%= render 'admin/registrars/show/details', registrar: @registrar %>
</div>
<div class="col-md-6">
<%= render 'contacts', registrar: @registrar %>
<%= render 'billing', registrar: @registrar %>
<%= render 'preferences', registrar: registrar %>
<%= render 'admin/registrars/show/contacts', registrar: @registrar %>
<%= render 'admin/registrars/show/billing', registrar: @registrar %>
<%= render 'admin/registrars/show/preferences', registrar: registrar %>
</div>
</div>
<div class="row">
<div class="col-md-12">
<%= render 'users', registrar: @registrar %>
<%= render 'admin/registrars/show/users', registrar: @registrar %>
</div>
</div>
<div class="row">
<div class="col-md-12">
<%= render 'white_ips', registrar: @registrar %>
<%= render 'admin/registrars/show/white_ips', registrar: @registrar %>
</div>
</div>

View file

@ -21,4 +21,4 @@
<dd><%= registrar.reference_no %></dd>
</dl>
</div>
</div>
</div>

View file

@ -5,17 +5,17 @@
<div class="panel-body">
<dl class="dl-horizontal">
<dt><%= t(:country) %></dt>
<dt><%= Registrar.human_attribute_name :country %></dt>
<dd><%= @registrar.country %></dd>
<dt><%= t(:address) %></dt>
<dt><%= Registrar.human_attribute_name :address %></dt>
<dd><%= @registrar.address %></dd>
<dt><%= t(:contact_phone) %></dt>
<dt><%= Registrar.human_attribute_name :phone %></dt>
<dd><%= @registrar.phone %></dd>
<dt><%= t(:contact_email) %></dt>
<dt><%= Registrar.human_attribute_name :email %></dt>
<dd><%= @registrar.email %></dd>
</dl>
</div>
</div>
</div>

View file

@ -15,7 +15,7 @@
<dd><%= registrar.code %></dd>
<dt><%= Registrar.human_attribute_name :balance %></dt>
<dd><%= registrar.balance %></dd>
<dd><%= number_to_currency registrar.balance %></dd>
<dt><%= Registrar.human_attribute_name :website %></dt>
<dd><%= registrar.website %></dd>

View file

@ -13,7 +13,7 @@
%h3.panel-title= t(:general)
.panel-body
%dl.dl-horizontal
%dt= t(:name)
%dt= Registrar.human_attribute_name :name
%dd= @registrar.name
%dt= Registrar.human_attribute_name :reg_no
@ -22,7 +22,7 @@
%dt= Registrar.human_attribute_name :vat_no
%dd= @registrar.vat_no
%dt= t(:id)
%dt= Registrar.human_attribute_name :code
%dd= @registrar.code
.col-md-6
@ -31,14 +31,14 @@
%h3.panel-title= t(:contact)
.panel-body
%dl.dl-horizontal
%dt= t(:country)
%dt= Registrar.human_attribute_name :country
%dd= @registrar.country
%dt= t(:address)
%dt= Registrar.human_attribute_name :address
%dd= @registrar.address
%dt= t(:contact_phone)
%dt= Registrar.human_attribute_name :phone
%dd= @registrar.phone
%dt= t(:contact_email)
%dt= Registrar.human_attribute_name :email
%dd= @registrar.email

View file

@ -13,12 +13,29 @@ en:
delete_btn: Delete
delete_btn_confirm: Are you sure you want delete registrar?
details:
header: Details
contacts:
header: Contacts
billing:
header: Billing
preferences:
header: Preferences
users:
header: API Users
new_btn: New API user
white_ips:
header: Whitelisted IPs
new_btn: New whitelisted IP
edit:
header: Edit registrar
billing:
header: Billing
create:
created: Registrar has been successfully created
@ -33,27 +50,14 @@ en:
create_btn: Create registrar
update_btn: Update registrar
address:
header: Address
hint: Used as a billing address
billing:
header: Billing
no_reference_number_hint: Reference number will be generated automatically
disabled_reference_number_hint: Reference number cannot be changed
preferences:
header: Preferences
details:
header: Details
contacts:
header: Contacts
preferences:
header: Preferences
users:
header: API Users
new_btn: New API user
white_ips:
header: Whitelisted IPs
new_btn: New whitelisted IP
header: Preferences

View file

@ -375,8 +375,6 @@ en:
choose: 'Choose...'
created_before: 'Created before'
created_after: 'Created after'
contact_phone: 'Contact phone'
contact_email: 'Contact e-mail'
address_help: 'Street name, house no - apartment no, city, county, country, zip'
download: 'Download'
failed_to_create_certificate: 'Failed to create certificate!'

View file

@ -0,0 +1,9 @@
class PrefixRegistrarsAddressColumns < ActiveRecord::Migration
def change
rename_column :registrars, :street, :address_street
rename_column :registrars, :zip, :address_zip
rename_column :registrars, :city, :address_city
rename_column :registrars, :state, :address_state
rename_column :registrars, :country_code, :address_country_code
end
end

View file

@ -2188,11 +2188,11 @@ CREATE TABLE public.registrars (
phone character varying,
email character varying NOT NULL,
billing_email character varying,
country_code character varying NOT NULL,
state character varying,
city character varying,
street character varying,
zip character varying,
address_country_code character varying NOT NULL,
address_state character varying,
address_city character varying,
address_street character varying,
address_zip character varying,
code character varying NOT NULL,
website character varying,
accounting_customer_code character varying NOT NULL,
@ -4945,3 +4945,5 @@ INSERT INTO schema_migrations (version) VALUES ('20190328151838');
INSERT INTO schema_migrations (version) VALUES ('20190415120246');
INSERT INTO schema_migrations (version) VALUES ('20190510090240');

View file

@ -3,12 +3,12 @@ FactoryBot.define do
sequence(:name) { |n| "test#{n}" }
sequence(:code) { |n| "test#{n}" }
sequence(:reg_no) { |n| "test#{n}" }
street 'test'
city 'test'
state 'test'
zip 'test'
email 'test@test.com'
country_code 'US'
address_street 'test'
address_zip 'test'
address_city 'test'
address_state 'test'
address_country_code 'US'
accounting_customer_code 'test'
language 'en'
sequence(:reference_no) { |n| "1234#{n}" }

View file

@ -3,11 +3,11 @@ bestnames:
reg_no: 1234
code: bestnames
email: info@bestnames.test
street: Main Street
zip: 12345
city: New York
state: New York
country_code: US
address_street: Main Street 1
address_zip: 1234
address_city: NY
address_state: NY State
address_country_code: US
accounting_customer_code: bestnames
language: en
billing_email: billing@bestnames.test
@ -19,18 +19,18 @@ goodnames:
reg_no: 12345
code: goodnames
email: info@goodnames.test
country_code: DE
address_country_code: US
vat_no: DE123456789
accounting_customer_code: goodnames
language: en
reference_no: 26
not_in_use:
name: any
name: Not in use
reg_no: any
code: any
email: any@example.com
country_code: US
address_country_code: US
vat_no: any
accounting_customer_code: any
language: en
@ -41,7 +41,7 @@ invalid:
reg_no: any
code: another
email: any
country_code: US
address_country_code: US
vat_no: any
accounting_customer_code: any
language: en

View file

@ -15,7 +15,7 @@ class RegistrarVATTest < ActiveSupport::TestCase
def test_apply_vat_rate_from_registry_when_registrar_is_local_vat_payer
Setting.registry_country_code = 'US'
@registrar.country_code = 'US'
@registrar.address_country_code = 'US'
Registry.instance.stub(:vat_rate, BigDecimal('5.5')) do
assert_equal BigDecimal('5.5'), @registrar.effective_vat_rate
@ -32,13 +32,13 @@ class RegistrarVATTest < ActiveSupport::TestCase
def test_apply_vat_rate_from_registrar_when_registrar_is_foreign_vat_payer
Setting.registry_country_code = 'US'
@registrar.country_code = 'DE'
@registrar.address_country_code = 'DE'
@registrar.vat_rate = BigDecimal('5.6')
assert_equal BigDecimal('5.6'), @registrar.effective_vat_rate
end
def test_require_vat_rate_when_registrar_is_foreign_vat_payer_and_vat_no_is_absent
@registrar.country_code = 'DE'
@registrar.address_country_code = 'DE'
@registrar.vat_no = ''
@registrar.vat_rate = ''
@ -50,7 +50,7 @@ class RegistrarVATTest < ActiveSupport::TestCase
end
def test_require_no_vat_rate_when_registrar_is_foreign_vat_payer_and_vat_no_is_present
@registrar.country_code = 'DE'
@registrar.address_country_code = 'DE'
@registrar.vat_no = 'valid'
@registrar.vat_rate = 1
@ -61,7 +61,7 @@ class RegistrarVATTest < ActiveSupport::TestCase
end
def test_vat_rate_validation
@registrar.country_code = 'DE'
@registrar.address_country_code = 'DE'
@registrar.vat_no = ''
@registrar.vat_rate = -1
@ -78,7 +78,7 @@ class RegistrarVATTest < ActiveSupport::TestCase
end
def test_serializes_and_deserializes_vat_rate
@registrar.country_code = 'DE'
@registrar.address_country_code = 'DE'
@registrar.vat_rate = BigDecimal('25.5')
@registrar.save!
@registrar.reload

View file

@ -5,8 +5,8 @@ class RegistrarTest < ActiveSupport::TestCase
@registrar = registrars(:bestnames)
end
def test_default_fixture_is_valid
assert @registrar.valid?, proc { @registrar.errors.full_messages }
def test_valid_registrar_is_valid
assert valid_registrar.valid?, proc { valid_registrar.errors.full_messages }
end
def test_invalid_fixture_is_invalid
@ -14,33 +14,33 @@ class RegistrarTest < ActiveSupport::TestCase
end
def test_invalid_without_name
@registrar.name = ''
assert @registrar.invalid?
registrar = valid_registrar
registrar.name = ''
assert registrar.invalid?
end
def test_invalid_without_reg_no
@registrar.reg_no = ''
assert @registrar.invalid?
registrar = valid_registrar
registrar.reg_no = ''
assert registrar.invalid?
end
def test_invalid_without_email
@registrar.email = ''
assert @registrar.invalid?
registrar = valid_registrar
registrar.email = ''
assert registrar.invalid?
end
def test_invalid_without_accounting_customer_code
@registrar.accounting_customer_code = ''
assert @registrar.invalid?
end
def test_invalid_without_country_code
@registrar.country_code = ''
assert @registrar.invalid?
registrar = valid_registrar
registrar.accounting_customer_code = ''
assert registrar.invalid?
end
def test_invalid_without_language
@registrar.language = ''
assert @registrar.invalid?
registrar = valid_registrar
registrar.language = ''
assert registrar.invalid?
end
def test_has_default_language
@ -56,7 +56,9 @@ class RegistrarTest < ActiveSupport::TestCase
end
def test_full_address
assert_equal 'Main Street, New York, New York, 12345', @registrar.address
registrar = Registrar.new(address_street: 'Main Street 1', address_zip: '1234',
address_city: 'NY', address_state: 'NY State')
assert_equal 'Main Street 1, NY, NY State, 1234', registrar.address
end
def test_validates_reference_number_format
@ -96,4 +98,10 @@ class RegistrarTest < ActiveSupport::TestCase
Setting.days_to_keep_invoices_active = @original_days_to_keep_invoices_active_setting
end
private
def valid_registrar
registrars(:bestnames)
end
end

View file

@ -4,6 +4,8 @@ class ContactVersionsTest < ApplicationSystemTestCase
def setup
super
@registrar = registrars(:bestnames)
create_contact_with_history
sign_in users(:admin)
end
@ -16,18 +18,13 @@ class ContactVersionsTest < ApplicationSystemTestCase
def create_contact_with_history
sql = <<-SQL.squish
INSERT INTO registrars (id, name, reg_no, email, country_code, code,
accounting_customer_code, language, reference_no)
VALUES (75, 'test_registrar', 'test123', 'test@test.com', 'EE', 'TEST123',
'test123', 'en', '1234');
INSERT INTO contacts (id, code, email, auth_info, registrar_id)
VALUES (75, 'test_code', 'test@inbox.test', '8b4d462aa04194ca78840a', 75);
VALUES (75, 'test_code', 'test@inbox.test', '8b4d462aa04194ca78840a', #{@registrar.id});
INSERT INTO log_contacts (item_type, item_id, event, whodunnit, object,
object_changes, created_at, session, children, ident_updated_at, uuid)
VALUES ('Contact', 75, 'update', '1-AdminUser',
'{"id": 75, "code": "test_code", "auth_info": "8b4d462aa04194ca78840a", "registrar_id": 75, "old_field": "value"}',
'{"id": 75, "code": "test_code", "auth_info": "8b4d462aa04194ca78840a", "registrar_id": #{@registrar.id}, "old_field": "value"}',
'{"other_made_up_field": "value"}',
'2018-04-23 15:50:48.113491', '2018-04-23 12:44:56',
'{"legal_documents":[null]}', null, null
@ -42,16 +39,20 @@ class ContactVersionsTest < ApplicationSystemTestCase
end
def test_removed_fields_are_not_causing_errors_in_index_view
assert_equal 'Best Names', @registrar.name
visit admin_contact_versions_path
assert_text 'test_registrar'
assert_text 'Best Names'
assert_text 'update 23.04.18, 18:50'
end
def test_removed_fields_are_not_causing_errors_in_details_view
assert_equal 'Best Names', @registrar.name
version_id = Contact.find(75).versions.last
visit admin_contact_version_path(version_id)
assert_text 'test_registrar'
assert_text 'Best Names'
assert_text '23.04.18, 18:50 update 1-AdminUser'
end
end
end

View file

@ -4,6 +4,8 @@ class DomainVersionsTest < ApplicationSystemTestCase
def setup
super
@registrar = registrars(:bestnames)
create_domain_with_history
sign_in users(:admin)
end
@ -16,22 +18,17 @@ class DomainVersionsTest < ApplicationSystemTestCase
def create_domain_with_history
sql = <<-SQL.squish
INSERT INTO registrars (id, name, reg_no, email, country_code, code,
accounting_customer_code, language, reference_no)
VALUES (54, 'test_registrar', 'test123', 'test@test.com', 'EE', 'TEST123',
'test123', 'en', '1234');
INSERT INTO contacts (id, code, email, auth_info, registrar_id)
VALUES (54, 'test_code', 'test@inbox.test', '8b4d462aa04194ca78840a', 54);
VALUES (54, 'test_code', 'test@inbox.test', '8b4d462aa04194ca78840a', #{@registrar.id});
INSERT INTO domains (id, registrar_id, valid_to, registrant_id,
transfer_code)
VALUES (54, 54, '2018-06-23T12:14:02.732+03:00', 54, 'transfer_code');
VALUES (54, #{@registrar.id}, '2018-06-23T12:14:02.732+03:00', 54, 'transfer_code');
INSERT INTO log_domains (item_type, item_id, event, whodunnit, object,
object_changes, created_at, session, children)
VALUES ('Domain', 54, 'update', '1-AdminUser',
'{"id": 54, "registrar_id": 54, "valid_to": "2018-07-23T12:14:05.583+03:00", "registrant_id": 54, "transfer_code": "transfer_code", "valid_from": "2017-07-23T12:14:05.583+03:00"}',
'{"id": 54, "registrar_id": #{@registrar.id}, "valid_to": "2018-07-23T12:14:05.583+03:00", "registrant_id": 54, "transfer_code": "transfer_code", "valid_from": "2017-07-23T12:14:05.583+03:00"}',
'{"foo": "bar", "other_made_up_field": "value"}',
'2018-04-23 15:50:48.113491', '2018-04-23 12:44:56',
'{"null_fracdmin_contacts":[108],"tech_contacts":[109],"nameservers":[],"dnskeys":[],"legal_documents":[null],"registrant":[1]}'
@ -45,17 +42,21 @@ class DomainVersionsTest < ApplicationSystemTestCase
end
def test_removed_fields_are_not_causing_errors_in_index_view
assert_equal 'Best Names', @registrar.name
visit admin_domain_versions_path
assert_text 'test_registrar'
assert_text 'test_registrar update 23.04.18, 18:50'
assert_text 'Best Names'
assert_text 'Best Names update 23.04.18, 18:50'
end
def test_removed_fields_are_not_causing_errors_in_details_view
assert_equal 'Best Names', @registrar.name
version_id = Domain.find(54).versions.last
visit admin_domain_version_path(version_id)
assert_text 'test_registrar'
assert_text 'Best Names'
assert_text '23.04.18, 18:50 update 1-AdminUser'
end
end
end

View file

@ -1,30 +0,0 @@
require 'test_helper'
class AdminAreaDeleteRegistrarTest < ApplicationSystemTestCase
setup do
sign_in users(:admin)
end
def test_can_be_deleted_when_not_in_use
visit admin_registrar_url(registrars(:not_in_use))
assert_difference 'Registrar.count', -1 do
click_link_or_button 'Delete'
end
assert_current_path admin_registrars_path
assert_text 'Registrar has been successfully deleted'
end
def test_cannot_be_deleted_when_in_use
registrar = registrars(:bestnames)
visit admin_registrar_url(registrar)
assert_no_difference 'Registrar.count' do
click_link_or_button 'Delete'
end
assert_current_path admin_registrar_path(registrar)
assert_text 'Cannot delete record because dependent domains exist'
end
end

View file

@ -1,26 +0,0 @@
require 'test_helper'
class AdminAreaRegistrarDetailsTest < ApplicationSystemTestCase
include ActionView::Helpers::NumberHelper
setup do
sign_in users(:admin)
@registrar = registrars(:bestnames)
end
def test_registrar_details
@registrar.accounting_customer_code = 'US0001'
@registrar.vat_no = 'US12345'
@registrar.vat_rate = 5
@registrar.language = 'en'
@registrar.billing_email = 'billing@bestnames.test'
@registrar.save(validate: false)
visit admin_registrar_path(@registrar)
assert_text 'Accounting customer code US0001'
assert_text 'VAT number US12345'
assert_text 'VAT rate 5.0%'
assert_text 'Language English'
assert_text 'billing@bestnames.test'
end
end

View file

@ -1,69 +0,0 @@
require 'test_helper'
class AdminAreaEditRegistrarTest < ApplicationSystemTestCase
setup do
sign_in users(:admin)
@registrar = registrars(:bestnames)
end
def test_attributes_update
visit admin_registrar_path(@registrar)
click_link_or_button 'Edit'
fill_in 'Name', with: 'new name'
fill_in 'Reg no', with: '4727673'
fill_in 'Contact phone', with: '2570937'
fill_in 'Website', with: 'http://new.example.com'
fill_in 'Contact e-mail', with: 'new@example.com'
fill_in 'Street', with: 'new street'
fill_in 'Zip', with: 'new zip'
fill_in 'City', with: 'new city'
fill_in 'State / Province', with: 'new state'
select 'Germany', from: 'Country'
fill_in 'VAT number', with: '2386449'
fill_in 'Accounting customer code', with: '866477'
fill_in 'Billing email', with: 'new-billing@example.com'
select 'Estonian', from: 'Language'
click_link_or_button 'Update registrar'
@registrar.reload
assert_equal 'new name', @registrar.name
assert_equal '4727673', @registrar.reg_no
assert_equal '2570937', @registrar.phone
assert_equal 'http://new.example.com', @registrar.website
assert_equal 'new@example.com', @registrar.email
assert_equal 'new street', @registrar.street
assert_equal 'new zip', @registrar.zip
assert_equal 'new city', @registrar.city
assert_equal 'new state', @registrar.state
assert_equal Country.new('DE'), @registrar.country
assert_equal '2386449', @registrar.vat_no
assert_equal '866477', @registrar.accounting_customer_code
assert_equal 'new-billing@example.com', @registrar.billing_email
assert_equal 'et', @registrar.language
assert_current_path admin_registrar_path(@registrar)
assert_text 'Registrar has been successfully updated'
end
def test_code_cannot_be_changed
visit admin_registrar_path(@registrar)
click_link_or_button 'Edit'
assert_no_field 'Code'
end
def test_fails_gracefully
visit admin_registrar_path(@registrar)
click_link_or_button 'Edit'
fill_in 'Name', with: 'Good Names'
click_link_or_button 'Update registrar'
assert_field 'Name', with: 'Good Names'
assert_text 'Name has already been taken'
end
end

View file

@ -1,50 +0,0 @@
require 'test_helper'
class AdminAreaNewRegistrarTest < ApplicationSystemTestCase
setup do
sign_in users(:admin)
end
def test_new_registrar_creation_with_required_params
visit admin_registrars_url
click_link_or_button 'New registrar'
fill_in 'Name', with: 'Brand new names'
fill_in 'Reg no', with: '55555555'
fill_in 'Contact e-mail', with: 'test@example.com'
select 'United States', from: 'Country'
fill_in 'Accounting customer code', with: 'test'
fill_in 'Code', with: 'test'
assert_difference 'Registrar.count' do
click_link_or_button 'Create registrar'
end
assert_current_path admin_registrar_path(Registrar.last)
assert_text 'Registrar has been successfully created'
end
def test_fails_gracefully
visit admin_registrars_url
click_link_or_button 'New registrar'
fill_in 'Name', with: 'Best Names'
fill_in 'Reg no', with: '55555555'
fill_in 'Contact e-mail', with: 'test@example.com'
fill_in 'Accounting customer code', with: 'test'
fill_in 'Code', with: 'test'
assert_no_difference 'Registrar.count' do
click_link_or_button 'Create registrar'
end
assert_field 'Name', with: 'Best Names'
assert_text 'Name has already been taken'
end
def test_pre_populated_default_language
Setting.default_language = 'en'
visit admin_registrars_url
click_link_or_button 'New registrar'
assert_field 'Language', with: 'en'
end
end

View file

@ -0,0 +1,84 @@
require 'test_helper'
class AdminRegistrarsSystemTest < ApplicationSystemTestCase
include ActionView::Helpers::NumberHelper
setup do
@registrar = registrars(:bestnames)
sign_in users(:admin)
end
def test_creates_new_registrar
assert_nil Registrar.find_by(name: 'New name')
visit admin_registrars_path
click_on 'New registrar'
fill_in 'Name', with: 'New name'
fill_in 'Reg no', with: '55555555'
fill_in 'Contact e-mail', with: 'any@registrar.test'
select 'United States', from: 'Country'
fill_in 'Accounting customer code', with: 'test'
fill_in 'Code', with: 'test'
click_on 'Create registrar'
assert_text 'Registrar has been successfully created'
assert_text 'New name'
end
def test_updates_registrar
assert_not_equal 'New name', @registrar.name
visit admin_registrar_path(@registrar)
click_link_or_button 'Edit'
fill_in 'Name', with: 'New name'
click_link_or_button 'Update registrar'
assert_text 'Registrar has been successfully updated'
assert_text 'New name'
end
def test_deletes_registrar
registrar = registrars(:not_in_use)
assert_equal 'Not in use', registrar.name
visit admin_registrar_path(registrar)
click_on 'Delete'
assert_text 'Registrar has been successfully deleted'
assert_no_text 'Not in use'
end
def test_registrar_cannot_be_deleted_when_in_use
visit admin_registrar_url(@registrar)
click_on 'Delete'
assert_text 'Cannot delete record because dependent domains exist'
end
def test_pre_populates_default_language_upon_creation
Setting.default_language = 'en'
visit new_admin_registrar_path
assert_field 'Language', with: 'en'
end
def test_code_cannot_be_edited
visit edit_admin_registrar_path(@registrar)
assert_no_field 'Code'
end
def test_shows_registrar_details
@registrar.accounting_customer_code = 'US0001'
@registrar.vat_no = 'US12345'
@registrar.vat_rate = 5
@registrar.language = 'en'
@registrar.billing_email = 'billing@bestnames.test'
@registrar.save(validate: false)
visit admin_registrar_path(@registrar)
assert_text 'Accounting customer code US0001'
assert_text 'VAT number US12345'
assert_text "VAT rate #{number_to_percentage(5, precision: 1)}"
assert_text 'Language English'
assert_text 'billing@bestnames.test'
end
end