287e35142e5f019b9a2af3911329ecb4b3f845a7
[samba.git] / source4 / torture / dcom / simple.c
1 /* 
2    Unix SMB/CIFS implementation.
3    run the "simple" example DCOM program 
4
5    Copyright (C) Jelmer Vernooij 2004
6    
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11    
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16    
17    You should have received a copy of the GNU General Public License
18    along with this program; if not, write to the Free Software
19    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 */
21
22 #include "includes.h"
23 #include "librpc/gen_ndr/ndr_dcom.h"
24 #include "librpc/gen_ndr/ndr_oxidresolver.h"
25
26 #define CLSID_SIMPLE "5e9ddec7-5767-11cf-beab-00aa006c3606"
27 #define DEFAULT_TRANS 4096
28
29 BOOL torture_dcom_simple(void)
30 {
31         NTSTATUS status;
32         struct dcerpc_pipe *p;
33         TALLOC_CTX *mem_ctx;
34         BOOL ret = True;
35         struct GUID IID[2];
36         struct GUID clsid;
37         WERROR error;
38         struct dcom_interface *interfaces;
39         struct IStream_Read r_read;
40         struct IStream_Write r_write;
41         WERROR results[2];
42         struct dcom_context *ctx;
43         char test_data[5];
44         int i;
45
46         mem_ctx = talloc_init("torture_dcom_simple");
47
48         dcom_init(&ctx, lp_parm_string(-1, "torture", "userdomain"),
49                                 lp_parm_string(-1, "torture", "username"), 
50                                   lp_parm_string(-1, "torture", "password"));
51
52         GUID_from_string(DCERPC_ISTREAM_UUID, &IID[0]);
53         GUID_from_string(DCERPC_IUNKNOWN_UUID, &IID[1]);
54         GUID_from_string(CLSID_SIMPLE, &clsid);
55         error = dcom_create_object(ctx, &clsid, 
56                                                           lp_parm_string(-1, "torture", "binding"), 2, IID,
57                                                           &interfaces, 
58                                                           results);
59                                                           
60
61         if (!W_ERROR_IS_OK(error)) {
62                 printf("dcom_create_object failed - %s\n", win_errstr(error));
63                 return False;
64         }
65         
66         ZERO_STRUCT(r_read);
67         r_read.in.num_requested = 20; /* Give me 20 0xFF bytes... */
68         status = dcerpc_IStream_Read(&interfaces[0], mem_ctx, &r_read);
69         if (NT_STATUS_IS_ERR(status)) {
70                 printf("IStream::Read() failed - %s\n", nt_errstr(status));
71                 ret = False;
72         } else if (!W_ERROR_IS_OK(r_read.out.result)) {
73                 printf("IStream::Read() failed - %s\n", win_errstr(r_read.out.result));
74                 ret = False;
75         }
76
77         for (i = 0; i < 5; i++) {
78                 test_data[i] = i+1;
79         }
80         r_write.in.num_requested = 5;
81         r_write.in.data = (uint8_t *)&test_data;
82         status = dcerpc_IStream_Write(&interfaces[0], mem_ctx, &r_write);
83         if (NT_STATUS_IS_ERR(status)) {
84                 printf("IStream::Write() failed - %s\n", nt_errstr(status));
85                 ret = False;
86         } else if (!W_ERROR_IS_OK(r_write.out.result)) {
87                 printf("IStream::Write() failed - %s\n", win_errstr(r_write.out.result));
88                 ret = False;
89         }
90
91         status = dcerpc_IUnknown_Release(&interfaces[1], mem_ctx, NULL);
92         if (NT_STATUS_IS_ERR(status)) {
93                 printf("IUnknown::Release() failed - %s\n", nt_errstr(status));
94                 return False;
95         }
96
97         talloc_destroy(mem_ctx);
98
99         torture_rpc_close(p);
100         return ret;
101 }