Author: gd
Date: 2007-11-27 11:20:34 +0000 (Tue, 27 Nov 2007)
New Revision: 26155

WebSVN: 
http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=26155

Log:
Add IDL and torture teset for wkssvc_NetrMessageBufferSend().

Guenther

Modified:
   branches/SAMBA_4_0/source/librpc/idl/wkssvc.idl
   branches/SAMBA_4_0/source/rpc_server/wkssvc/dcesrv_wkssvc.c
   branches/SAMBA_4_0/source/torture/rpc/wkssvc.c


Changeset:
Modified: branches/SAMBA_4_0/source/librpc/idl/wkssvc.idl
===================================================================
--- branches/SAMBA_4_0/source/librpc/idl/wkssvc.idl     2007-11-27 11:14:51 UTC 
(rev 26154)
+++ branches/SAMBA_4_0/source/librpc/idl/wkssvc.idl     2007-11-27 11:20:34 UTC 
(rev 26155)
@@ -372,7 +372,13 @@
 
        /*****************************/
        /* Function        0x0c      */
-       WERROR WKSSVC_NETRMESSAGEBUFFERSEND ();
+       WERROR wkssvc_NetrMessageBufferSend(
+               [in] [string,charset(UTF16)] uint16 *server_name,
+               [in,ref] [string,charset(UTF16)] uint16 *message_name,
+               [in] [string,charset(UTF16)] uint16 *message_sender_name,
+               [in] [size_is(message_size)] [ref] uint8 *message_buffer,
+               [in] uint32 message_size
+               );
 
        /*****************************/
        /* Function        0x0d      */

Modified: branches/SAMBA_4_0/source/rpc_server/wkssvc/dcesrv_wkssvc.c
===================================================================
--- branches/SAMBA_4_0/source/rpc_server/wkssvc/dcesrv_wkssvc.c 2007-11-27 
11:14:51 UTC (rev 26154)
+++ branches/SAMBA_4_0/source/rpc_server/wkssvc/dcesrv_wkssvc.c 2007-11-27 
11:20:34 UTC (rev 26155)
@@ -222,11 +222,11 @@
 }
 
 
-/* 
-  WKSSVC_NETRMESSAGEBUFFERSEND 
+/*
+  wkssvc_NetrMessageBufferSend
 */
-static WERROR dcesrv_WKSSVC_NETRMESSAGEBUFFERSEND(struct dcesrv_call_state 
*dce_call, TALLOC_CTX *mem_ctx,
-                      struct WKSSVC_NETRMESSAGEBUFFERSEND *r)
+static WERROR dcesrv_wkssvc_NetrMessageBufferSend(struct dcesrv_call_state 
*dce_call, TALLOC_CTX *mem_ctx,
+                      struct wkssvc_NetrMessageBufferSend *r)
 {
        DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
 }

Modified: branches/SAMBA_4_0/source/torture/rpc/wkssvc.c
===================================================================
--- branches/SAMBA_4_0/source/torture/rpc/wkssvc.c      2007-11-27 11:14:51 UTC 
(rev 26154)
+++ branches/SAMBA_4_0/source/torture/rpc/wkssvc.c      2007-11-27 11:20:34 UTC 
(rev 26155)
@@ -28,6 +28,7 @@
 #define SMBTORTURE_ALTERNATE_NAME "smbtrt_altname"
 #define SMBTORTURE_TRANSPORT_NAME "\\Device\\smbtrt_transport_name"
 #define SMBTORTURE_USE_NAME "S:"
+#define SMBTORTURE_MESSAGE "smbtrt_message"
 
 static bool test_NetWkstaGetInfo(struct torture_context *tctx,
                                 struct dcerpc_pipe *p)
@@ -740,6 +741,35 @@
        return true;
 }
 
+/* only succeeds as long as the local messenger service is running - Guenther 
*/
+
+static bool test_NetrMessageBufferSend(struct torture_context *tctx,
+                                      struct dcerpc_pipe *p)
+{
+       NTSTATUS status;
+       struct wkssvc_NetrMessageBufferSend r;
+       const char *message = SMBTORTURE_MESSAGE;
+       size_t size;
+       uint8_t *msg;
+
+       size = push_ucs2_talloc(tctx, (void **)&msg, message);
+
+       r.in.server_name = dcerpc_server_name(p);
+       r.in.message_name = dcerpc_server_name(p);
+       r.in.message_sender_name = dcerpc_server_name(p);
+       r.in.message_buffer = msg;
+       r.in.message_size = size;
+
+       torture_comment(tctx, "testing NetrMessageBufferSend\n");
+
+       status = dcerpc_wkssvc_NetrMessageBufferSend(p, tctx, &r);
+       torture_assert_ntstatus_ok(tctx, status,
+                                  "NetrMessageBufferSend failed");
+       torture_assert_werr_ok(tctx, r.out.result,
+                              "NetrMessageBufferSend failed");
+       return true;
+}
+
 struct torture_suite *torture_rpc_wkssvc(TALLOC_CTX *mem_ctx)
 {
        struct torture_suite *suite;
@@ -790,6 +820,8 @@
 
        torture_rpc_tcase_add_test(tcase, "NetrWorkstationStatisticsGet",
                                   test_NetrWorkstationStatisticsGet);
+       torture_rpc_tcase_add_test(tcase, "NetrMessageBufferSend",
+                                  test_NetrMessageBufferSend);
 
        return suite;
 }

Reply via email to