VirtualBox

source: vbox/trunk/src/VBox/Main/webservice/webtest.cpp@ 29853

Last change on this file since 29853 was 29200, checked in by vboxsync, 15 years ago

more manual Oracle rebranding in headers

  • Property filesplitter.c set to Makefile.kmk
  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 15.7 KB
Line 
1/*
2 * webtest.cpp:
3 * demo webservice client in C++. This mimics some of the
4 * functionality of VBoxManage for testing purposes.
5 *
6 * Copyright (C) 2006-2010 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 */
16
17// gSOAP headers (must come after vbox includes because it checks for conflicting defs)
18#include "soapStub.h"
19
20// include generated namespaces table
21#include "vboxwebsrv.nsmap"
22
23#include <iostream>
24#include <sstream>
25#include <string>
26
27
28/**
29 *
30 * @param argc
31 * @param argv[]
32 * @return
33 */
34int main(int argc, char* argv[])
35{
36 struct soap soap; // gSOAP runtime environment
37 soap_init(&soap); // initialize runtime environment (only once)
38
39 if (argc < 2)
40 {
41 std::cout <<
42 "webtest: VirtualBox webservice testcase.\n"
43 "Usage:\n"
44 " - IWebsessionManager:\n"
45 " - webtest logon <user> <pass>: IWebsessionManager::logon().\n"
46 " - webtest getsession <vboxref>: IWebsessionManager::getSessionObject().\n"
47 " - webtest logoff <vboxref>: IWebsessionManager::logoff().\n"
48 " - IVirtualBox:\n"
49 " - webtest version <vboxref>: IVirtualBox::getVersion().\n"
50 " - webtest gethost <vboxref>: IVirtualBox::getHost().\n"
51 " - webtest getmachines <vboxref>: IVirtualBox::getMachines().\n"
52 " - webtest createmachine <vboxref> <baseFolder> <name>: IVirtualBox::createMachine().\n"
53 " - webtest registermachine <vboxref> <machineref>: IVirtualBox::registerMachine().\n"
54 " - IHost:\n"
55 " - webtest getdvddrives <hostref>: IHost::getDVDDrives.\n"
56 " - IHostDVDDrive:\n"
57 " - webtest getdvdname <dvdref>: IHostDVDDrive::getname.\n"
58 " - IMachine:\n"
59 " - webtest getname <machineref>: IMachine::getName().\n"
60 " - webtest getid <machineref>: IMachine::getId().\n"
61 " - webtest getostype <machineref>: IMachine::getGuestOSType().\n"
62 " - webtest savesettings <machineref>: IMachine::saveSettings().\n"
63 " - All managed object references:\n"
64 " - webtest getif <ref>: report interface of object.\n"
65 " - webtest release <ref>: IUnknown::Release().\n";
66 exit(1);
67 }
68
69 const char *pcszArgEndpoint = "localhost:18083";
70
71 const char *pcszMode = argv[1];
72 int soaprc = 2;
73
74 if (!strcmp(pcszMode, "logon"))
75 {
76 if (argc < 4)
77 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
78 else
79 {
80 _vbox__IWebsessionManager_USCORElogon req;
81 req.username = argv[2];
82 req.password = argv[3];
83 _vbox__IWebsessionManager_USCORElogonResponse resp;
84
85 if (!(soaprc = soap_call___vbox__IWebsessionManager_USCORElogon(&soap,
86 pcszArgEndpoint,
87 NULL,
88 &req,
89 &resp)))
90 std::cout << "VirtualBox objref: \"" << resp.returnval << "\"\n";
91 }
92 }
93 else if (!strcmp(pcszMode, "getsession"))
94 {
95 if (argc < 3)
96 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
97 else
98 {
99 _vbox__IWebsessionManager_USCOREgetSessionObject req;
100 req.refIVirtualBox = argv[2];
101 _vbox__IWebsessionManager_USCOREgetSessionObjectResponse resp;
102
103 if (!(soaprc = soap_call___vbox__IWebsessionManager_USCOREgetSessionObject(&soap,
104 pcszArgEndpoint,
105 NULL,
106 &req,
107 &resp)))
108 std::cout << "session: \"" << resp.returnval << "\"\n";
109 }
110 }
111 else if (!strcmp(pcszMode, "logoff"))
112 {
113 if (argc < 3)
114 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
115 else
116 {
117 _vbox__IWebsessionManager_USCORElogoff req;
118 req.refIVirtualBox = argv[2];
119 _vbox__IWebsessionManager_USCORElogoffResponse resp;
120
121 if (!(soaprc = soap_call___vbox__IWebsessionManager_USCORElogoff(&soap,
122 pcszArgEndpoint,
123 NULL,
124 &req,
125 &resp)))
126 {
127 ;
128 }
129 }
130 }
131 else if (!strcmp(pcszMode, "version"))
132 {
133 if (argc < 3)
134 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
135 else
136 {
137 _vbox__IVirtualBox_USCOREgetVersion req;
138 req._USCOREthis = argv[2];
139 _vbox__IVirtualBox_USCOREgetVersionResponse resp;
140
141 if (!(soaprc = soap_call___vbox__IVirtualBox_USCOREgetVersion(&soap,
142 pcszArgEndpoint,
143 NULL,
144 &req,
145 &resp)))
146 std::cout << "version: \"" << resp.returnval << "\"\n";
147 }
148 }
149 else if (!strcmp(pcszMode, "gethost"))
150 {
151 if (argc < 3)
152 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
153 else
154 {
155 _vbox__IVirtualBox_USCOREgetHost req;
156 req._USCOREthis = argv[2];
157 _vbox__IVirtualBox_USCOREgetHostResponse resp;
158
159 if (!(soaprc = soap_call___vbox__IVirtualBox_USCOREgetHost(&soap,
160 pcszArgEndpoint,
161 NULL,
162 &req,
163 &resp)))
164 {
165 std::cout << "Host objref " << resp.returnval << "\n";
166 }
167 }
168 }
169 else if (!strcmp(pcszMode, "getmachines"))
170 {
171 if (argc < 3)
172 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
173 else
174 {
175 _vbox__IVirtualBox_USCOREgetMachines req;
176 req._USCOREthis = argv[2];
177 _vbox__IVirtualBox_USCOREgetMachinesResponse resp;
178
179 if (!(soaprc = soap_call___vbox__IVirtualBox_USCOREgetMachines(&soap,
180 pcszArgEndpoint,
181 NULL,
182 &req,
183 &resp)))
184 {
185 size_t c = resp.returnval.size();
186 for (size_t i = 0;
187 i < c;
188 ++i)
189 {
190 std::cout << "Machine " << i << ": objref " << resp.returnval[i] << "\n";
191 }
192 }
193 }
194 }
195 else if (!strcmp(pcszMode, "createmachine"))
196 {
197 if (argc < 5)
198 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
199 else
200 {
201 _vbox__IVirtualBox_USCOREcreateMachine req;
202 req._USCOREthis = argv[2];
203 req.baseFolder = argv[3];
204 req.name = argv[4];
205 std::cout << "createmachine: baseFolder = \"" << req.baseFolder << "\", name = \"" << req.name << "\"\n";
206 _vbox__IVirtualBox_USCOREcreateMachineResponse resp;
207
208 if (!(soaprc = soap_call___vbox__IVirtualBox_USCOREcreateMachine(&soap,
209 pcszArgEndpoint,
210 NULL,
211 &req,
212 &resp)))
213 std::cout << "Machine created: managed object reference ID is " << resp.returnval << "\n";
214 }
215 }
216 else if (!strcmp(pcszMode, "registermachine"))
217 {
218 if (argc < 4)
219 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
220 else
221 {
222 _vbox__IVirtualBox_USCOREregisterMachine req;
223 req._USCOREthis = argv[2];
224 req.machine = argv[3];
225 _vbox__IVirtualBox_USCOREregisterMachineResponse resp;
226 if (!(soaprc = soap_call___vbox__IVirtualBox_USCOREregisterMachine(&soap,
227 pcszArgEndpoint,
228 NULL,
229 &req,
230 &resp)))
231 std::cout << "Machine registered.\n";
232 }
233 }
234 else if (!strcmp(pcszMode, "getdvddrives"))
235 {
236 if (argc < 3)
237 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
238 else
239 {
240 _vbox__IHost_USCOREgetDVDDrives req;
241 req._USCOREthis = argv[2];
242 _vbox__IHost_USCOREgetDVDDrivesResponse resp;
243 if (!(soaprc = soap_call___vbox__IHost_USCOREgetDVDDrives(&soap,
244 pcszArgEndpoint,
245 NULL,
246 &req,
247 &resp)))
248 {
249 size_t c = resp.returnval.size();
250 for (size_t i = 0;
251 i < c;
252 ++i)
253 {
254 std::cout << "DVD drive " << i << ": objref " << resp.returnval[i] << "\n";
255 }
256 }
257 }
258 }
259 else if (!strcmp(pcszMode, "getname"))
260 {
261 if (argc < 3)
262 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
263 else
264 {
265 _vbox__IMachine_USCOREgetName req;
266 req._USCOREthis = argv[2];
267 _vbox__IMachine_USCOREgetNameResponse resp;
268 if (!(soaprc = soap_call___vbox__IMachine_USCOREgetName(&soap,
269 pcszArgEndpoint,
270 NULL,
271 &req,
272 &resp)))
273 printf("Name is: %s\n", resp.returnval.c_str());
274 }
275 }
276 else if (!strcmp(pcszMode, "getid"))
277 {
278 if (argc < 3)
279 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
280 else
281 {
282 _vbox__IMachine_USCOREgetId req;
283 req._USCOREthis = argv[2];
284 _vbox__IMachine_USCOREgetIdResponse resp;
285 if (!(soaprc = soap_call___vbox__IMachine_USCOREgetId(&soap,
286 pcszArgEndpoint,
287 NULL,
288 &req,
289 &resp)))
290 std::cout << "UUID is: " << resp.returnval << "\n";;
291 }
292 }
293 else if (!strcmp(pcszMode, "getostypeid"))
294 {
295 if (argc < 3)
296 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
297 else
298 {
299 _vbox__IMachine_USCOREgetOSTypeId req;
300 req._USCOREthis = argv[2];
301 _vbox__IMachine_USCOREgetOSTypeIdResponse resp;
302 if (!(soaprc = soap_call___vbox__IMachine_USCOREgetOSTypeId(&soap,
303 pcszArgEndpoint,
304 NULL,
305 &req,
306 &resp)))
307 std::cout << "Guest OS type is: " << resp.returnval << "\n";
308 }
309 }
310 else if (!strcmp(pcszMode, "savesettings"))
311 {
312 if (argc < 3)
313 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
314 else
315 {
316 _vbox__IMachine_USCOREsaveSettings req;
317 req._USCOREthis = argv[2];
318 _vbox__IMachine_USCOREsaveSettingsResponse resp;
319 if (!(soaprc = soap_call___vbox__IMachine_USCOREsaveSettings(&soap,
320 pcszArgEndpoint,
321 NULL,
322 &req,
323 &resp)))
324 std::cout << "Settings saved\n";
325 }
326 }
327 else if (!strcmp(pcszMode, "release"))
328 {
329 if (argc < 3)
330 std::cout << "Not enough arguments for \"" << pcszMode << "\" mode.\n";
331 else
332 {
333 _vbox__IManagedObjectRef_USCORErelease req;
334 req._USCOREthis = argv[2];
335 _vbox__IManagedObjectRef_USCOREreleaseResponse resp;
336 if (!(soaprc = soap_call___vbox__IManagedObjectRef_USCORErelease(&soap,
337 pcszArgEndpoint,
338 NULL,
339 &req,
340 &resp)))
341 std::cout << "Managed object reference " << req._USCOREthis << " released.\n";
342 }
343 }
344 else
345 std::cout << "Unknown mode parameter \"" << pcszMode << "\".\n";
346
347 if (soaprc)
348 {
349 if ( (soap.fault)
350 && (soap.fault->detail)
351 )
352 {
353 if (soap.fault->detail->vbox__InvalidObjectFault)
354 {
355 std::cout << "Bad object ID: " << soap.fault->detail->vbox__InvalidObjectFault->badObjectID << "\n";
356 }
357 if (soap.fault->detail->vbox__RuntimeFault)
358 {
359 std::cout << "Result code: 0x" << std::hex << soap.fault->detail->vbox__RuntimeFault->resultCode << "\n";
360 std::cout << "Text: " << std::hex << soap.fault->detail->vbox__RuntimeFault->text << "\n";
361 std::cout << "Component: " << std::hex << soap.fault->detail->vbox__RuntimeFault->component << "\n";
362 std::cout << "Interface ID: " << std::hex << soap.fault->detail->vbox__RuntimeFault->interfaceID << "\n";
363 }
364 }
365 else
366 {
367 std::cerr << "Invalid fault data, fault message:\n";
368 soap_print_fault(&soap, stderr); // display the SOAP fault message on the stderr stream
369 }
370 }
371
372 soap_destroy(&soap); // delete deserialized class instances (for C++ only)
373 soap_end(&soap); // remove deserialized data and clean up
374 soap_done(&soap); // detach the gSOAP environment
375
376 return soaprc;
377}
378
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette