From 26a0e7a3f5ba7f8d6af2d2b8d7a6acf1323e8c57 Mon Sep 17 00:00:00 2001 From: Kai Blin Date: Sun, 11 Mar 2012 00:25:57 +0100 Subject: [PATCH] s4 dns: Test deleting records and fix a small bu Autobuild-User: Kai Blin Autobuild-Date: Sun Mar 11 02:27:45 CET 2012 on sn-devel-104 --- source4/dns_server/dns_update.c | 4 +++ source4/scripting/python/samba/tests/dns.py | 39 +++++++++++++++++++++++++++++ 2 files changed, 43 insertions(+) diff --git a/source4/dns_server/dns_update.c b/source4/dns_server/dns_update.c index ca1708b060b..3d7ecce1263 100644 --- a/source4/dns_server/dns_update.c +++ b/source4/dns_server/dns_update.c @@ -628,6 +628,10 @@ static WERROR handle_one_update(struct dns_server *dns, ZERO_STRUCT(recs[i]); } } + + werror = dns_replace_records(dns, mem_ctx, dn, + needs_add, recs, rcount); + W_ERROR_NOT_OK_RETURN(werror); } return WERR_OK; diff --git a/source4/scripting/python/samba/tests/dns.py b/source4/scripting/python/samba/tests/dns.py index 8285139a923..ff973bde058 100644 --- a/source4/scripting/python/samba/tests/dns.py +++ b/source4/scripting/python/samba/tests/dns.py @@ -429,6 +429,45 @@ class DNSTest(TestCase): self.assertEquals(response.answers[0].rdata.txt, '"This is a test" "and this is a test, too"') + def test_delete_record(self): + "Test if deleting records works" + p = self.make_name_packet(dns.DNS_OPCODE_UPDATE) + updates = [] + + name = self.get_dns_domain() + + u = self.make_name_question(name, dns.DNS_QTYPE_SOA, dns.DNS_QCLASS_IN) + updates.append(u) + self.finish_name_packet(p, updates) + + updates = [] + r = dns.res_rec() + r.name = "textrec.%s" % self.get_dns_domain() + r.rr_type = dns.DNS_QTYPE_TXT + r.rr_class = dns.DNS_QCLASS_NONE + r.ttl = 0 + r.length = 0xffff + r.rdata = dns.txt_record() + r.rdata.txt = '"This is a test"' + updates.append(r) + p.nscount = len(updates) + p.nsrecs = updates + + response = self.dns_transaction_udp(p) + self.assert_dns_rcode_equals(response, dns.DNS_RCODE_OK) + + p = self.make_name_packet(dns.DNS_OPCODE_QUERY) + questions = [] + + name = "textrec.%s" % self.get_dns_domain() + q = self.make_name_question(name, dns.DNS_QTYPE_TXT, dns.DNS_QCLASS_IN) + questions.append(q) + + self.finish_name_packet(p, questions) + response = self.dns_transaction_udp(p) + self.assert_dns_rcode_equals(response, dns.DNS_RCODE_NXDOMAIN) + + if __name__ == "__main__": import unittest unittest.main() -- 2.11.4.GIT