mirror of
https://github.com/isc-projects/bind9.git
synced 2026-03-24 19:35:00 -04:00
The old name "common" clashes with the convention of system test directory naming. It appears as a system test directory, but it only contains helper files. To reduce confusion and to allow automatic detection of issues with possibly missing test files, rename the helper directory to "_common". The leading underscore indicates the directory is different and the its name can no longer be confused with regular system test directories.
79 lines
2.5 KiB
Python
79 lines
2.5 KiB
Python
# 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
|