summaryrefslogtreecommitdiff
path: root/source4/torture
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2003-11-19 09:15:46 +0000
committerAndrew Tridgell <tridge@samba.org>2003-11-19 09:15:46 +0000
commit4e18040236c0f51a526383800fb1de8a65ab3175 (patch)
tree4d2a3d482d7d699db6a6bb1a74485b0719feeb75 /source4/torture
parentde3f0b424f5c89b9c084c5b0d7af46585d1cbf0e (diff)
downloadsamba-4e18040236c0f51a526383800fb1de8a65ab3175.tar.gz
samba-4e18040236c0f51a526383800fb1de8a65ab3175.tar.bz2
samba-4e18040236c0f51a526383800fb1de8a65ab3175.zip
srvsvc IDL and test code from metze. Thanks!
(This used to be commit 54d3cb22dc0ddc46eb114aa104e0660b3a437cb2)
Diffstat (limited to 'source4/torture')
-rw-r--r--source4/torture/rpc/srvsvc.c296
-rw-r--r--source4/torture/torture.c1
2 files changed, 297 insertions, 0 deletions
diff --git a/source4/torture/rpc/srvsvc.c b/source4/torture/rpc/srvsvc.c
new file mode 100644
index 0000000000..384959f26a
--- /dev/null
+++ b/source4/torture/rpc/srvsvc.c
@@ -0,0 +1,296 @@
+/*
+ Unix SMB/CIFS implementation.
+ test suite for srvsvc rpc operations
+
+ Copyright (C) Stefan (metze) Metzmacher 2003
+
+ 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"
+
+
+static BOOL test_NetConnEnum(struct dcerpc_pipe *p,
+ TALLOC_CTX *mem_ctx)
+{
+ NTSTATUS status;
+ struct srvsvc_NetConnEnum r;
+ struct srvsvc_NetConnCtr0 c0;
+ uint32 levels[] = {0, 1};
+ int i;
+ BOOL ret = True;
+
+ r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
+ r.in.path = talloc_asprintf(mem_ctx,"%s","ADMIN$");
+ r.in.ctr.subctr.ctr0 = &c0;
+ r.in.ctr.subctr.ctr0->count = 0;
+ r.in.ctr.subctr.ctr0->array = NULL;
+ r.in.preferred_len = (uint32)-1;
+ r.in.resume_handle = NULL;
+
+ for (i=0;i<ARRAY_SIZE(levels);i++) {
+ r.in.ctr.level = levels[i];
+ r.in.ctr.level2 = levels[i];
+ printf("testing NetConnEnum level %u\n", r.in.ctr.level);
+ status = dcerpc_srvsvc_NetConnEnum(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("NetConnEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
+ ret = False;
+ }
+ }
+
+ return True;
+}
+
+static BOOL test_NetFileEnum(struct dcerpc_pipe *p,
+ TALLOC_CTX *mem_ctx)
+{
+ NTSTATUS status;
+ struct srvsvc_NetFileEnum r;
+ struct srvsvc_NetFileCtr3 c3;
+ uint32 levels[] = {2, 3};
+ int i;
+ BOOL ret = True;
+
+ r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
+ r.in.path = NULL;
+ r.in.user = NULL;
+ r.in.ctr.subctr.ctr3 = &c3;
+ r.in.ctr.subctr.ctr3->count = 0;
+ r.in.ctr.subctr.ctr3->array = NULL;
+ r.in.preferred_len = (uint32)4096;
+ r.in.resume_handle = NULL;
+
+ for (i=0;i<ARRAY_SIZE(levels);i++) {
+ r.in.ctr.level = levels[i];
+ r.in.ctr.level2 = levels[i];
+ printf("testing NetFileEnum level %u\n", r.in.ctr.level);
+ status = dcerpc_srvsvc_NetFileEnum(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("NetFileEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
+ ret = False;
+ }
+ }
+
+ return True;
+}
+
+static BOOL test_NetSessEnum(struct dcerpc_pipe *p,
+ TALLOC_CTX *mem_ctx)
+{
+ NTSTATUS status;
+ struct srvsvc_NetSessEnum r;
+ struct srvsvc_NetSessCtr0 c0;
+ uint32 levels[] = {0, 1, 2, 10, 502};
+ int i;
+ BOOL ret = True;
+
+ r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
+ r.in.client = NULL;
+ r.in.user = NULL;
+ r.in.ctr.subctr.ctr0 = &c0;
+ r.in.ctr.subctr.ctr0->count = 0;
+ r.in.ctr.subctr.ctr0->array = NULL;
+ r.in.preferred_len = (uint32)-1;
+ r.in.resume_handle = NULL;
+
+ for (i=0;i<ARRAY_SIZE(levels);i++) {
+ r.in.ctr.level = levels[i];
+ r.in.ctr.level2 = levels[i];
+ printf("testing NetSessEnum level %u\n", r.in.ctr.level);
+ status = dcerpc_srvsvc_NetSessEnum(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("NetSessEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
+ ret = False;
+ }
+ }
+
+ return True;
+}
+
+static BOOL test_NetShareEnumAll(struct dcerpc_pipe *p,
+ TALLOC_CTX *mem_ctx)
+{
+ NTSTATUS status;
+ struct srvsvc_NetShareEnumAll r;
+ struct srvsvc_NetShareCtr0 c0;
+ uint32 levels[] = {0, 1, 2, 501, 502};
+ int i;
+ BOOL ret = True;
+
+ r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
+ r.in.ctr.subctr.ctr0 = &c0;
+ r.in.ctr.subctr.ctr0->count = 0;
+ r.in.ctr.subctr.ctr0->array = NULL;
+ r.in.preferred_len = (uint32)-1;
+ r.in.resume_handle = NULL;
+
+ for (i=0;i<ARRAY_SIZE(levels);i++) {
+ r.in.ctr.level = levels[i];
+ r.in.ctr.level2 = levels[i];
+ printf("testing NetShareEnumAll level %u\n", r.in.ctr.level);
+ status = dcerpc_srvsvc_NetShareEnumAll(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("NetShareEnumAll level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
+ ret = False;
+ }
+ }
+
+ return True;
+}
+
+#if 0
+static BOOL test_NetDiskEnum(struct dcerpc_pipe *p,
+ TALLOC_CTX *mem_ctx)
+{
+ NTSTATUS status;
+ struct srvsvc_NetDiskEnum r;
+ struct srvsvc_NetDiskCtr0 c0;
+ uint32 levels[] = {0, 1, 2, 3};
+ int i;
+ BOOL ret = True;
+
+ r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
+ r.in.preferred_len = (uint32)-1;
+ r.in.resume_handle = NULL;
+
+ for (i=0;i<ARRAY_SIZE(levels);i++) {
+ r.in.level = levels[i];
+ ZERO_STRUCT(r.out);
+ printf("testing NetDiskEnum level %u\n", r.in.level);
+ status = dcerpc_srvsvc_NetDiskEnum(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ NDR_PRINT_OUT_DEBUG(srvsvc_NetDiskEnum, &r);
+ printf("NetDiskEnum level %u failed - %s\n", r.in.level, nt_errstr(status));
+ ret = False;
+ }
+ }
+
+ return True;
+}
+
+static BOOL test_NetTransportEnum(struct dcerpc_pipe *p,
+ TALLOC_CTX *mem_ctx)
+{
+ NTSTATUS status;
+ struct srvsvc_NetTransportEnum r;
+ struct srvsvc_NetTransportCtr0 c0;
+ uint32 levels[] = {0, 1};
+ int i;
+ BOOL ret = True;
+
+ r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
+ r.in.ctr.subctr.ctr0 = &c0;
+ r.in.ctr.subctr.ctr0->count = 0;
+ r.in.ctr.subctr.ctr0->array = NULL;
+ r.in.preferred_len = (uint32)-1;
+ r.in.resume_handle = NULL;
+
+ for (i=0;i<ARRAY_SIZE(levels);i++) {
+ r.in.ctr.level = levels[i];
+ r.in.ctr.level2 = levels[i];
+ printf("testing NetTransportEnum level %u\n", r.in.ctr.level);
+ status = dcerpc_srvsvc_NetTransportEnum(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("NetTransportEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
+ ret = False;
+ }
+ }
+
+ return True;
+}
+#endif
+static BOOL test_NetShareEnum(struct dcerpc_pipe *p,
+ TALLOC_CTX *mem_ctx)
+{
+ NTSTATUS status;
+ struct srvsvc_NetShareEnum r;
+ struct srvsvc_NetShareCtr0 c0;
+ uint32 levels[] = {0, 1, 2, 502};
+ int i;
+ BOOL ret = True;
+
+ r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
+ r.in.ctr.subctr.ctr0 = &c0;
+ r.in.ctr.subctr.ctr0->count = 0;
+ r.in.ctr.subctr.ctr0->array = NULL;
+ r.in.preferred_len = (uint32)-1;
+ r.in.resume_handle = NULL;
+
+ for (i=0;i<ARRAY_SIZE(levels);i++) {
+ r.in.ctr.level = levels[i];
+ r.in.ctr.level2 = levels[i];
+ printf("testing NetShareEnum level %u\n", r.in.ctr.level);
+ status = dcerpc_srvsvc_NetShareEnum(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("NetShareEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
+ ret = False;
+ }
+ }
+
+ return True;
+}
+
+BOOL torture_rpc_srvsvc(int dummy)
+{
+ NTSTATUS status;
+ struct dcerpc_pipe *p;
+ TALLOC_CTX *mem_ctx;
+ BOOL ret = True;
+
+ mem_ctx = talloc_init("torture_rpc_srvsvc");
+
+ status = torture_rpc_connection(&p,
+ DCERPC_SRVSVC_NAME,
+ DCERPC_SRVSVC_UUID,
+ DCERPC_SRVSVC_VERSION);
+ if (!NT_STATUS_IS_OK(status)) {
+ return False;
+ }
+
+ p->flags |= DCERPC_DEBUG_PRINT_BOTH;
+
+ if (!test_NetConnEnum(p, mem_ctx)) {
+ ret = False;
+ }
+
+ if (!test_NetFileEnum(p, mem_ctx)) {
+ ret = False;
+ }
+
+ if (!test_NetSessEnum(p, mem_ctx)) {
+ ret = False;
+ }
+
+ if (!test_NetShareEnumAll(p, mem_ctx)) {
+ ret = False;
+ }
+#if 0
+ if (!test_NetDiskEnum(p, mem_ctx)) {
+ ret = False;
+ }
+
+ if (!test_NetTransportEnum(p, mem_ctx)) {
+ ret = False;
+ }
+#endif
+ if (!test_NetShareEnum(p, mem_ctx)) {
+ ret = False;
+ }
+
+ torture_rpc_close(p);
+
+ return ret;
+}
diff --git a/source4/torture/torture.c b/source4/torture/torture.c
index 711a0ae54e..fca54de64e 100644
--- a/source4/torture/torture.c
+++ b/source4/torture/torture.c
@@ -3993,6 +3993,7 @@ static struct {
{"RPC-SPOOLSS", torture_rpc_spoolss, 0},
{"RPC-SAMR", torture_rpc_samr, 0},
{"RPC-WKSSVC", torture_rpc_wkssvc, 0},
+ {"RPC-SRVSVC", torture_rpc_srvsvc, 0},
{NULL, NULL, 0}};