VirtualBox

source: vbox/trunk/src/VBox/Devices/Storage/testcase/tstVD-2.cpp@ 15164

Last change on this file since 15164 was 14970, checked in by vboxsync, 16 years ago

Storage/testcase: fix lost "default=" message.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 7.0 KB
Line 
1/** @file
2 *
3 * Simple VBox HDD container test utility. Only fast tests.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22#include <VBox/err.h>
23#include <VBox/VBoxHDD-new.h>
24#include <iprt/string.h>
25#include <iprt/stream.h>
26#include <iprt/file.h>
27#include <iprt/mem.h>
28#include <iprt/initterm.h>
29#include <iprt/rand.h>
30#include "stdio.h"
31#include "stdlib.h"
32
33/*******************************************************************************
34* Global Variables *
35*******************************************************************************/
36/** The error count. */
37unsigned g_cErrors = 0;
38
39static struct KeyValuePair {
40 const char *key;
41 const char *value;
42} aCfgNode[] = {
43 { "TargetName", "test" },
44 { "LUN", "1" },
45 { "TargetAddress", "address" },
46 { NULL, NULL }
47};
48
49static bool tstAreKeysValid(void *pvUser, const char *pszzValid)
50{
51 return true;
52}
53
54static const char *tstGetValueByKey(const char *pszKey)
55{
56 for (int i = 0; aCfgNode[i].key; i++)
57 if (!strcmp(aCfgNode[i].key, pszKey))
58 return aCfgNode[i].value;
59 return NULL;
60}
61
62static int tstQuerySize(void *pvUser, const char *pszName, size_t *pcbValue)
63{
64 const char *pszValue = tstGetValueByKey(pszName);
65 if (!pszValue)
66 return VERR_CFGM_VALUE_NOT_FOUND;
67 *pcbValue = strlen(pszValue) + 1;
68 return VINF_SUCCESS;
69}
70
71static int tstQuery(void *pvUser, const char *pszName, char *pszValue, size_t cchValue)
72{
73 const char *pszTmp = tstGetValueByKey(pszName);
74 if (!pszValue)
75 return VERR_CFGM_VALUE_NOT_FOUND;
76 size_t cchTmp = strlen(pszTmp) + 1;
77 if (cchValue < cchTmp)
78 return VERR_CFGM_NOT_ENOUGH_SPACE;
79 memcpy(pszValue, pszTmp, cchTmp);
80 return VINF_SUCCESS;
81}
82
83
84VDINTERFACECONFIG icc = {
85 sizeof(VDINTERFACECONFIG),
86 VDINTERFACETYPE_CONFIG,
87 tstAreKeysValid,
88 tstQuerySize,
89 tstQuery
90};
91
92static int tstVDBackendInfo(void)
93{
94 int rc;
95#define MAX_BACKENDS 100
96 VDBACKENDINFO aVDInfo[MAX_BACKENDS];
97 unsigned cEntries;
98
99#define CHECK(str) \
100 do \
101 { \
102 RTPrintf("%s rc=%Rrc\n", str, rc); \
103 if (RT_FAILURE(rc)) \
104 return rc; \
105 } while (0)
106
107 rc = VDBackendInfo(MAX_BACKENDS, aVDInfo, &cEntries);
108 CHECK("VDBackendInfo()");
109
110 for (unsigned i=0; i < cEntries; i++)
111 {
112 RTPrintf("Backend %u: name=%s capabilities=%#06x extensions=",
113 i, aVDInfo[i].pszBackend, aVDInfo[i].uBackendCaps);
114 if (aVDInfo[i].papszFileExtensions)
115 {
116 const char *const *papsz = aVDInfo[i].papszFileExtensions;
117 while (*papsz != NULL)
118 {
119 if (papsz != aVDInfo[i].papszFileExtensions)
120 RTPrintf(",");
121 RTPrintf("%s", *papsz);
122 papsz++;
123 }
124 if (papsz == aVDInfo[i].papszFileExtensions)
125 RTPrintf("<EMPTY>");
126 }
127 else
128 RTPrintf("<NONE>");
129 RTPrintf(" config=");
130 if (aVDInfo[i].paConfigInfo)
131 {
132 PCVDCONFIGINFO pa = aVDInfo[i].paConfigInfo;
133 while (pa->pszKey != NULL)
134 {
135 if (pa != aVDInfo[i].paConfigInfo)
136 RTPrintf(",");
137 RTPrintf("(key=%s type=", pa->pszKey);
138 switch (pa->enmValueType)
139 {
140 case VDCFGVALUETYPE_INTEGER:
141 RTPrintf("integer");
142 break;
143 case VDCFGVALUETYPE_STRING:
144 RTPrintf("string");
145 break;
146 case VDCFGVALUETYPE_BYTES:
147 RTPrintf("bytes");
148 break;
149 default:
150 RTPrintf("INVALID!");
151 }
152 RTPrintf(" default=");
153 if (pa->pszDefaultValue)
154 RTPrintf("%s", pa->pszDefaultValue);
155 else
156 RTPrintf("<NONE>");
157 RTPrintf(" flags=");
158 if (!pa->uKeyFlags)
159 RTPrintf("none");
160 unsigned cFlags = 0;
161 if (pa->uKeyFlags & VD_CFGKEY_MANDATORY)
162 {
163 if (cFlags)
164 RTPrintf(",");
165 RTPrintf("mandatory");
166 cFlags++;
167 }
168 if (pa->uKeyFlags & VD_CFGKEY_EXPERT)
169 {
170 if (cFlags)
171 RTPrintf(",");
172 RTPrintf("expert");
173 cFlags++;
174 }
175 RTPrintf(")");
176 pa++;
177 }
178 if (pa == aVDInfo[i].paConfigInfo)
179 RTPrintf("<EMPTY>");
180 }
181 else
182 RTPrintf("<NONE>");
183 RTPrintf("\n");
184
185 VDINTERFACE ic;
186 ic.cbSize = sizeof(ic);
187 ic.enmInterface = VDINTERFACETYPE_CONFIG;
188 ic.pCallbacks = &icc;
189 char *pszLocation, *pszName;
190 rc = aVDInfo[i].pfnComposeLocation(&ic, &pszLocation);
191 CHECK("pfnComposeLocation()");
192 if (pszLocation)
193 {
194 RTMemFree(pszLocation);
195 if (aVDInfo[i].uBackendCaps & VD_CAP_FILE)
196 {
197 RTPrintf("Non-NULL location returned for file-based backend!\n");
198 return VERR_INTERNAL_ERROR;
199 }
200 }
201 rc = aVDInfo[i].pfnComposeName(&ic, &pszName);
202 CHECK("pfnComposeName()");
203 if (pszName)
204 {
205 RTMemFree(pszName);
206 if (aVDInfo[i].uBackendCaps & VD_CAP_FILE)
207 {
208 RTPrintf("Non-NULL name returned for file-based backend!\n");
209 return VERR_INTERNAL_ERROR;
210 }
211 }
212 }
213
214#undef CHECK
215 return 0;
216}
217
218
219int main(int argc, char *argv[])
220{
221 int rc;
222
223 RTR3Init();
224 RTPrintf("tstVD-2: TESTING...\n");
225
226 rc = tstVDBackendInfo();
227 if (RT_FAILURE(rc))
228 {
229 RTPrintf("tstVD-2: getting backend info test failed! rc=%Rrc\n", rc);
230 g_cErrors++;
231 }
232
233 rc = VDShutdown();
234 if (RT_FAILURE(rc))
235 {
236 RTPrintf("tstVD-2: unloading backends failed! rc=%Rrc\n", rc);
237 g_cErrors++;
238 }
239 /*
240 * Summary
241 */
242 if (!g_cErrors)
243 RTPrintf("tstVD-2: SUCCESS\n");
244 else
245 RTPrintf("tstVD-2: FAILURE - %d errors\n", g_cErrors);
246
247 return !!g_cErrors;
248}
249
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