-def set_nameserver(t, nameserver):
- '''set the nameserver in resolv.conf'''
- if not getattr(t, 'resolv_conf_backup', False):
- t.run_cmd("mv -f /etc/resolv.conf /etc/resolv.conf.wintest-bak")
- t.write_file("/etc/resolv.conf", '''
-# Generated by wintest, the Samba v Windows automated testing system
-nameserver %s
-
-# your original resolv.conf appears below:
-
-''' % t.substitute(nameserver))
- t.run_cmd('cat /etc/resolv.conf.wintest-bak >> /etc/resolv.conf')
- t.resolv_conf_backup = '/etc/resolv.conf.wintest-bak';
-
-
-def restore_resolv_conf(t):
- '''restore the /etc/resolv.conf after testing is complete'''
- if getattr(t, 'resolv_conf_backup', False):
- t.info("restoring /etc/resolv.conf")
- t.run_cmd("mv -f %s /etc/resolv.conf" % t.resolv_conf_backup)
-
-def rndc_cmd(t, cmd, checkfail=True):
- '''run a rndc command'''
- t.run_cmd("${RNDC} -c ${PREFIX}/etc/rndc.conf %s" % cmd, checkfail=checkfail)
-
-
-def restart_bind(t):
- '''restart the test environment version of bind'''
- t.info("Restarting bind9")
- t.putenv('KEYTAB_FILE', '${PREFIX}/private/dns.keytab')
- t.putenv('KRB5_KTNAME', '${PREFIX}/private/dns.keytab')
- t.chdir('${PREFIX}')
- t.run_cmd("mkdir -p var/named/data")
- t.run_cmd("chown -R ${BIND_USER} var/named")
-
- nameserver = t.get_nameserver()
- if nameserver == t.getvar('INTERFACE_IP'):
- raise RuntimeError("old /etc/resolv.conf must not contain %s as a nameserver, this will create loops with the generated dns configuration")
- t.setvar('DNSSERVER', nameserver)
-
- t.write_file("etc/named.conf", '''
-options {
- listen-on port 53 { ${INTERFACE_IP}; };
- directory "${PREFIX}/var/named";
- dump-file "${PREFIX}/var/named/data/cache_dump.db";
- pid-file "${PREFIX}/var/named/named.pid";
- statistics-file "${PREFIX}/var/named/data/named_stats.txt";
- memstatistics-file "${PREFIX}/var/named/data/named_mem_stats.txt";
- allow-query { ${INTERFACE_NET}; 127.0.0.0/8; };
- recursion yes;
- tkey-gssapi-credential "DNS/${LCREALM}";
- tkey-domain "${REALM}";
-
- forward only;
- forwarders {
- ${DNSSERVER};
- };
-
-};
-
-key "rndc-key" {
- algorithm hmac-md5;
- secret "lA/cTrno03mt5Ju17ybEYw==";
-};
-
-controls {
- inet ${INTERFACE_IP} port 953
- allow { 127.0.0.0/8; ${INTERFACE_NET}; } keys { "rndc-key"; };
-};
-
-include "${PREFIX}/private/named.conf";
-''')
-
- # add forwarding for the windows domains
- domains = t.get_domains()
- for d in domains:
- t.write_file('etc/named.conf',
- '''
-zone "%s" IN {
- type forward;
- forward only;
- forwarders {
- %s;
- };
-};
-''' % (d, domains[d]),
- mode='a')
-
-
- t.write_file("etc/rndc.conf", '''
-# Start of rndc.conf
-key "rndc-key" {
- algorithm hmac-md5;
- secret "lA/cTrno03mt5Ju17ybEYw==";
-};
-
-options {
- default-key "rndc-key";
- default-server ${INTERFACE_IP};
- default-port 953;
-};
-''')
-
- set_nameserver(t, t.getvar('INTERFACE_IP'))
-
- rndc_cmd(t, "stop", checkfail=False)
- t.port_wait("${INTERFACE_IP}", 53, wait_for_fail=True)
- t.bind_child = t.run_child("${BIND9} -u ${BIND_USER} -n 1 -c ${PREFIX}/etc/named.conf -g")
-
- t.port_wait("${INTERFACE_IP}", 53)
- rndc_cmd(t, "flush")
-
-