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:
@@ -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
|
||||
|
||||
@@ -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";
|
||||
};
|
||||
@@ -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";
|
||||
};
|
||||
|
||||
21
bin/tests/system/stress/ns2/zone.template.db
Normal file
21
bin/tests/system/stress/ns2/zone.template.db
Normal 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
|
||||
@@ -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; };
|
||||
};
|
||||
|
||||
@@ -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; };
|
||||
};
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
@@ -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()
|
||||
79
bin/tests/system/stress/tests_stress_update.py
Normal file
79
bin/tests/system/stress/tests_stress_update.py
Normal 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
|
||||
@@ -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;
|
||||
Reference in New Issue
Block a user