feat: add full Zonemaster stack with Docker and Spanish UI
- Clone all 5 Zonemaster component repos (LDNS, Engine, CLI, Backend, GUI) - Dockerfile.backend: 8-stage multi-stage build LDNS→Engine→CLI→Backend - Dockerfile.gui: Astro static build served via nginx - docker-compose.yml: backend (internal) + frontend (port 5353) - nginx.conf: root redirects to /es/, /api/ proxied to backend - zonemaster-gui/config.ts: defaultLanguage set to 'es' (Spanish) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
74
zonemaster-engine/t/Test-connectivity03.t
Normal file
74
zonemaster-engine/t/Test-connectivity03.t
Normal file
@@ -0,0 +1,74 @@
|
||||
use Test::More;
|
||||
use File::Slurp;
|
||||
use File::Basename;
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
BEGIN {
|
||||
use_ok( q{Zonemaster::Engine} );
|
||||
use_ok( q{Zonemaster::Engine::Nameserver} );
|
||||
use_ok( q{Zonemaster::Engine::Test::Connectivity} );
|
||||
use_ok( q{Zonemaster::Engine::Util} );
|
||||
}
|
||||
|
||||
my $checking_module = q{Connectivity};
|
||||
my $testcase = 'connectivity03';
|
||||
my $datafile = 't/' . basename ($0, '.t') . '.data';
|
||||
|
||||
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 ) = @_;
|
||||
|
||||
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" );
|
||||
}
|
||||
return scalar( @res );
|
||||
}
|
||||
|
||||
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 );
|
||||
}
|
||||
|
||||
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 $zone = Zonemaster::Engine->zone( q{001.tf} );
|
||||
zone_gives( $testcase, $zone, [qw{IPV4_ONE_ASN IPV6_ONE_ASN}] );
|
||||
zone_gives_not( $testcase, $zone, [qw{EMPTY_ASN_SET ERROR_ASN_DATABASE IPV4_DIFFERENT_ASN IPV4_SAME_ASN IPV6_DIFFERENT_ASN IPV6_SAME_ASN}] );
|
||||
|
||||
$zone = Zonemaster::Engine->zone( q{zonemaster.net} );
|
||||
zone_gives( $testcase, $zone, [qw{IPV4_DIFFERENT_ASN IPV6_DIFFERENT_ASN}] );
|
||||
zone_gives_not( $testcase, $zone, [qw{EMPTY_ASN_SET ERROR_ASN_DATABASE IPV4_SAME_ASN IPV6_SAME_ASN IPV4_ONE_ASN IPV6_ONE_ASN}] );
|
||||
|
||||
$zone = Zonemaster::Engine->zone( q{zut-root.rd.nic.fr} );
|
||||
zone_gives( $testcase, $zone, [qw{IPV4_ONE_ASN}] );
|
||||
zone_gives_not( $testcase, $zone, [qw{EMPTY_ASN_SET ERROR_ASN_DATABASE IPV4_DIFFERENT_ASN IPV4_SAME_ASN IPV6_DIFFERENT_ASN IPV6_ONE_ASN IPV6_SAME_ASN}] );
|
||||
|
||||
TODO: {
|
||||
my @missing = qw( EMPTY_ASN_SET ERROR_ASN_DATABASE IPV4_SAME_ASN IPV6_SAME_ASN );
|
||||
local $TODO = "Need to find/create zones with those errors: ";
|
||||
warn $TODO, "\n\t", join("\n\t", @missing), "\n";
|
||||
}
|
||||
###
|
||||
|
||||
if ( $ENV{ZONEMASTER_RECORD} ) {
|
||||
Zonemaster::Engine::Nameserver->save( $datafile );
|
||||
}
|
||||
|
||||
done_testing;
|
||||
Reference in New Issue
Block a user