-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1297 from tgreenx/betterize-t
Betterize new unit testing framework
- Loading branch information
Showing
5 changed files
with
382 additions
and
476 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,200 +1,136 @@ | ||
use Test::More; | ||
use File::Slurp; | ||
use File::Basename; | ||
use strict; | ||
use warnings; | ||
|
||
|
||
use Test::More; | ||
use File::Basename; | ||
use File::Spec::Functions qw( rel2abs ); | ||
use lib dirname( rel2abs( $0 ) ); | ||
|
||
BEGIN { | ||
use_ok( q{Zonemaster::Engine} ); | ||
use_ok( q{Zonemaster::Engine::Nameserver} ); | ||
use_ok( q{Zonemaster::Engine::Test::DNSSEC} ); | ||
use_ok( q{Zonemaster::Engine::Util}, qw( parse_hints ) ); | ||
use_ok( q{TestUtil}, qw( perform_testcase_testing ) ); | ||
} | ||
|
||
my $checking_module = q{DNSSEC}; | ||
my $testcase = 'dnssec16'; | ||
|
||
sub zone_gives { | ||
my ( $test, $zone, $gives_ref ) = @_; | ||
Zonemaster::Engine->logger->clear_history(); | ||
my @res = grep { $_->tag !~ /^TEST_CASE_(END|START)$/ } Zonemaster::Engine->test_method( $checking_module, $test, $zone ); | ||
foreach my $gives ( @{$gives_ref} ) { | ||
ok( ( grep { $_->tag eq $gives } @res ), $zone->name->string . " gives $gives" ); | ||
} | ||
return scalar( @res ); | ||
} | ||
|
||
sub zone_gives_not { | ||
my ( $test, $zone, $gives_ref ) = @_; | ||
########### | ||
# dnssec16 - https://github.com/zonemaster/zonemaster/blob/master/docs/public/specifications/test-zones/DNSSEC-TP/dnssec16.md | ||
my $test_module = q{DNSSEC}; | ||
my $test_case = 'dnssec16'; | ||
|
||
Zonemaster::Engine->logger->clear_history(); | ||
my @res = grep { $_->tag !~ /^TEST_CASE_(END|START)$/ } Zonemaster::Engine->test_method( $checking_module, $test, $zone ); | ||
foreach my $gives ( @{$gives_ref} ) { | ||
ok( !( grep { $_->tag eq $gives } @res ), $zone->name->string . " does not give $gives" ); | ||
# Common hint file (test-zone-data/COMMON/hintfile) | ||
Zonemaster::Engine::Recursor->remove_fake_addresses( '.' ); | ||
Zonemaster::Engine::Recursor->add_fake_addresses( '.', | ||
{ 'ns1' => [ '127.1.0.1', 'fda1:b2:c3::127:1:0:1' ], | ||
'ns2' => [ '127.1.0.2', 'fda1:b2:c3::127:1:0:2' ], | ||
} | ||
return scalar( @res ); | ||
} | ||
); | ||
|
||
# Test zone scenarios | ||
# - Documentation: L<TestUtil/perform_testcase_testing()> | ||
# - Format: { SCENARIO_NAME => [ zone_name, [ MANDATORY_MESSAGE_TAGS ], [ FORBIDDEN_MESSAGE_TAGS ], testable ] } | ||
my %subtests = ( | ||
'CDS-INVALID-RRSIG' => [ | ||
q(cds-invalid-rrsig.dnssec16.xa), | ||
[ qw(DS16_CDS_INVALID_RRSIG) ], | ||
[ qw(DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CD) ], | ||
1, | ||
], | ||
'CDS-MATCHES-NO-DNSKEY' => [ | ||
q(cds-matches-no-dnskey.dnssec16.xa), | ||
[ qw(DS16_CDS_MATCHES_NO_DNSKEY) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1, | ||
], | ||
'CDS-MATCHES-NON-SEP-DNSKEY' => [ | ||
q(cds-matches-non-sep-dnskey.dnssec16.xa), | ||
[ qw(DS16_CDS_MATCHES_NON_SEP_DNSKEY) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'CDS-MATCHES-NON-ZONE-DNSKEY' => [ | ||
q(cds-matches-non-zone-dnskey.dnssec16.xa), | ||
[ qw(DS16_CDS_MATCHES_NON_ZONE_DNSKEY) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'CDS-NOT-SIGNED-BY-CDS' => [ | ||
q(cds-not-signed-by-cds.dnssec16.xa), | ||
[ qw(DS16_CDS_NOT_SIGNED_BY_CDS) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'CDS-SIGNED-BY-UNKNOWN-DNSKEY' => [ | ||
q(cds-signed-by-unknown-dnskey.dnssec16.xa), | ||
[ qw(DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'CDS-UNSIGNED' => [ | ||
q(cds-unsigned.dnssec16.xa), | ||
[ qw(DS16_CDS_UNSIGNED DS16_CDS_NOT_SIGNED_BY_CDS) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'CDS-WITHOUT-DNSKEY' => [ | ||
q(cds-without-dnskey.dnssec16.xa), | ||
[ qw(DS16_CDS_WITHOUT_DNSKEY) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'DELETE-CDS' => [ | ||
q(delete-cds.dnssec16.xa), | ||
[ qw(DS16_DELETE_CDS) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'DNSKEY-NOT-SIGNED-BY-CDS' => [ | ||
q(dnskey-not-signed-by-cds.dnssec16.xa), | ||
[ qw(DS16_DNSKEY_NOT_SIGNED_BY_CDS) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'MIXED-DELETE-CDS' => [ | ||
q(mixed-delete-cds.dnssec16.xa), | ||
[ qw(DS16_MIXED_DELETE_CDS) ], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS) ], | ||
1 | ||
], | ||
'NO-CDS' => [ | ||
q(no-cds.dnssec16.xa), | ||
[], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'NOT-AA' => [ | ||
q(not-aa.dnssec16.xa), | ||
[], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
], | ||
'VALID-CDS' => [ | ||
q(valid-cds.dnssec16.xa), | ||
[], | ||
[ qw(DS16_CDS_INVALID_RRSIG DS16_CDS_MATCHES_NON_SEP_DNSKEY DS16_CDS_MATCHES_NON_ZONE_DNSKEY DS16_CDS_MATCHES_NO_DNSKEY DS16_CDS_NOT_SIGNED_BY_CDS DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY DS16_CDS_UNSIGNED DS16_CDS_WITHOUT_DNSKEY DS16_DELETE_CDS DS16_DNSKEY_NOT_SIGNED_BY_CDS DS16_MIXED_DELETE_CDS) ], | ||
1 | ||
] | ||
); | ||
########### | ||
|
||
my $datafile = 't/' . basename ($0, '.t') . '.data'; | ||
|
||
if ( not $ENV{ZONEMASTER_RECORD} ) { | ||
die q{Stored data file missing} if not -r $datafile; | ||
Zonemaster::Engine::Nameserver->restore( $datafile ); | ||
Zonemaster::Engine::Profile->effective->set( q{no_network}, 1 ); | ||
} | ||
|
||
# Common hint file (test-zone-data/COMMON/hintfile) | ||
my $hints; | ||
{ | ||
$hints = <<EOF, | ||
. 3600000 NS ns1. | ||
ns1. 3600000 A 127.1.0.1 | ||
ns1. 3600000 AAAA fda1:b2:c3::127:1:0:1 | ||
; | ||
. 3600000 NS ns2. | ||
ns2. 3600000 A 127.1.0.2 | ||
ns2. 3600000 AAAA fda1:b2:c3::127:1:0:2 | ||
EOF | ||
|
||
}; | ||
my $hints_data = parse_hints( $hints); | ||
Zonemaster::Engine::Recursor->remove_fake_addresses( '.' ); | ||
Zonemaster::Engine::Recursor->add_fake_addresses( '.', $hints_data ); | ||
|
||
########### | ||
# DNSSEC16 | ||
########### | ||
|
||
my ($json, $profile_test); | ||
$json = qq({ "test_cases": [ "$testcase" ] }); | ||
$profile_test = Zonemaster::Engine::Profile->from_json( $json ); | ||
Zonemaster::Engine::Profile->effective->merge( $profile_test ); | ||
|
||
my $blockline = 0; | ||
my ($zonename, @gives, @gives_not); | ||
while (my $line = <DATA>) { | ||
chomp($line); | ||
next if $line =~ /^#/; | ||
next if ($blockline == 0 and $line eq ''); | ||
if ($blockline == 3 and $line eq '') { | ||
$blockline = 0; | ||
next; | ||
}; | ||
if ($blockline == 0) { | ||
$zonename = $line; | ||
$blockline = 1; | ||
next; | ||
}; | ||
if ($blockline == 1) { | ||
if ($line eq '(none)') { | ||
@gives = (); | ||
} else { | ||
$line =~ s/ *, */ /g; | ||
@gives = split (/ +/, $line); | ||
} | ||
$blockline = 2; | ||
next; | ||
}; | ||
if ($blockline == 2) { | ||
if ($line eq '(none)') { | ||
@gives_not = (); | ||
} else { | ||
$line =~ s/ *, */ /g; | ||
@gives_not = split (/ +/, $line); | ||
} | ||
|
||
my $zone = Zonemaster::Engine->zone( $zonename ); | ||
zone_gives( $testcase, $zone, \@gives ) if scalar @gives; | ||
zone_gives_not( $testcase, $zone, \@gives_not ) if scalar @gives_not; | ||
$blockline = 3; | ||
$zonename = ''; | ||
@gives = ''; | ||
@gives_not = ''; | ||
next; | ||
}; | ||
die "Error in data section"; | ||
}; | ||
Zonemaster::Engine::Profile->effective->merge( Zonemaster::Engine::Profile->from_json( qq({ "test_cases": [ "$test_case" ] }) ) ); | ||
|
||
perform_testcase_testing( $test_case, $test_module, %subtests ); | ||
|
||
if ( $ENV{ZONEMASTER_RECORD} ) { | ||
Zonemaster::Engine::Nameserver->save( $datafile ); | ||
} | ||
|
||
Zonemaster::Engine::Profile->effective->set( q{no_network}, 0 ); | ||
Zonemaster::Engine::Profile->effective->set( q{net.ipv4}, 0 ); | ||
Zonemaster::Engine::Profile->effective->set( q{net.ipv6}, 0 ); | ||
|
||
TODO: { | ||
local $TODO = "Nothing"; | ||
} | ||
|
||
done_testing; | ||
|
||
|
||
# In that __DATA__ section each test is a block consisting of three lines: | ||
# 1 Zone name | ||
# 2 Tags tag "gives" | ||
# 3 Tags that "gives not" | ||
# | ||
# If tag line is "(none)" than it should be ignored. | ||
# | ||
# Empty lines between blocks. Lines with "#" in column one are ignored (comments); | ||
|
||
|
||
__DATA__ | ||
cds-invalid-rrsig.dnssec16.xa | ||
DS16_CDS_INVALID_RRSIG | ||
DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
cds-matches-no-dnskey.dnssec16.xa | ||
DS16_CDS_MATCHES_NO_DNSKEY | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
cds-matches-non-sep-dnskey.dnssec16.xa | ||
DS16_CDS_MATCHES_NON_SEP_DNSKEY | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
cds-matches-non-zone-dnskey.dnssec16.xa | ||
DS16_CDS_MATCHES_NON_ZONE_DNSKEY | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
cds-not-signed-by-cds.dnssec16.xa | ||
DS16_CDS_NOT_SIGNED_BY_CDS | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
cds-signed-by-unknown-dnskey.dnssec16.xa | ||
DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
cds-unsigned.dnssec16.xa | ||
DS16_CDS_UNSIGNED, DS16_CDS_NOT_SIGNED_BY_CDS | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
cds-without-dnskey.dnssec16.xa | ||
DS16_CDS_WITHOUT_DNSKEY | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
delete-cds.dnssec16.xa | ||
DS16_DELETE_CDS | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
dnskey-not-signed-by-cds.dnssec16.xa | ||
DS16_DNSKEY_NOT_SIGNED_BY_CDS | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_MIXED_DELETE_CDS | ||
mixed-delete-cds.dnssec16.xa | ||
DS16_MIXED_DELETE_CDS | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS | ||
no-cds.dnssec16.xa | ||
(none) | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
not-aa.dnssec16.xa | ||
(none) | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
valid-cds.dnssec16.xa | ||
(none) | ||
DS16_CDS_INVALID_RRSIG, DS16_CDS_MATCHES_NON_SEP_DNSKEY, DS16_CDS_MATCHES_NON_ZONE_DNSKEY, DS16_CDS_MATCHES_NO_DNSKEY, DS16_CDS_NOT_SIGNED_BY_CDS, DS16_CDS_SIGNED_BY_UNKNOWN_DNSKEY, DS16_CDS_UNSIGNED, DS16_CDS_WITHOUT_DNSKEY, DS16_DELETE_CDS, DS16_DNSKEY_NOT_SIGNED_BY_CDS, DS16_MIXED_DELETE_CDS | ||
# Always an empty line after the last block |
Oops, something went wrong.