mirror of
https://github.com/internetee/registry.git
synced 2025-06-12 07:34:45 +02:00
parent
03b6f1df91
commit
4960b4400f
5 changed files with 37 additions and 24 deletions
|
@ -5,7 +5,8 @@ class Nameserver < ActiveRecord::Base
|
||||||
belongs_to :domain, required: true
|
belongs_to :domain, required: true
|
||||||
|
|
||||||
# rubocop: disable Metrics/LineLength
|
# rubocop: disable Metrics/LineLength
|
||||||
validates :hostname, presence: true, format: { with: /\A(([a-zA-Z0-9]|[a-zA-ZäöüõšžÄÖÜÕŠŽ0-9][a-zA-ZäöüõšžÄÖÜÕŠŽ0-9\-]*[a-zA-ZäöüõšžÄÖÜÕŠŽ0-9])\.)*([A-Za-z0-9]|[A-Za-z0-9][A-Za-z0-9\-]*[A-Za-z0-9])\z/ }
|
validates :hostname, presence: true#, format: { with: /\A(([a-zA-Z0-9]|[a-zA-ZäöüõšžÄÖÜÕŠŽ0-9][a-zA-ZäöüõšžÄÖÜÕŠŽ0-9\-]*[a-zA-ZäöüõšžÄÖÜÕŠŽ0-9])\.)*([A-Za-z0-9]|[A-Za-z0-9][A-Za-z0-9\-]*[A-Za-z0-9])\z/ }
|
||||||
|
validates :hostname, format: { with: /\A(([a-zA-Z0-9]|[a-zA-ZäöüõšžÄÖÜÕŠŽ0-9][a-zA-ZäöüõšžÄÖÜÕŠŽ0-9\-]*[a-zA-ZäöüõšžÄÖÜÕŠŽ0-9])\.)*([A-Za-z0-9]|[A-Za-z0-9][A-Za-z0-9\-]*[A-Za-z0-9])\z/ }, allow_blank: true
|
||||||
validate :val_ipv4
|
validate :val_ipv4
|
||||||
validate :val_ipv6
|
validate :val_ipv6
|
||||||
validate :require_ip, if: :glue_record_required?
|
validate :require_ip, if: :glue_record_required?
|
||||||
|
|
4
test/fixtures/nameservers.yml
vendored
4
test/fixtures/nameservers.yml
vendored
|
@ -1,4 +1,4 @@
|
||||||
ns1:
|
shop_ns1:
|
||||||
hostname: ns1.bestnames.test
|
hostname: ns1.bestnames.test
|
||||||
ipv4:
|
ipv4:
|
||||||
- 192.0.2.1
|
- 192.0.2.1
|
||||||
|
@ -6,7 +6,7 @@ ns1:
|
||||||
- 2001:db8::1
|
- 2001:db8::1
|
||||||
domain: shop
|
domain: shop
|
||||||
|
|
||||||
ns2:
|
shop_ns2:
|
||||||
hostname: ns2.bestnames.test
|
hostname: ns2.bestnames.test
|
||||||
ipv4:
|
ipv4:
|
||||||
- 192.0.2.2
|
- 192.0.2.2
|
||||||
|
|
|
@ -1,24 +1,14 @@
|
||||||
require 'test_helper'
|
require 'test_helper'
|
||||||
|
|
||||||
class APINameserversPutTest < ActionDispatch::IntegrationTest
|
class APINameserversPutTest < ActionDispatch::IntegrationTest
|
||||||
def setup
|
def test_replaces_registrar_nameservers
|
||||||
@registrar = registrars(:bestnames)
|
old_nameserver_ids = [nameservers(:shop_ns1).id,
|
||||||
end
|
nameservers(:airport_ns1).id,
|
||||||
|
nameservers(:metro_ns1).id]
|
||||||
def test_deletes_old_nameservers
|
|
||||||
previous_nameserver_ids = @registrar.nameservers.where(hostname: 'ns1.bestnames.test').ids
|
|
||||||
request_params = { format: :json, data: { type: 'nameserver', id: 'ns1.bestnames.test',
|
|
||||||
attributes: { hostname: 'ns55.bestnames.test' } } }
|
|
||||||
|
|
||||||
put '/repp/v1/registrar/nameservers', request_params, { 'HTTP_AUTHORIZATION' => http_auth_key }
|
|
||||||
refute @registrar.nameservers(true).where(id: previous_nameserver_ids).exists?
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_creates_new_nameservers
|
|
||||||
request_params = { format: :json, data: { type: 'nameserver', id: 'ns1.bestnames.test',
|
request_params = { format: :json, data: { type: 'nameserver', id: 'ns1.bestnames.test',
|
||||||
attributes: { hostname: 'ns55.bestnames.test' } } }
|
attributes: { hostname: 'ns55.bestnames.test' } } }
|
||||||
put '/repp/v1/registrar/nameservers', request_params, { 'HTTP_AUTHORIZATION' => http_auth_key }
|
put '/repp/v1/registrar/nameservers', request_params, { 'HTTP_AUTHORIZATION' => http_auth_key }
|
||||||
assert_equal 2, @registrar.nameservers.where(hostname: 'ns55.bestnames.test').size
|
assert_empty (old_nameserver_ids & registrars(:bestnames).nameservers(true).ids)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_saves_all_attributes
|
def test_saves_all_attributes
|
||||||
|
@ -33,14 +23,22 @@ class APINameserversPutTest < ActionDispatch::IntegrationTest
|
||||||
assert_equal ['2001:DB8::55'], new_nameserver.ipv6
|
assert_equal ['2001:DB8::55'], new_nameserver.ipv6
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_keeps_other_nameserver_intact
|
||||||
|
request_params = { format: :json, data: { type: 'nameserver', id: 'ns1.bestnames.test',
|
||||||
|
attributes: { hostname: 'ns55.bestnames.test' } } }
|
||||||
|
|
||||||
|
other_nameserver_hash = nameservers(:shop_ns2).attributes
|
||||||
|
put '/repp/v1/registrar/nameservers', request_params, { 'HTTP_AUTHORIZATION' => http_auth_key }
|
||||||
|
assert_equal other_nameserver_hash, nameservers(:shop_ns2).reload.attributes
|
||||||
|
end
|
||||||
|
|
||||||
def test_keeps_other_registrar_nameservers_intact
|
def test_keeps_other_registrar_nameservers_intact
|
||||||
request_params = { format: :json, data: { type: 'nameserver', id: 'ns1.bestnames.test',
|
request_params = { format: :json, data: { type: 'nameserver', id: 'ns1.bestnames.test',
|
||||||
attributes: { hostname: 'ns55.bestnames.test' } } }
|
attributes: { hostname: 'ns55.bestnames.test' } } }
|
||||||
|
|
||||||
other_registrar_nameserver_ids = registrars(:goodnames).nameservers.ids
|
nameserver_hash = nameservers(:metro_ns1).attributes
|
||||||
assert other_registrar_nameserver_ids.any?
|
|
||||||
put '/repp/v1/registrar/nameservers', request_params, { 'HTTP_AUTHORIZATION' => http_auth_key }
|
put '/repp/v1/registrar/nameservers', request_params, { 'HTTP_AUTHORIZATION' => http_auth_key }
|
||||||
assert_equal other_registrar_nameserver_ids, registrars(:goodnames).nameservers(true).ids
|
assert_equal nameserver_hash, nameservers(:metro_ns1).reload.attributes
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_returns_new_nameserver_record
|
def test_returns_new_nameserver_record
|
||||||
|
|
|
@ -2,7 +2,7 @@ require 'test_helper'
|
||||||
|
|
||||||
class NameserverGlueRecordTest < ActiveSupport::TestCase
|
class NameserverGlueRecordTest < ActiveSupport::TestCase
|
||||||
def setup
|
def setup
|
||||||
@nameserver = nameservers(:ns1)
|
@nameserver = nameservers(:shop_ns1)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_invalid_without_ip_if_glue_record_is_required
|
def test_invalid_without_ip_if_glue_record_is_required
|
||||||
|
|
|
@ -2,7 +2,7 @@ require 'test_helper'
|
||||||
|
|
||||||
class NameserverTest < ActiveSupport::TestCase
|
class NameserverTest < ActiveSupport::TestCase
|
||||||
def setup
|
def setup
|
||||||
@nameserver = nameservers(:ns1)
|
@nameserver = nameservers(:shop_ns1)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_valid
|
def test_valid
|
||||||
|
@ -19,8 +19,22 @@ class NameserverTest < ActiveSupport::TestCase
|
||||||
assert @nameserver.invalid?
|
assert @nameserver.invalid?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_hostname_format_validation
|
||||||
|
@nameserver.hostname = 'foo_bar'
|
||||||
|
assert @nameserver.invalid?
|
||||||
|
|
||||||
|
@nameserver.hostname = 'foo.bar'
|
||||||
|
assert @nameserver.valid?
|
||||||
|
|
||||||
|
@nameserver.hostname = 'äöüõšž.ÄÖÜÕŠŽ.umlauts'
|
||||||
|
assert @nameserver.valid?
|
||||||
|
end
|
||||||
|
|
||||||
def test_hostnames
|
def test_hostnames
|
||||||
assert_equal %w[ns1.bestnames.test ns2.bestnames.test], Nameserver.hostnames
|
assert_equal %w[ns1.bestnames.test
|
||||||
|
ns2.bestnames.test
|
||||||
|
ns1.bestnames.test
|
||||||
|
ns1.bestnames.test], Nameserver.hostnames
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_normalizes_hostname
|
def test_normalizes_hostname
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue