internetee-registry/test/integration/repp/v1/domains/dnssec_test.rb

130 lines
3.8 KiB
Ruby

require 'test_helper'
class ReppV1DomainsDnssecTest < ActionDispatch::IntegrationTest
def setup
@user = users(:api_bestnames)
@domain = domains(:shop)
token = Base64.encode64("#{@user.username}:#{@user.plain_text_password}")
token = "Basic #{token}"
@auth_headers = { 'Authorization' => token }
Spy.on_instance_method(ValidateDnssec, :validate_dnssec).and_return(true)
end
def test_shows_dnssec_keys_associated_with_domain
get "/repp/v1/domains/#{@domain.name}/dnssec", headers: @auth_headers
json = JSON.parse(response.body, symbolize_names: true)
assert_response :ok
assert_equal 1000, json[:code]
assert_equal 'Command completed successfully', json[:message]
assert_empty json[:data][:dns_keys]
payload = {
dns_keys: [
{ flags: '256',
alg: '14',
protocol: '3',
public_key: 'dGVzdA=='
}
]
}
post "/repp/v1/domains/#{@domain.name}/dnssec", params: payload, headers: @auth_headers
json = JSON.parse(response.body, symbolize_names: true)
get "/repp/v1/domains/#{@domain.name}/dnssec", headers: @auth_headers
json = JSON.parse(response.body, symbolize_names: true)
assert_equal 1, json[:data][:dns_keys].length
end
def test_creates_dnssec_key_successfully
assert @domain.dnskeys.empty?
payload = {
dns_keys: [
{ flags: '256',
alg: '14',
protocol: '3',
public_key: 'dGVzdA=='
}
]
}
post "/repp/v1/domains/#{@domain.name}/dnssec", params: payload, headers: @auth_headers
json = JSON.parse(response.body, symbolize_names: true)
@domain.reload
assert_response :ok
assert_equal 1000, json[:code]
assert_equal 'Command completed successfully', json[:message]
assert @domain.dnskeys.present?
dnssec_key = @domain.dnskeys.last
assert_equal payload[:dns_keys][0][:flags].to_i, dnssec_key.flags
assert_equal payload[:dns_keys][0][:alg].to_i, dnssec_key.alg
assert_equal payload[:dns_keys][0][:protocol].to_i, dnssec_key.protocol
assert_equal payload[:dns_keys][0][:public_key], dnssec_key.public_key
end
def test_creates_dnssec_key_with_every_algo
algos = Depp::Dnskey::ALGORITHMS.map {|pair| pair[1].to_s}
algos_to_check = %w[15 16]
assert (algos & algos_to_check) == algos_to_check
algos.each do |alg|
assert @domain.dnskeys.empty?
payload = {
dns_keys: [
{ flags: '256',
alg: alg,
protocol: '3',
public_key: 'dGVzdA=='
}
]
}
post "/repp/v1/domains/#{@domain.name}/dnssec", params: payload, headers: @auth_headers
json = JSON.parse(response.body, symbolize_names: true)
@domain.reload
assert_response :ok
assert_equal 1000, json[:code]
assert_equal 'Command completed successfully', json[:message]
assert @domain.dnskeys.present?
dnssec_key = @domain.dnskeys.last
assert_equal payload[:dns_keys][0][:alg].to_i, dnssec_key.alg
@domain.dnskeys.destroy_all
end
end
def test_removes_existing_dnssec_key_successfully
payload = {
dns_keys: [
{ flags: '256',
alg: '14',
protocol: '3',
public_key: 'dGVzdA=='
}
]
}
post "/repp/v1/domains/#{@domain.name}/dnssec", params: payload, headers: @auth_headers
json = JSON.parse(response.body, symbolize_names: true)
assert @domain.dnskeys.any?
# Real delete here
delete "/repp/v1/domains/#{@domain.name}/dnssec", params: payload, headers: @auth_headers
json = JSON.parse(response.body, symbolize_names: true)
@domain.reload
assert_response :ok
assert_equal 1000, json[:code]
assert_equal 'Command completed successfully', json[:message]
assert @domain.dnskeys.empty?
end
end