summaryrefslogtreecommitdiff
path: root/source4/torture/rpc
diff options
context:
space:
mode:
authorStefan Metzmacher <metze@samba.org>2004-11-22 17:14:57 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 13:06:05 -0500
commite94c88cedc97cb59ff6c73c5bf82d343925a0fa9 (patch)
treeeccba1c872783bca6aeb594c5c64390f820efae3 /source4/torture/rpc
parent5e2f7e9ae28277d975c3b9e889e0501bf192d2ea (diff)
downloadsamba-e94c88cedc97cb59ff6c73c5bf82d343925a0fa9.tar.gz
samba-e94c88cedc97cb59ff6c73c5bf82d343925a0fa9.tar.bz2
samba-e94c88cedc97cb59ff6c73c5bf82d343925a0fa9.zip
r3914: add idl, torture test and simple server for netr_DrsGetDCNameEx2()
metze (This used to be commit 1ffabbaa667c7dec6657ec523f92f072a2a47a95)
Diffstat (limited to 'source4/torture/rpc')
-rw-r--r--source4/torture/rpc/netlogon.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/source4/torture/rpc/netlogon.c b/source4/torture/rpc/netlogon.c
index 9c87106550..a23cdb8b0c 100644
--- a/source4/torture/rpc/netlogon.c
+++ b/source4/torture/rpc/netlogon.c
@@ -887,6 +887,46 @@ static BOOL test_DsrEnumerateDomainTrusts(struct dcerpc_pipe *p, TALLOC_CTX *mem
return True;
}
+/*
+ try a netlogon netr_DrsGetDCNameEx2
+*/
+static BOOL test_netr_DrsGetDCNameEx2(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx)
+{
+ NTSTATUS status;
+ struct netr_DrsGetDCNameEx2 r;
+ BOOL ret = True;
+
+ r.in.server_unc = talloc_asprintf(mem_ctx, "\\\\%s", dcerpc_server_name(p));
+ r.in.client_account = NULL;
+ r.in.mask = 0x00000000;
+ r.in.domain_name = talloc_asprintf(mem_ctx, "%s", lp_realm());
+ r.in.domain_guid = NULL;
+ r.in.site_name = NULL;
+ r.in.flags = 0x40000000;
+
+ printf("Testing netr_DrsGetDCNameEx2 without client account\n");
+
+ status = dcerpc_netr_DrsGetDCNameEx2(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(r.out.result)) {
+ printf("netr_DrsGetDCNameEx2 - %s/%s\n",
+ nt_errstr(status), win_errstr(r.out.result));
+ ret = False;
+ }
+
+ printf("Testing netr_DrsGetDCNameEx2 with client acount\n");
+ r.in.client_account = TEST_MACHINE_NAME"$";
+ r.in.mask = 0x00002000;
+ r.in.flags = 0x80000000;
+
+ status = dcerpc_netr_DrsGetDCNameEx2(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(r.out.result)) {
+ printf("netr_DrsGetDCNameEx2 - %s/%s\n",
+ nt_errstr(status), win_errstr(r.out.result));
+ ret = False;
+ }
+
+ return ret;
+}
static BOOL test_GetDomainInfo(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx)
{
@@ -1122,6 +1162,10 @@ BOOL torture_rpc_netlogon(void)
ret = False;
}
+ if (!test_netr_DrsGetDCNameEx2(p, mem_ctx)) {
+ ret = False;
+ }
+
talloc_destroy(mem_ctx);
torture_rpc_close(p);