summaryrefslogtreecommitdiffstats
path: root/modules/predict/predict.test.lua
blob: 590b41cb5ceaf73117d671210596899e4debc7c5 (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
-- SPDX-License-Identifier: GPL-3.0-or-later
-- setup resolver
modules = { 'predict' }

-- mock global functions
local resolve_count = 0
local current_epoch = 0

resolve = function ()
	resolve_count = resolve_count + 1
end

stats.frequent = function ()
	return {
		{name = 'example.com', type = 'TYPE65535'},
		{name = 'example.com', type = 'SOA'},
	}
end

predict.epoch = function ()
	return current_epoch % predict.period + 1
end

-- test if draining of prefetch queue works
local function test_predict_drain()
	resolve_count = 0
	predict.queue_len = 2
	predict.queue['TYPE65535 example.com'] = 1
	predict.queue['SOA example.com'] = 1
	predict.drain()
	-- test that it attempted to prefetch
	same(resolve_count, 2, 'attempted to prefetch on drain')
	same(predict.queue_len, 0, 'prefetch queue empty after drain')
end

-- test if prediction process works
local function test_predict_process()
	-- start new epoch
	predict.process()
	same(predict.queue_len, 0, 'first epoch, empty prefetch queue')
	-- next epoch, still no period for frequent queries
	current_epoch = current_epoch + 1
	predict.process()
	same(predict.queue_len, 0, 'second epoch, empty prefetch queue')
	-- next epoch, found period
	current_epoch = current_epoch + 1
	predict.process()
	same(predict.queue_len, 2, 'third epoch, prefetching')
	-- drain works with scheduled prefetches (two batches)
	resolve_count = 0
	predict.drain()
	predict.drain()
	same(resolve_count, 2, 'attempted to resolve queries in queue')
	same(predict.queue_len, 0, 'prefetch queue is empty')
end

-- return test set
return {
	test_predict_drain,
	test_predict_process
}