summaryrefslogtreecommitdiffstats
path: root/modules/stats/test.integr/kresd_config.j2
blob: 872ce2e391139938a6e12ec6d2e0622f9a8ff638 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
-- SPDX-License-Identifier: GPL-3.0-or-later
local ffi = require('ffi')

{% raw %}
modules.load('stats')

FWD_TARGET = policy.FORWARD('192.0.2.1')

function check_stats(got)
	log_info(ffi.C.LOG_GRP_TESTS, 'checking if stat values match expected values:')
	local expected = {
		['answer.cd'] = 2,
		['answer.cached'] = 1,
		['answer.nodata'] = 1,
		['answer.noerror'] = 2,
		['answer.nxdomain'] = 1,
		['answer.servfail'] = 2,
		['answer.edns0'] = 6,
		['answer.ra'] = 6,
		['answer.rd'] = 5,
		['answer.do'] = 1,
		['answer.ad'] = 0,
		['answer.tc'] = 0,
		['answer.aa'] = 0,
		['answer.total'] = 6
	}
	print(table_print(expected))

	local ok = true
	for key, expval in pairs(expected) do
		if got[key] ~= expval then
			log_info(ffi.C.LOG_GRP_TESTS,
			    'ERROR: stats key ' .. key
			    .. ' has unexpected value'
			    .. ' (expected ' .. tostring(expval)
			    .. ' got ' .. tostring(got[key] .. ')'))
			ok = false
		end
	end
	if ok then
		log_info(ffi.C.LOG_GRP_TESTS, 'no problem found')
		return FWD_TARGET
	else
		return policy.DENY_MSG('Stats test failure')
	end
end

function reply_result(state, req)
	local got = stats.list()
	log_info(ffi.C.LOG_GRP_TESTS, 'current stats.list() values:')
	print(table_print(got))
	local result = check_stats(got)
	return result(state, req)
end
policy.add(policy.all(policy.FLAGS('PASSTHRU_LEGACY'))) -- the test isn't written with this in mind
policy.add(policy.pattern(reply_result, 'stats.test.'))
policy.add(policy.all(FWD_TARGET)) -- avoid iteration

-- make sure DNSSEC is turned off for tests
trust_anchors.remove('.')

-- Enable queries without RD bit
pcall(modules.unload, 'refuse_nord')

-- 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

_hint_root_file('hints')
cache.size = 2*MB
log_level('debug')
{% endraw %}

net = { '{{SELF_ADDR}}' }


{% if QMIN == "false" %}
option('NO_MINIMIZE', true)
{% else %}
option('NO_MINIMIZE', false)
{% endif %}


-- Self-checks on globals
assert(help() ~= nil)
assert(worker.id ~= nil)
-- Self-checks on facilities
assert(cache.count() == 0)
assert(cache.stats() ~= nil)
assert(cache.backends() ~= nil)
assert(worker.stats() ~= nil)
assert(net.interfaces() ~= nil)
-- Self-checks on loaded stuff
assert(net.list()[1].transport.ip == '{{SELF_ADDR}}')
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)