summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJelmer Vernooij <jelmer@samba.org>2004-09-27 22:06:27 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 12:59:24 -0500
commit322d1ccd9f40b838911a7c076ebf3fb754b2550c (patch)
tree8c72313208124a33ff50358e099dad953c5f232e
parentfc3c05e63f4fedb1532e86d9421490fda6435c79 (diff)
downloadsamba-322d1ccd9f40b838911a7c076ebf3fb754b2550c.tar.gz
samba-322d1ccd9f40b838911a7c076ebf3fb754b2550c.tar.bz2
samba-322d1ccd9f40b838911a7c076ebf3fb754b2550c.zip
r2699: Correct handle ServerAlive() and ServerAlive2() + add torture tests
(This used to be commit 9e74144aa8e5f9a8b6e3d5293833c4afeebeddb0)
-rw-r--r--source4/librpc/idl/dcom.idl20
-rw-r--r--source4/librpc/idl/oxidresolver.idl9
-rw-r--r--source4/torture/rpc/oxidresolve.c117
3 files changed, 130 insertions, 16 deletions
diff --git a/source4/librpc/idl/dcom.idl b/source4/librpc/idl/dcom.idl
index df0bcbc80e..46a5122299 100644
--- a/source4/librpc/idl/dcom.idl
+++ b/source4/librpc/idl/dcom.idl
@@ -275,7 +275,7 @@ interface IUnknown
/* Returns the interface with the specified IID
if implemented by this object */
HRESULT QueryInterface([in] IID *riid
- /*FIXME, [out] void **data*/);
+ /*FIXME, [out] void **data*/);
/*****************/
/* Function 0x01 */
@@ -293,11 +293,15 @@ interface IUnknown
pointer_default(unique)
] interface IClassFactory : IUnknown
{
- HRESULT CreateInstance();
+ HRESULT CreateInstance(/*FIXME[in] IUnknown *pUnknown,
+ [in] IID *riid,
+ [out, iid_is(riid)] void **ppv*/);
HRESULT RemoteCreateInstance();
- HRESULT LockServer();
+ /* Set lock to TRUE when you want to do a lock
+ and set it to FALSE when you want to unlock */
+ HRESULT LockServer([in] uint8 lock);
HRESULT RemoteLockServer();
}
@@ -451,16 +455,6 @@ interface ISystemActivator : IUnknown
}
-// Service Control Manager
-
-[
- uuid(),
- version(2.0)
-] interface SCM
-{
- void SCM_Dummy();
-}
-
[
object,
uuid(00000136-0000-0000-C000-000000000046)
diff --git a/source4/librpc/idl/oxidresolver.idl b/source4/librpc/idl/oxidresolver.idl
index 57c5cd439f..61e3049a10 100644
--- a/source4/librpc/idl/oxidresolver.idl
+++ b/source4/librpc/idl/oxidresolver.idl
@@ -86,10 +86,13 @@ interface IOXIDResolver
[out, ref] uint32 *pAuthnHint,
[out, ref] COMVERSION *pComVersion
);
+ typedef struct {
+ COMVERSION version;
+ uint32 unknown1;
+ } COMINFO;
[idempotent] WERROR ServerAlive2 (
- [out] COMVERSION version,
- [out] uint8 unknown1[4],
+ [out] COMINFO info,
[out] DUALSTRINGARRAY dualstring,
- [out] uint8 unknown2[5]);
+ [out] uint8 unknown2[3]);
}
diff --git a/source4/torture/rpc/oxidresolve.c b/source4/torture/rpc/oxidresolve.c
new file mode 100644
index 0000000000..476d140842
--- /dev/null
+++ b/source4/torture/rpc/oxidresolve.c
@@ -0,0 +1,117 @@
+/*
+ Unix SMB/CIFS implementation.
+ test suite for oxidresolve operations
+
+ Copyright (C) Jelmer Vernooij 2004
+
+ 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 int test_SimplePing(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx)
+{
+ struct SimplePing r;
+ NTSTATUS status;
+ HYPER_T h = 10;
+
+ r.in.SetId = &h;
+
+ status = dcerpc_SimplePing(p, mem_ctx, &r);
+ if(NT_STATUS_IS_ERR(status)) {
+ fprintf(stderr, "SimplePing: %s\n", nt_errstr(status));
+ return 0;
+ }
+
+ if(!W_ERROR_IS_OK(r.out.result)) {
+ fprintf(stderr, "SimplePing: %s\n", win_errstr(r.out.result));
+ return 0;
+ }
+
+ return 1;
+}
+
+static int test_ServerAlive(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx)
+{
+ struct ServerAlive r;
+ NTSTATUS status;
+
+ status = dcerpc_ServerAlive(p, mem_ctx, &r);
+ if(NT_STATUS_IS_ERR(status)) {
+ fprintf(stderr, "ServerAlive: %s\n", nt_errstr(status));
+ return 0;
+ }
+
+ if(!W_ERROR_IS_OK(r.out.result)) {
+ fprintf(stderr, "ServerAlive: %s\n", win_errstr(r.out.result));
+ return 0;
+ }
+
+ return 1;
+}
+
+
+static int test_ServerAlive2(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx)
+{
+ struct ServerAlive2 r;
+ NTSTATUS status;
+
+ status = dcerpc_ServerAlive2(p, mem_ctx, &r);
+ if(NT_STATUS_IS_ERR(status)) {
+ fprintf(stderr, "ServerAlive2: %s\n", nt_errstr(status));
+ return 0;
+ }
+
+ if(!W_ERROR_IS_OK(r.out.result)) {
+ fprintf(stderr, "ServerAlive2: %s\n", win_errstr(r.out.result));
+ return 0;
+ }
+
+ return 1;
+}
+
+BOOL torture_rpc_oxidresolve(int dummy)
+{
+ NTSTATUS status;
+ struct dcerpc_pipe *p;
+ TALLOC_CTX *mem_ctx;
+ BOOL ret = True;
+
+ mem_ctx = talloc_init("torture_rpc_oxidresolve");
+
+ status = torture_rpc_connection(&p,
+ DCERPC_IOXIDRESOLVER_NAME,
+ DCERPC_IOXIDRESOLVER_UUID,
+ DCERPC_IOXIDRESOLVER_VERSION);
+
+ if (!NT_STATUS_IS_OK(status)) {
+ return False;
+ }
+
+ if(!test_SimplePing(p, mem_ctx))
+ ret = False;
+
+ if(!test_ServerAlive(p, mem_ctx))
+ ret = False;
+
+ if(!test_ServerAlive2(p, mem_ctx))
+ ret = False;
+
+ talloc_destroy(mem_ctx);
+
+ torture_rpc_close(p);
+
+ return ret;
+}