91 lines
2 KiB
Django/Jinja
91 lines
2 KiB
Django/Jinja
-- SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
trust_anchors.remove('.')
|
|
{% for TAF in TRUST_ANCHOR_FILES %}
|
|
trust_anchors.add_file('{{TAF}}')
|
|
{% endfor %}
|
|
|
|
modules.load("hints")
|
|
hints.root({['{{ROOT_NAME}}'] = '{{ROOT_ADDR}}'})
|
|
|
|
{% raw %}
|
|
-- Disable RFC5011 TA update
|
|
if ta_update then
|
|
modules.unload('ta_update')
|
|
end
|
|
|
|
-- Disable RFC8145 signaling, scenario doesn't provide expected answers
|
|
if ta_signal_query then
|
|
modules.unload('ta_signal_query')
|
|
end
|
|
|
|
-- Disable RFC8109 priming, scenario doesn't provide expected answers
|
|
if priming then
|
|
modules.unload('priming')
|
|
end
|
|
|
|
-- Disable this module because it make one priming query
|
|
if detect_time_skew then
|
|
modules.unload('detect_time_skew')
|
|
end
|
|
|
|
log_level('debug')
|
|
policy.add(policy.all(policy.DEBUG_ALWAYS))
|
|
|
|
cache.open(1*MB)
|
|
|
|
{% endraw %}
|
|
|
|
{% if DO_IP6 == "true" %}
|
|
net.ipv6 = true
|
|
{% else %}
|
|
net.ipv6 = false
|
|
{% endif %}
|
|
|
|
{% if DO_IP4 == "true" %}
|
|
net.ipv4 = true
|
|
{% else %}
|
|
net.ipv4 = false
|
|
{% endif %}
|
|
|
|
-- both instances listen on both addresses
|
|
-- so queries get distributed between them randomly
|
|
net.listen('{{programs[0]["address"]}}')
|
|
net.listen('{{programs[1]["address"]}}')
|
|
|
|
{% raw %}
|
|
-- Self-checks on globals
|
|
assert(help() ~= nil)
|
|
assert(worker.id ~= nil)
|
|
-- Self-checks on facilities
|
|
assert(cache.stats() ~= nil)
|
|
assert(cache.backends() ~= nil)
|
|
assert(worker.stats() ~= nil)
|
|
assert(net.interfaces() ~= nil)
|
|
-- Self-checks on loaded stuff
|
|
{% endraw %}
|
|
|
|
assert(net.list()[1].transport.ip == '{{programs[0]["address"]}}')
|
|
|
|
{% raw %}
|
|
assert(#modules.list() > 0)
|
|
-- Self-check timers
|
|
ev = event.recurrent(1 * sec, function (ev) return 1 end)
|
|
event.cancel(ev)
|
|
ev = event.after(0, function (ev) return 1 end)
|
|
|
|
local ffi = require('ffi')
|
|
local kr_cach = kres.context().cache
|
|
|
|
-- canary for cache overflow
|
|
local kr_rrset = kres.rrset(
|
|
todname('www.example.com'),
|
|
kres.type.A,
|
|
kres.class.IN,
|
|
604800)
|
|
assert(kr_rrset:add_rdata('\192\000\002\001', 4))
|
|
assert(kr_cach:insert(kr_rrset, nil, ffi.C.KR_RANK_SECURE))
|
|
|
|
local generators = dofile('./dns_gen.lua')
|
|
event.after(0, generators.gen_batch)
|
|
{% endraw %}
|