Merge branch 'mnowak/pytest_rewrite_stress-9.18' into 'bind-9.18'

[9.18] Rewrite stress test to pytest

See merge request isc-projects/bind9!8182
This commit is contained in:
Michal Nowak
2023-08-08 13:08:29 +00:00
12 changed files with 188 additions and 303 deletions

View File

@@ -11,14 +11,8 @@
# See the COPYRIGHT file distributed with this work for additional
# information regarding copyright ownership.
rm -f reload.pid
rm -f ns?/zones.conf
rm -f ns?/zone*.bk
rm -f ns1/delegations.db
rm -f ns1/root.db
rm -f ns2/zone0*.db
rm -f ns2/zone0*.jnl
rm -f */named.memstats

View File

@@ -1,32 +0,0 @@
/*
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
*
* SPDX-License-Identifier: MPL-2.0
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, you can obtain one at https://mozilla.org/MPL/2.0/.
*
* See the COPYRIGHT file distributed with this work for additional
* information regarding copyright ownership.
*/
controls { /* empty */ };
options {
query-source address 10.53.0.1;
notify-source 10.53.0.1;
transfer-source 10.53.0.1;
port @PORT@;
pid-file "named.pid";
listen-on { 10.53.0.1; };
listen-on-v6 { none; };
recursion no;
dnssec-validation no;
notify yes;
};
zone "." {
type primary;
file "root.db";
};

View File

@@ -26,9 +26,32 @@ options {
notify yes;
};
zone "." {
type hint;
file "../../common/root.hint";
zone "zone000000.example" {
type primary;
allow-update { any; };
file "zone000000.example.db";
};
include "zones.conf";
zone "zone000001.example" {
type primary;
allow-update { any; };
file "zone000001.example.db";
};
zone "zone000002.example" {
type primary;
allow-update { any; };
file "zone000002.example.db";
};
zone "zone000003.example" {
type primary;
allow-update { any; };
file "zone000003.example.db";
};
zone "zone000004.example" {
type primary;
allow-update { any; };
file "zone000004.example.db";
};

View File

@@ -0,0 +1,21 @@
; Copyright (C) Internet Systems Consortium, Inc. ("ISC")
;
; SPDX-License-Identifier: MPL-2.0
;
; This Source Code Form is subject to the terms of the Mozilla Public
; License, v. 2.0. If a copy of the MPL was not distributed with this
; file, you can obtain one at https://mozilla.org/MPL/2.0/.
;
; See the COPYRIGHT file distributed with this work for additional
; information regarding copyright ownership.
$TTL 300
@ IN SOA ns2 hostmaster 1 300 120 3600 86400
@ NS ns2
NS ns3
NS ns4
ns2 A 10.53.0.2
ns3 A 10.53.0.3
ns4 A 10.53.0.4
$GENERATE 0-999 name${0,6} A 10.0.0.1

View File

@@ -35,16 +35,40 @@ controls {
inet 10.53.0.3 port @CONTROLPORT@ allow { any; } keys { rndc_key; };
};
zone "." {
type hint;
file "../../common/root.hint";
};
server 10.53.0.4 {
provide-ixfr no;
};
server 10.53.0.2 {
request-ixfr no;
};
include "zones.conf";
zone "zone000000.example" {
type secondary;
file "zone000000.example.bk";
primaries { 10.53.0.2; };
};
zone "zone000001.example" {
type secondary;
file "zone000001.example.bk";
primaries { 10.53.0.2; };
};
zone "zone000002.example" {
type secondary;
file "zone000002.example.bk";
primaries { 10.53.0.2; };
};
zone "zone000003.example" {
type secondary;
file "zone000003.example.bk";
primaries { 10.53.0.2; };
};
zone "zone000004.example" {
type secondary;
file "zone000004.example.bk";
primaries { 10.53.0.2; };
};

View File

@@ -26,10 +26,32 @@ options {
notify yes;
};
zone "." {
type hint;
file "../../common/root.hint";
zone "zone000000.example" {
type secondary;
file "zone000000.example.bk";
primaries { 10.53.0.3; };
};
include "zones.conf";
zone "zone000001.example" {
type secondary;
file "zone000001.example.bk";
primaries { 10.53.0.3; };
};
zone "zone000002.example" {
type secondary;
file "zone000002.example.bk";
primaries { 10.53.0.3; };
};
zone "zone000003.example" {
type secondary;
file "zone000003.example.bk";
primaries { 10.53.0.3; };
};
zone "zone000004.example" {
type secondary;
file "zone000004.example.bk";
primaries { 10.53.0.3; };
};

View File

@@ -1,86 +0,0 @@
#!/usr/bin/perl
# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
#
# SPDX-License-Identifier: MPL-2.0
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, you can obtain one at https://mozilla.org/MPL/2.0/.
#
# See the COPYRIGHT file distributed with this work for additional
# information regarding copyright ownership.
#
# Set up test data for zone transfer quota tests.
#
use FileHandle;
my $n_zones = 5;
my $n_names = 1000;
make_zones(2, undef);
make_zones(3, "10.53.0.2");
make_zones(4, "10.53.0.3");
my $rootdelegations =
new FileHandle("ns1/root.db", "w") or die;
print $rootdelegations <<END;
\$TTL 300
. IN SOA gson.nominum.com. a.root.servers.nil. (
2000042100 ; serial
600 ; refresh
600 ; retry
1200 ; expire
600 ; minimum
)
. NS a.root-servers.nil.
a.root-servers.nil. A 10.53.0.1
END
for ($z = 0; $z < $n_zones; $z++) {
my $zn = sprintf("zone%06d.example", $z);
foreach $ns (qw(2 3 4)) {
print $rootdelegations "$zn. NS ns$ns.$zn.\n";
print $rootdelegations "ns$ns.$zn. A 10.53.0.$ns\n";
}
}
close $rootdelegations;
sub make_zones {
my ($nsno, $secondaried_from) = @_;
my $namedconf = new FileHandle("ns$nsno/zones.conf", "w") or die;
for ($z = 0; $z < $n_zones; $z++) {
my $zn = sprintf("zone%06d.example", $z);
if (defined($secondaried_from)) {
print $namedconf "zone \"$zn\" { type secondary; " .
"file \"$zn.bk\"; primaries " .
"{ $secondaried_from; }; };\n";
} else {
print $namedconf "zone \"$zn\" { " .
"type primary; " .
"allow-update { any; }; " .
"file \"$zn.db\"; };\n";
my $fn = "ns$nsno/$zn.db";
my $f = new FileHandle($fn, "w") or die "open: $fn: $!";
print $f "\$TTL 300
\@ IN SOA ns2.$zn. hostmaster 1 300 120 3600 86400
@ NS ns2.$zn.
ns2.$zn. A 10.53.0.2
@ NS ns3.$zn.
ns3.$zn. A 10.53.0.3
@ NS ns4.$zn.
ns4.$zn. A 10.53.0.4
MX 10 mail1.isp.example.
MX 20 mail2.isp.example.
";
for ($i = 0; $i < $n_names; $i++) {
print $f sprintf("name%06d", $i) .
" A 10.0.0.1\n";
}
$f->close;
}
}
}

View File

@@ -14,13 +14,12 @@
# shellcheck source=conf.sh
. ../conf.sh
#
# Set up test data for zone transfer quota tests.
#
cp ns2/zone.template.db ns2/zone000000.example.db
cp ns2/zone.template.db ns2/zone000001.example.db
cp ns2/zone.template.db ns2/zone000002.example.db
cp ns2/zone.template.db ns2/zone000003.example.db
cp ns2/zone.template.db ns2/zone000004.example.db
$PERL setup.pl
copy_setports ns1/named.conf.in ns1/named.conf
copy_setports ns2/named.conf.in ns2/named.conf
copy_setports ns3/named.conf.in ns3/named.conf
copy_setports ns4/named.conf.in ns4/named.conf

View File

@@ -1,44 +0,0 @@
#!/bin/sh
# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
#
# SPDX-License-Identifier: MPL-2.0
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, you can obtain one at https://mozilla.org/MPL/2.0/.
#
# See the COPYRIGHT file distributed with this work for additional
# information regarding copyright ownership.
set -e
. ../conf.sh
status=0
(
$SHELL -c "while true
do $RNDC -c ../common/rndc.conf -s 10.53.0.3 -p $CONTROLPORT reload 2>&1 |
sed 's/^/I:ns3 /';
sleep 1
done" & echo $! >reload.pid
) &
for i in 0 1 2 3 4
do
$PERL update.pl -s 10.53.0.2 -p $PORT zone00000$i.example. &
done
echo_i "waiting for background processes to finish"
wait
echo_i "killing reload loop"
kill $(cat reload.pid)
# If the test has run to completion without named crashing, it has succeeded.
# Otherwise, the crash will be detected by the test framework and the test will
# fail.
echo_i "exit status: $status"
[ $status -eq 0 ] || exit 1

View File

@@ -1,14 +0,0 @@
# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
#
# SPDX-License-Identifier: MPL-2.0
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, you can obtain one at https://mozilla.org/MPL/2.0/.
#
# See the COPYRIGHT file distributed with this work for additional
# information regarding copyright ownership.
def test_stress(run_tests_sh):
run_tests_sh()

View File

@@ -0,0 +1,79 @@
# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
#
# SPDX-License-Identifier: MPL-2.0
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, you can obtain one at https://mozilla.org/MPL/2.0/.
#
# See the COPYRIGHT file distributed with this work for additional
# information regarding copyright ownership.
import concurrent.futures
import os
import subprocess
import time
import dns.query
import dns.update
def rndc_loop(test_state, server):
rndc = os.getenv("RNDC")
port = os.getenv("CONTROLPORT")
cmdline = [
rndc,
"-c",
"../common/rndc.conf",
"-p",
port,
"-s",
server,
"reload",
]
while not test_state["finished"]:
subprocess.run(cmdline, check=False)
time.sleep(1)
def update_zone(test_state, zone, named_port, logger):
server = "10.53.0.2"
for i in range(1000):
if test_state["finished"]:
return
update = dns.update.UpdateMessage(zone)
update.add(f"dynamic-{i}.{zone}", 300, "TXT", f"txt-{i}")
try:
response = dns.query.udp(update, server, 10, named_port)
assert response.rcode() == dns.rcode.NOERROR
except dns.exception.Timeout:
logger.info(f"error: query timeout for {zone}")
logger.info(f"Update of {server} zone {zone} successful")
# If the test has run to completion without named crashing, it has succeeded.
def test_update_stress(named_port, logger):
test_state = {"finished": False}
with concurrent.futures.ThreadPoolExecutor() as executor:
executor.submit(rndc_loop, test_state, "10.53.0.3")
updaters = []
for i in range(5):
zone = f"zone00000{i}.example."
updaters.append(
executor.submit(update_zone, test_state, zone, named_port, logger)
)
# All the update_zone() tasks are expected to complete within 5
# minutes. If they do not, we cannot assert immediately as that will
# cause the ThreadPoolExecutor context manager to wait indefinitely;
# instead, we first signal all tasks that it is time to exit and only
# check whether any task failed to finish within 5 minutes outside of
# the ThreadPoolExecutor context manager.
unfinished_tasks = concurrent.futures.wait(updaters, timeout=300).not_done
test_state["finished"] = True
assert not unfinished_tasks

View File

@@ -1,101 +0,0 @@
#!/usr/bin/perl
# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
#
# SPDX-License-Identifier: MPL-2.0
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, you can obtain one at https://mozilla.org/MPL/2.0/.
#
# See the COPYRIGHT file distributed with this work for additional
# information regarding copyright ownership.
#
# Dynamic update test suite.
#
# Usage:
#
# perl update_test.pl [-s server] [-p port] zone
#
# The server defaults to 127.0.0.1.
# The port defaults to 53.
#
# The "Special NS rules" tests will only work correctly if the
# has no NS records to begin with, or alternatively has a
# single NS record pointing at the name "ns1" (relative to
# the zone name).
#
# Installation notes:
#
# This program uses the Net::DNS::Resolver module.
# You can install it by saying
#
# perl -MCPAN -e "install Net::DNS"
#
use Getopt::Std;
use Net::DNS;
use Net::DNS::Update;
use Net::DNS::Resolver;
$opt_s = "127.0.0.1";
$opt_p = 53;
getopt('s:p:');
$res = new Net::DNS::Resolver;
$res->nameservers($opt_s);
$res->port($opt_p);
$res->defnames(0); # Do not append default domain.
@ARGV == 1 or die
"usage: perl update_test.pl [-s server] [-p port] zone\n";
$zone = shift @ARGV;
my $failures = 0;
sub assert {
my ($cond, $explanation) = @_;
if (!$cond) {
print "I:Test Failed: $explanation ***\n";
$failures++
}
}
sub test {
my ($expected, @records) = @_;
my $update = new Net::DNS::Update("$zone");
foreach $rec (@records) {
$update->push(@$rec);
}
$reply = $res->send($update);
# Did it work?
if (defined $reply) {
my $rcode = $reply->header->rcode;
assert($rcode eq $expected, "expected $expected, got $rcode");
} else {
print "I:Update failed: ", $res->errorstring, "\n";
}
}
sub section {
my ($msg) = @_;
print "I:$msg\n";
}
for ($i = 0; $i < 1000; $i++) {
test("NOERROR", ["update", rr_add("dynamic-$i.$zone 300 TXT txt-$i" )]);
}
if ($failures) {
print "I:$failures tests failed.\n";
} else {
print "I:Update of $opt_s zone $zone successful.\n";
}
exit $failures;