mirror of
https://github.com/samba-team/samba.git
synced 2025-01-22 22:04:08 +03:00
s4-selftest: Add tests for RPC dnsserver
Signed-off-by: Andrew Tridgell <tridge@samba.org>
This commit is contained in:
parent
b619705c22
commit
7ca0bed38d
@ -557,6 +557,7 @@ sub provision_raw_prepare($$$$$$$$$$)
|
||||
push (@provision_options, "--root=$ctx->{unix_name}");
|
||||
push (@provision_options, "--server-role=\"$ctx->{server_role}\"");
|
||||
push (@provision_options, "--function-level=\"$ctx->{functional_level}\"");
|
||||
push (@provision_options, "--dns-backend=BIND9_DLZ");
|
||||
|
||||
@{$ctx->{provision_options}} = @provision_options;
|
||||
|
||||
|
181
source4/scripting/python/samba/tests/dcerpc/dnsserver.py
Normal file
181
source4/scripting/python/samba/tests/dcerpc/dnsserver.py
Normal file
@ -0,0 +1,181 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
# Unix SMB/CIFS implementation.
|
||||
# Copyright (C) Amitay Isaacs <amitay@gmail.com> 2011
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation; either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
#
|
||||
|
||||
"""Tests for samba.dcerpc.dnsserver"""
|
||||
|
||||
from samba.dcerpc import dnsp, dnsserver
|
||||
from samba.tests import RpcInterfaceTestCase, env_get_var_value
|
||||
from samba.netcmd.dns import ARecord
|
||||
|
||||
class DnsserverTests(RpcInterfaceTestCase):
|
||||
|
||||
def setUp(self):
|
||||
super(DnsserverTests, self).setUp()
|
||||
self.server = env_get_var_value("SERVER_IP")
|
||||
self.zone = env_get_var_value("REALM").lower()
|
||||
self.conn = dnsserver.dnsserver("ncacn_ip_tcp:%s" % (self.server),
|
||||
self.get_loadparm(),
|
||||
self.get_credentials())
|
||||
|
||||
def test_operation2(self):
|
||||
pass
|
||||
|
||||
|
||||
def test_query2(self):
|
||||
typeid, result = self.conn.DnssrvQuery2(dnsserver.DNS_CLIENT_VERSION_W2K,
|
||||
0,
|
||||
self.server,
|
||||
None,
|
||||
'ServerInfo')
|
||||
self.assertEquals(dnsserver.DNSSRV_TYPEID_SERVER_INFO_W2K, typeid)
|
||||
|
||||
typeid, result = self.conn.DnssrvQuery2(dnsserver.DNS_CLIENT_VERSION_DOTNET,
|
||||
0,
|
||||
self.server,
|
||||
None,
|
||||
'ServerInfo')
|
||||
self.assertEquals(dnsserver.DNSSRV_TYPEID_SERVER_INFO_DOTNET, typeid)
|
||||
|
||||
typeid, result = self.conn.DnssrvQuery2(dnsserver.DNS_CLIENT_VERSION_LONGHORN,
|
||||
0,
|
||||
self.server,
|
||||
None,
|
||||
'ServerInfo')
|
||||
self.assertEquals(dnsserver.DNSSRV_TYPEID_SERVER_INFO, typeid)
|
||||
|
||||
|
||||
def test_complexoepration2(self):
|
||||
client_version = dnsserver.DNS_CLIENT_VERSION_LONGHORN
|
||||
request_filter = dnsserver.DNS_ZONE_REQUEST_PRIMARY
|
||||
typeid, zones = self.conn.DnssrvComplexOperation2(client_version,
|
||||
0,
|
||||
self.server,
|
||||
None,
|
||||
'EnumZones',
|
||||
dnsserver.DNSSRV_TYPEID_DWORD,
|
||||
request_filter)
|
||||
self.assertEquals(dnsserver.DNSSRV_TYPEID_ZONE_LIST, typeid)
|
||||
self.assertEquals(2, zones.dwZoneCount)
|
||||
|
||||
|
||||
def test_enumrecords2(self):
|
||||
client_version = dnsserver.DNS_CLIENT_VERSION_LONGHORN
|
||||
record_type = dnsp.DNS_TYPE_NS
|
||||
select_flags = (dnsserver.DNS_RPC_VIEW_ROOT_HINT_DATA |
|
||||
dnsserver.DNS_RPC_VIEW_ADDITIONAL_DATA)
|
||||
buflen, roothints = self.conn.DnssrvEnumRecords2(client_version,
|
||||
0,
|
||||
self.server,
|
||||
'..RootHints',
|
||||
'.',
|
||||
None,
|
||||
record_type,
|
||||
select_flags,
|
||||
None,
|
||||
None)
|
||||
self.assertEquals(14, roothints.count) # 1 NS + 13 A records (a-m)
|
||||
|
||||
|
||||
def test_updaterecords2(self):
|
||||
client_version = dnsserver.DNS_CLIENT_VERSION_LONGHORN
|
||||
record_type = dnsp.DNS_TYPE_A
|
||||
select_flags = dnsserver.DNS_RPC_VIEW_AUTHORITY_DATA
|
||||
|
||||
name = 'dummy'
|
||||
rec = ARecord('1.2.3.4')
|
||||
rec2 = ARecord('5.6.7.8')
|
||||
|
||||
# Add record
|
||||
add_rec_buf = dnsserver.DNS_RPC_RECORD_BUF()
|
||||
add_rec_buf.rec = rec
|
||||
self.conn.DnssrvUpdateRecord2(client_version,
|
||||
0,
|
||||
self.server,
|
||||
self.zone,
|
||||
name,
|
||||
add_rec_buf,
|
||||
None)
|
||||
|
||||
buflen, result = self.conn.DnssrvEnumRecords2(client_version,
|
||||
0,
|
||||
self.server,
|
||||
self.zone,
|
||||
name,
|
||||
None,
|
||||
record_type,
|
||||
select_flags,
|
||||
None,
|
||||
None)
|
||||
self.assertEquals(1, result.count)
|
||||
self.assertEquals(1, result.rec[0].wRecordCount)
|
||||
self.assertEquals(dnsp.DNS_TYPE_A, result.rec[0].records[0].wType)
|
||||
self.assertEquals('1.2.3.4', result.rec[0].records[0].data)
|
||||
|
||||
# Update record
|
||||
add_rec_buf = dnsserver.DNS_RPC_RECORD_BUF()
|
||||
add_rec_buf.rec = rec2
|
||||
del_rec_buf = dnsserver.DNS_RPC_RECORD_BUF()
|
||||
del_rec_buf.rec = rec
|
||||
self.conn.DnssrvUpdateRecord2(client_version,
|
||||
0,
|
||||
self.server,
|
||||
self.zone,
|
||||
name,
|
||||
add_rec_buf,
|
||||
del_rec_buf)
|
||||
|
||||
buflen, result = self.conn.DnssrvEnumRecords2(client_version,
|
||||
0,
|
||||
self.server,
|
||||
self.zone,
|
||||
name,
|
||||
None,
|
||||
record_type,
|
||||
select_flags,
|
||||
None,
|
||||
None)
|
||||
self.assertEquals(1, result.count)
|
||||
self.assertEquals(1, result.rec[0].wRecordCount)
|
||||
self.assertEquals(dnsp.DNS_TYPE_A, result.rec[0].records[0].wType)
|
||||
self.assertEquals('5.6.7.8', result.rec[0].records[0].data)
|
||||
|
||||
# Delete record
|
||||
del_rec_buf = dnsserver.DNS_RPC_RECORD_BUF()
|
||||
del_rec_buf.rec = rec2
|
||||
self.conn.DnssrvUpdateRecord2(client_version,
|
||||
0,
|
||||
self.server,
|
||||
self.zone,
|
||||
name,
|
||||
None,
|
||||
del_rec_buf)
|
||||
|
||||
try:
|
||||
buflen, result = self.conn.DnssrvEnumRecords2(client_version,
|
||||
0,
|
||||
self.server,
|
||||
self.zone,
|
||||
name,
|
||||
None,
|
||||
record_type,
|
||||
select_flags,
|
||||
None,
|
||||
None)
|
||||
except RuntimeError, e:
|
||||
self.assertEquals("(9714, 'WERR_DNS_ERROR_NAME_DOES_NOT_EXIST')", str(e))
|
@ -424,6 +424,7 @@ planpythontestsuite("none", "samba.tests.samba3sam")
|
||||
planpythontestsuite("none", "subunit")
|
||||
planpythontestsuite("dc:local", "samba.tests.dcerpc.rpcecho")
|
||||
plantestsuite_idlist("samba.tests.dcerpc.registry", "dc:local", [subunitrun, "$LISTOPT", '-U"$USERNAME%$PASSWORD"', "samba.tests.dcerpc.registry"])
|
||||
plantestsuite_idlist("samba.tests.dcerpc.dnsserver(dc)", "dc", [subunitrun, "$LISTOPT", '-U"$USERNAME%$PASSWORD"', "samba.tests.dcerpc.dnsserver"])
|
||||
plantestsuite("samba4.ldap.python(dc)", "dc", [python, os.path.join(samba4srcdir, "dsdb/tests/python/ldap.py"), '$SERVER', '-U"$USERNAME%$PASSWORD"', '-W', '$DOMAIN'])
|
||||
plantestsuite("samba4.tokengroups.python(dc)", "dc:local", [python, os.path.join(samba4srcdir, "dsdb/tests/python/token_group.py"), '$SERVER', '-U"$USERNAME%$PASSWORD"', '-W', '$DOMAIN'])
|
||||
plantestsuite("samba4.sam.python(dc)", "dc", [python, os.path.join(samba4srcdir, "dsdb/tests/python/sam.py"), '$SERVER', '-U"$USERNAME%$PASSWORD"', '-W', '$DOMAIN'])
|
||||
|
Loading…
x
Reference in New Issue
Block a user