summaryrefslogtreecommitdiff
path: root/source4/torture
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2005-05-10 02:03:47 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 13:16:35 -0500
commit191c8b508277d7886b9a961b8636c41fd84caa4f (patch)
tree8b78d2a9b48e4d80f397d481384eeb8406cdb7fb /source4/torture
parent0ac02ed7c344a7462d5d797b46e89e9d4a6937de (diff)
downloadsamba-191c8b508277d7886b9a961b8636c41fd84caa4f.tar.gz
samba-191c8b508277d7886b9a961b8636c41fd84caa4f.tar.bz2
samba-191c8b508277d7886b9a961b8636c41fd84caa4f.zip
r6694: a simple CLDAP torture test
interestingly, w2k3 seems to have 4 different varients of the netlogon cldap response. We decode two of them so far. The other two are tricky as they aren't distinguished by a command code, they use the same command codes (0x13 and 0x17) but have quite a different format. Very strange! (This used to be commit 58f1c39282e281450fe94ceab7ca0a53ec7172e1)
Diffstat (limited to 'source4/torture')
-rw-r--r--source4/torture/config.mk5
-rw-r--r--source4/torture/ldap/cldap.c81
-rw-r--r--source4/torture/torture.c1
3 files changed, 85 insertions, 2 deletions
diff --git a/source4/torture/config.mk b/source4/torture/config.mk
index d22edc4bc2..128a5cafc9 100644
--- a/source4/torture/config.mk
+++ b/source4/torture/config.mk
@@ -163,9 +163,10 @@ ADD_OBJ_FILES = \
[SUBSYSTEM::TORTURE_LDAP]
ADD_OBJ_FILES = \
torture/ldap/common.o \
- torture/ldap/basic.o
+ torture/ldap/basic.o \
+ torture/ldap/cldap.o
REQUIRED_SUBSYSTEMS = \
- LIBCLI_LDAP
+ LIBCLI_LDAP LIBCLI_CLDAP
# End SUBSYSTEM TORTURE_LDAP
#################################
diff --git a/source4/torture/ldap/cldap.c b/source4/torture/ldap/cldap.c
new file mode 100644
index 0000000000..23bb7f5ba0
--- /dev/null
+++ b/source4/torture/ldap/cldap.c
@@ -0,0 +1,81 @@
+/*
+ Unix SMB/CIFS mplementation.
+
+ test CLDAP operations
+
+ Copyright (C) Andrew Tridgell 2005
+
+ 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 2 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, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
+#include "includes.h"
+#include "libcli/cldap/cldap.h"
+#include "libcli/ldap/ldap.h"
+#include "lib/events/events.h"
+
+
+/*
+ test netlogon operations
+*/
+static BOOL test_cldap_netlogon(TALLOC_CTX *mem_ctx, const char *dest)
+{
+ struct cldap_socket *cldap = cldap_socket_init(mem_ctx, NULL);
+ NTSTATUS status;
+ struct cldap_netlogon search;
+ int i;
+
+ search.in.dest_address = dest;
+ search.in.realm = lp_realm();
+ search.in.host = lp_netbios_name();
+ search.in.version = 6;
+ status = cldap_netlogon(cldap, mem_ctx, &search);
+
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("netlogon failed - %s\n", nt_errstr(status));
+ } else {
+ NDR_PRINT_DEBUG(nbt_cldap_netlogon, &search.out.netlogon);
+ }
+
+ for (i=0;i<20;i++) {
+ search.in.version = i;
+ status = cldap_netlogon(cldap, mem_ctx, &search);
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("netlogon[%d] failed - %s\n", i, nt_errstr(status));
+ } else {
+ NDR_PRINT_DEBUG(nbt_cldap_netlogon, &search.out.netlogon);
+ }
+ }
+
+ printf("cldap_search gave %s\n", nt_errstr(status));
+
+ return True;
+}
+
+BOOL torture_cldap(void)
+{
+ TALLOC_CTX *mem_ctx;
+ BOOL ret = True;
+ const char *host = lp_parm_string(-1, "torture", "host");
+
+ mem_ctx = talloc_init("torture_cldap");
+
+ ret &= test_cldap_netlogon(mem_ctx, host);
+
+ talloc_free(mem_ctx);
+
+ return ret;
+}
+
diff --git a/source4/torture/torture.c b/source4/torture/torture.c
index 8aa0e91a98..bb411558d6 100644
--- a/source4/torture/torture.c
+++ b/source4/torture/torture.c
@@ -2411,6 +2411,7 @@ static struct {
/* ldap testers */
{"LDAP-BASIC", torture_ldap_basic, 0},
+ {"LDAP-CLDAP", torture_cldap, 0},
/* nbt tests */
{"NBT-REGISTER", torture_nbt_register, 0},