ReactOS 0.4.16-dev-2224-g3637fd8
drive.c
Go to the documentation of this file.
1/*
2 * Unit test suite for drive functions.
3 *
4 * Copyright 2002 Dmitry Timoshkov
5 *
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
10 *
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 */
20
21#include <stdarg.h>
22
23#include "wine/test.h"
24#include "windef.h"
25#include "winbase.h"
26#include "winerror.h"
27
29
30static void test_GetDriveTypeA(void)
31{
32 char drive[] = "?:\\";
33 char existing_drive_letter = 0;
34 DWORD logical_drives;
35 UINT type;
36
37 logical_drives = GetLogicalDrives();
38 ok(logical_drives != 0, "GetLogicalDrives error %ld\n", GetLastError());
39
40 for (drive[0] = 'A'; drive[0] <= 'Z'; drive[0]++)
41 {
44 "not a valid drive %c: type %u\n", drive[0], type);
45
46 if (!(logical_drives & 1))
48 "GetDriveTypeA should return DRIVE_NO_ROOT_DIR for inexistent drive %c: but not %u\n",
49 drive[0], type);
50 else if (type != DRIVE_NO_ROOT_DIR)
51 existing_drive_letter = drive[0];
52
53 logical_drives >>= 1;
54 }
55
56 if (!existing_drive_letter) {
57 skip("No drives found, skipping drive spec format tests.\n");
58 return;
59 }
60
61 drive[0] = existing_drive_letter;
62 drive[2] = 0; /* C: */
64 ok(type > DRIVE_NO_ROOT_DIR && type <= DRIVE_RAMDISK, "got %u for drive spec '%s'\n", type, drive);
65
66 drive[1] = '?'; /* C? */
68 ok(type == DRIVE_NO_ROOT_DIR, "got %u for drive spec '%s'\n", type, drive);
69
70 drive[1] = 0; /* C */
72 ok(type == DRIVE_NO_ROOT_DIR, "got %u for drive spec '%s'\n", type, drive);
73
74 drive[0] = '?'; /* the string "?" */
76 ok(type == DRIVE_NO_ROOT_DIR, "got %u for drive spec '%s'\n", type, drive);
77
78 drive[0] = 0; /* the empty string */
80 ok(type == DRIVE_NO_ROOT_DIR, "got %u for drive spec '%s'\n", type, drive);
81}
82
83static void test_GetDriveTypeW(void)
84{
85 WCHAR drive[] = {'?',':','\\',0};
86 WCHAR existing_drive_letter = 0;
87 DWORD logical_drives;
88 UINT type;
89
90 logical_drives = GetLogicalDrives();
91 ok(logical_drives != 0, "GetLogicalDrives error %ld\n", GetLastError());
92
93 for (drive[0] = 'A'; drive[0] <= 'Z'; drive[0]++)
94 {
97 "not a valid drive %c: type %u\n", drive[0], type);
98
99 if (!(logical_drives & 1))
101 "GetDriveTypeW should return DRIVE_NO_ROOT_DIR for inexistent drive %c: but not %u\n",
102 drive[0], type);
103 else if (type != DRIVE_NO_ROOT_DIR)
104 existing_drive_letter = drive[0];
105
106 logical_drives >>= 1;
107 }
108
109 if (!existing_drive_letter) {
110 skip("No drives found, skipping drive spec format tests.\n");
111 return;
112 }
113
114 drive[0] = existing_drive_letter;
115 drive[2] = 0; /* C: */
117 ok(type > DRIVE_NO_ROOT_DIR && type <= DRIVE_RAMDISK, "got %u for drive spec '%s'\n",
119
120 drive[1] = '?'; /* C? */
122 ok(type == DRIVE_NO_ROOT_DIR, "got %u for drive spec '%s'\n", type, wine_dbgstr_w(drive));
123
124 drive[1] = 0; /* C */
126 ok(type == DRIVE_NO_ROOT_DIR, "got %u for drive spec '%s'\n", type, wine_dbgstr_w(drive));
127
128 drive[0] = '?'; /* the string "?" */
130 ok(type == DRIVE_NO_ROOT_DIR, "got %u for drive spec '%s'\n", type, wine_dbgstr_w(drive));
131
132 drive[0] = 0; /* the empty string */
134 ok(type == DRIVE_NO_ROOT_DIR, "got %u for drive spec '%s'\n", type, wine_dbgstr_w(drive));
135}
136
137static void test_GetDiskFreeSpaceA(void)
138{
139 BOOL ret;
140 DWORD sectors_per_cluster, bytes_per_sector, free_clusters, total_clusters;
141 char volume_guid_path[50];
142 char drive[] = "?:\\";
143 DWORD logical_drives;
144
145 ret = GetDiskFreeSpaceA(NULL, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
146 ok(ret, "GetDiskFreeSpaceA error %ld\n", GetLastError());
147
148 ret = GetDiskFreeSpaceA("", &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
150 "GetDiskFreeSpaceA(\"\"): ret=%d GetLastError=%ld\n",
151 ret, GetLastError());
152
153 ret = GetDiskFreeSpaceA("\\", &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
154 ok(ret, "GetDiskFreeSpaceA error %ld\n", GetLastError());
155
156 ret = GetDiskFreeSpaceA("/", &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
157 ok(ret, "GetDiskFreeSpaceA error %ld\n", GetLastError());
158
159 ret = GetDiskFreeSpaceA("C:\\", &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
160 ok(ret, "GetDiskFreeSpaceA error %ld\n", GetLastError());
161
162#ifdef __REACTOS__
164#endif
165 ret = GetVolumeNameForVolumeMountPointA("C:\\", volume_guid_path, ARRAY_SIZE(volume_guid_path));
166 ok(ret, "GetVolumeNameForVolumeMountPointA error %ld\n", GetLastError());
167
168 ret = GetDiskFreeSpaceA(volume_guid_path, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
169 ok(ret, "GetDiskFreeSpaceA error %ld\n", GetLastError());
170#ifdef __REACTOS__
171 }
172#endif
173
174 logical_drives = GetLogicalDrives();
175 ok(logical_drives != 0, "GetLogicalDrives error %ld\n", GetLastError());
176
177 for (drive[0] = 'A'; drive[0] <= 'Z'; drive[0]++)
178 {
179 UINT drivetype = GetDriveTypeA(drive);
180 /* Skip floppy drives because NT pops up a MessageBox if no
181 * floppy is present
182 */
183 if (drivetype != DRIVE_REMOVABLE && drivetype != DRIVE_NO_ROOT_DIR)
184 {
185 ret = GetDiskFreeSpaceA(drive, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
186 if (!(logical_drives & 1))
188 "GetDiskFreeSpaceA(%s): ret=%d GetLastError=%ld\n",
190 else
191 {
192
193 if (!ret)
194 /* GetDiskFreeSpaceA() should succeed, but it can fail with too many
195 different GetLastError() results to be usable for an ok() */
196 trace("GetDiskFreeSpaceA(%s) failed with %ld\n", drive, GetLastError());
197
198 if( GetVersion() & 0x80000000)
199 /* win3.0 through winME */
200 ok( total_clusters <= 65535,
201 "total clusters is %ld > 65535\n", total_clusters);
202 else if (pGetDiskFreeSpaceExA) {
203 /* NT, 2k, XP : GetDiskFreeSpace should be accurate */
204 ULARGE_INTEGER totEx, tot, d;
205
207 tot.QuadPart = (tot.QuadPart * bytes_per_sector) * total_clusters;
208 ret = pGetDiskFreeSpaceExA( drive, &d, &totEx, NULL);
209
210 if (!ret)
211 /* GetDiskFreeSpaceExA() should succeed, but it can fail with too many
212 different GetLastError() results to be usable for an ok() */
213 trace("GetDiskFreeSpaceExA(%s) failed with %ld\n", drive, GetLastError());
214
215 ok( bytes_per_sector == 0 || /* empty cd rom drive */
216 totEx.QuadPart <= tot.QuadPart,
217 "GetDiskFreeSpaceA should report at least as much bytes on disk %s as GetDiskFreeSpaceExA\n", drive);
218 }
219 }
220 }
221 logical_drives >>= 1;
222 }
223}
224
225static void test_GetDiskFreeSpaceW(void)
226{
227 BOOL ret;
228 DWORD sectors_per_cluster, bytes_per_sector, free_clusters, total_clusters;
229 WCHAR volume_guid_path[50];
230 WCHAR drive[] = {'?',':','\\',0};
231 DWORD logical_drives;
232 static const WCHAR empty_pathW[] = { 0 };
233 static const WCHAR root_pathW[] = { '\\', 0 };
234 static const WCHAR unix_style_root_pathW[] = { '/', 0 };
235 static const WCHAR c_drive_pathW[] = { 'C', ':', '\\', 0 };
236
237 ret = GetDiskFreeSpaceW(NULL, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
239 {
240 win_skip("GetDiskFreeSpaceW is not available\n");
241 return;
242 }
243 ok(ret, "GetDiskFreeSpaceW error %ld\n", GetLastError());
244
245 ret = GetDiskFreeSpaceW(empty_pathW, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
247 "GetDiskFreeSpaceW(\"\"): ret=%d GetLastError=%ld\n",
248 ret, GetLastError());
249
250 ret = GetDiskFreeSpaceW(root_pathW, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
251 ok(ret, "GetDiskFreeSpaceW(\"\") error %ld\n", GetLastError());
252
253 ret = GetDiskFreeSpaceW(unix_style_root_pathW, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
254 ok(ret, "GetDiskFreeSpaceW error %ld\n", GetLastError());
255
256 ret = GetDiskFreeSpaceW(c_drive_pathW, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
257 ok(ret, "GetDiskFreeSpaceW error %ld\n", GetLastError());
258
259 ret = GetVolumeNameForVolumeMountPointW(c_drive_pathW, volume_guid_path, ARRAY_SIZE(volume_guid_path));
260 ok(ret, "GetVolumeNameForVolumeMountPointW error %ld\n", GetLastError());
261
262 ret = GetDiskFreeSpaceW(volume_guid_path, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
263 ok(ret, "GetDiskFreeSpaceW error %ld\n", GetLastError());
264
265 logical_drives = GetLogicalDrives();
266 ok(logical_drives != 0, "GetLogicalDrives error %ld\n", GetLastError());
267
268 for (drive[0] = 'A'; drive[0] <= 'Z'; drive[0]++)
269 {
270 UINT drivetype = GetDriveTypeW(drive);
271 /* Skip floppy drives because NT4 pops up a MessageBox if no floppy is present */
272 if (drivetype != DRIVE_REMOVABLE && drivetype != DRIVE_NO_ROOT_DIR)
273 {
274 ret = GetDiskFreeSpaceW(drive, &sectors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
275 if (!(logical_drives & 1))
277 "GetDiskFreeSpaceW(%c): ret=%d GetLastError=%ld\n",
278 drive[0], ret, GetLastError());
279 else if (!ret)
280 /* GetDiskFreeSpaceW() should succeed, but it can fail with too many
281 different GetLastError() results to be usable for an ok() */
282 trace("GetDiskFreeSpaceW(%c) failed with %ld\n", drive[0], GetLastError());
283 }
284 logical_drives >>= 1;
285 }
286}
287
289{
290 HANDLE hkernel32 = GetModuleHandleA("kernel32");
291 pGetDiskFreeSpaceExA = (void *) GetProcAddress(hkernel32, "GetDiskFreeSpaceExA");
292
295
298}
#define GetNTVersion()
Definition: apitest.h:17
#define trace
Definition: atltest.h:70
#define ok(value,...)
Definition: atltest.h:57
#define skip(...)
Definition: atltest.h:64
#define START_TEST(x)
Definition: atltest.h:75
#define ARRAY_SIZE(A)
Definition: main.h:20
#define NULL
Definition: types.h:112
#define ERROR_CALL_NOT_IMPLEMENTED
Definition: compat.h:102
#define GetProcAddress(x, y)
Definition: compat.h:753
#define ERROR_INVALID_NAME
Definition: compat.h:103
UINT WINAPI GetDriveTypeA(IN LPCSTR lpRootPathName)
Definition: disk.c:468
UINT WINAPI GetDriveTypeW(IN LPCWSTR lpRootPathName)
Definition: disk.c:497
BOOL WINAPI GetDiskFreeSpaceW(IN LPCWSTR lpRootPathName, OUT LPDWORD lpSectorsPerCluster, OUT LPDWORD lpBytesPerSector, OUT LPDWORD lpNumberOfFreeClusters, OUT LPDWORD lpTotalNumberOfClusters)
Definition: disk.c:173
BOOL WINAPI GetDiskFreeSpaceA(IN LPCSTR lpRootPathName, OUT LPDWORD lpSectorsPerCluster, OUT LPDWORD lpBytesPerSector, OUT LPDWORD lpNumberOfFreeClusters, OUT LPDWORD lpTotalNumberOfClusters)
Definition: disk.c:142
HMODULE WINAPI DECLSPEC_HOTPATCH GetModuleHandleA(LPCSTR lpModuleName)
Definition: loader.c:812
DWORD WINAPI GetVersion(void)
Definition: version.c:1458
DWORD WINAPI DECLSPEC_HOTPATCH GetLogicalDrives(void)
Definition: volume.c:513
return ret
Definition: mutex.c:146
unsigned int BOOL
Definition: ntddk_ex.h:94
unsigned long DWORD
Definition: ntddk_ex.h:95
GLuint GLuint GLsizei GLenum type
Definition: gl.h:1545
#define d
Definition: ke_i.h:81
#define wine_dbgstr_w
Definition: kernel32.h:34
#define win_skip
Definition: minitest.h:67
static int sectors_per_cluster
Definition: mkdosfs.c:546
BOOL WINAPI GetVolumeNameForVolumeMountPointA(IN LPCSTR lpszVolumeMountPoint, IN LPSTR lpszVolumeName, IN DWORD cchBufferLength)
Definition: mntpoint.c:518
BOOL WINAPI GetVolumeNameForVolumeMountPointW(IN LPCWSTR VolumeMountPoint, OUT LPWSTR VolumeName, IN DWORD VolumeNameLength)
Definition: mntpoint.c:496
static void test_GetDiskFreeSpaceW(void)
Definition: drive.c:225
static void test_GetDriveTypeA(void)
Definition: drive.c:30
static void test_GetDriveTypeW(void)
Definition: drive.c:83
static void test_GetDiskFreeSpaceA(void)
Definition: drive.c:137
static PULARGE_INTEGER
Definition: drive.c:28
static HINSTANCE hkernel32
Definition: process.c:68
unsigned int UINT
Definition: ndis.h:50
#define DWORD
Definition: nt_native.h:44
#define _WIN32_WINNT_VISTA
Definition: sdkddkver.h:25
ULONGLONG QuadPart
Definition: ms-dtyp.idl:185
#define DRIVE_UNKNOWN
Definition: winbase.h:280
#define DRIVE_NO_ROOT_DIR
Definition: winbase.h:281
DWORD WINAPI GetLastError(void)
Definition: except.c:1042
#define DRIVE_RAMDISK
Definition: winbase.h:279
#define DRIVE_REMOVABLE
Definition: winbase.h:275
#define WINAPI
Definition: msvc.h:6
#define ERROR_PATH_NOT_FOUND
Definition: winerror.h:228
#define ERROR_INVALID_DRIVE
Definition: winerror.h:240
const char * LPCSTR
Definition: xmlstorage.h:183
__wchar_t WCHAR
Definition: xmlstorage.h:180