summaryrefslogtreecommitdiffstats
path: root/tests/manager/datamodel/templates/test_forward_macros.py
blob: b4516d1d7ddabb8c5dcd98ffca0dc517d0afa54f (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
from knot_resolver_manager.manager.datamodel.forward_schema import ForwardSchema
from knot_resolver_manager.manager.datamodel.templates import template_from_str
from knot_resolver_manager.manager.datamodel.types import IPAddressOptionalPort


def test_policy_rule_forward_add():
    tmpl_str = """{% from 'macros/forward_macros.lua.j2' import policy_rule_forward_add %}
{{ policy_rule_forward_add(rule.subtree[0],rule.options,rule.servers) }}"""

    rule = ForwardSchema(
        {
            "subtree": ".",
            "servers": [{"address": ["2001:148f:fffe::1", "185.43.135.1"], "hostname": "odvr.nic.cz"}],
            "options": {
                "authoritative": False,
                "dnssec": True,
            },
        }
    )
    result = "policy.rule_forward_add('.',{dnssec=true,auth=false},{{'2001:148f:fffe::1',tls=false,hostname='odvr.nic.cz',},{'185.43.135.1',tls=false,hostname='odvr.nic.cz',},})"

    tmpl = template_from_str(tmpl_str)
    assert tmpl.render(rule=rule) == result

    rule.servers = [IPAddressOptionalPort("2001:148f:fffe::1"), IPAddressOptionalPort("185.43.135.1")]
    result = "policy.rule_forward_add('.',{dnssec=true,auth=false},{{'2001:148f:fffe::1'},{'185.43.135.1'},})"
    assert tmpl.render(rule=rule) == result