mirror of
https://github.com/internetee/registry.git
synced 2025-08-15 22:13:54 +02:00
209 lines
6.2 KiB
Ruby
209 lines
6.2 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 }
|
|
|
|
adapter = ENV["shunter_default_adapter"].constantize.new
|
|
adapter&.clear!
|
|
|
|
# Mock DNSValidator to return success
|
|
@original_validate = DNSValidator.method(:validate)
|
|
DNSValidator.define_singleton_method(:validate) { |**args| { errors: [] } }
|
|
end
|
|
|
|
def teardown
|
|
# Restore original validate method
|
|
DNSValidator.define_singleton_method(:validate, @original_validate)
|
|
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
|
|
|
|
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 = Dnskey::ALGORITHMS
|
|
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
|
|
|
|
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
|
|
|
|
def test_returns_error_response_if_throttled
|
|
ENV["shunter_default_threshold"] = '1'
|
|
ENV["shunter_enabled"] = 'true'
|
|
|
|
get "/repp/v1/domains/#{@domain.name}/dnssec", headers: @auth_headers
|
|
get "/repp/v1/domains/#{@domain.name}/dnssec", headers: @auth_headers
|
|
json = JSON.parse(response.body, symbolize_names: true)
|
|
|
|
assert_response :bad_request
|
|
assert_equal json[:code], 2502
|
|
assert response.body.include?(Shunter.default_error_message)
|
|
ENV["shunter_default_threshold"] = '10000'
|
|
ENV["shunter_enabled"] = 'false'
|
|
end
|
|
|
|
def test_validates_dns_when_adding_dnskey
|
|
ENV['DNS_VALIDATION_ENABLED'] = 'true'
|
|
|
|
# Mock successful DNS validation
|
|
DNSValidator.stub :validate, { errors: [] } do
|
|
payload = {
|
|
dns_keys: [
|
|
{ flags: '257',
|
|
alg: '8',
|
|
protocol: '3',
|
|
public_key: 'AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8' },
|
|
],
|
|
}
|
|
|
|
post "/repp/v1/domains/#{@domain.name}/dnssec", params: payload, 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]
|
|
|
|
@domain.reload
|
|
assert @domain.dnskeys.present?
|
|
dnssec_key = @domain.dnskeys.last
|
|
assert_equal 257, dnssec_key.flags
|
|
assert_equal 8, dnssec_key.alg
|
|
end
|
|
ensure
|
|
ENV.delete('DNS_VALIDATION_ENABLED')
|
|
end
|
|
|
|
def test_fails_to_add_dnskey_with_invalid_dns
|
|
ENV['DNS_VALIDATION_ENABLED'] = 'true'
|
|
|
|
# Mock DNS validation failure
|
|
DNSValidator.stub :validate, { errors: ['DNSKEY record not found in DNS'] } do
|
|
payload = {
|
|
dns_keys: [
|
|
{ flags: '257',
|
|
alg: '8',
|
|
protocol: '3',
|
|
public_key: 'AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8' },
|
|
],
|
|
}
|
|
|
|
post "/repp/v1/domains/#{@domain.name}/dnssec", params: payload, headers: @auth_headers
|
|
json = JSON.parse(response.body, symbolize_names: true)
|
|
|
|
assert_response :bad_request
|
|
assert_equal 2306, json[:code]
|
|
assert json[:message].include?('DNSKEY record not found')
|
|
|
|
@domain.reload
|
|
assert @domain.dnskeys.empty?
|
|
end
|
|
ensure
|
|
ENV.delete('DNS_VALIDATION_ENABLED')
|
|
end
|
|
end
|