2002-08-27 03:56:08 +02:00
|
|
|
/*
|
|
|
|
* Unit test suite for drive functions.
|
|
|
|
*
|
|
|
|
* Copyright 2002 Dmitry Timoshkov
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "wine/test.h"
|
|
|
|
#include "winbase.h"
|
|
|
|
#include "winerror.h"
|
|
|
|
|
|
|
|
void test_GetDriveTypeA(void)
|
|
|
|
{
|
|
|
|
char drive[] = "?:\\";
|
|
|
|
DWORD logical_drives;
|
|
|
|
UINT type;
|
|
|
|
|
|
|
|
logical_drives = GetLogicalDrives();
|
|
|
|
ok(logical_drives != 0, "GetLogicalDrives error %ld", GetLastError());
|
|
|
|
|
|
|
|
for (drive[0] = 'A'; drive[0] <= 'Z'; drive[0]++)
|
|
|
|
{
|
|
|
|
type = GetDriveTypeA(drive);
|
|
|
|
ok(type > 0 && type <= 6, "not a valid drive %c: type %u", drive[0], type);
|
|
|
|
|
|
|
|
if (!(logical_drives & 1))
|
|
|
|
ok(type == DRIVE_NO_ROOT_DIR,
|
2002-11-30 20:02:53 +01:00
|
|
|
"GetDriveTypeA should return DRIVE_NO_ROOT_DIR for inexistant drive %c: but not %u",
|
2002-08-27 03:56:08 +02:00
|
|
|
drive[0], type);
|
|
|
|
|
|
|
|
logical_drives >>= 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void test_GetDriveTypeW(void)
|
|
|
|
{
|
|
|
|
WCHAR drive[] = {'?',':','\\',0};
|
|
|
|
DWORD logical_drives;
|
|
|
|
UINT type;
|
|
|
|
|
|
|
|
logical_drives = GetLogicalDrives();
|
|
|
|
ok(logical_drives != 0, "GetLogicalDrives error %ld", GetLastError());
|
|
|
|
|
|
|
|
for (drive[0] = 'A'; drive[0] <= 'Z'; drive[0]++)
|
|
|
|
{
|
|
|
|
type = GetDriveTypeW(drive);
|
2002-11-30 20:02:53 +01:00
|
|
|
if (type == DRIVE_UNKNOWN && GetLastError()==ERROR_CALL_NOT_IMPLEMENTED)
|
|
|
|
{
|
|
|
|
/* Must be Win9x which doesn't support the Unicode functions */
|
|
|
|
return;
|
|
|
|
}
|
2002-08-27 03:56:08 +02:00
|
|
|
ok(type > 0 && type <= 6, "not a valid drive %c: type %u", drive[0], type);
|
|
|
|
|
|
|
|
if (!(logical_drives & 1))
|
|
|
|
ok(type == DRIVE_NO_ROOT_DIR,
|
2002-11-30 20:02:53 +01:00
|
|
|
"GetDriveTypeW should return DRIVE_NO_ROOT_DIR for inexistant drive %c: but not %u",
|
2002-08-27 03:56:08 +02:00
|
|
|
drive[0], type);
|
|
|
|
|
|
|
|
logical_drives >>= 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void test_GetDiskFreeSpaceA(void)
|
|
|
|
{
|
|
|
|
BOOL ret;
|
|
|
|
DWORD sectors_per_cluster, bytes_per_sector, free_clusters, total_clusters;
|
|
|
|
char drive[] = "?:\\";
|
|
|
|
DWORD logical_drives;
|
|
|
|
|
|
|
|
ret = GetDiskFreeSpaceA(NULL, §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
|
|
|
ok(ret, "GetDiskFreeSpaceA error %ld", GetLastError());
|
|
|
|
|
|
|
|
ret = GetDiskFreeSpaceA("", §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
2002-11-30 20:02:53 +01:00
|
|
|
ok(!ret && (GetLastError() == ERROR_PATH_NOT_FOUND || GetLastError() == ERROR_INVALID_NAME),
|
|
|
|
"GetDiskFreeSpaceA(\"\"): ret=%d GetLastError=%ld",
|
|
|
|
ret, GetLastError());
|
2002-08-27 03:56:08 +02:00
|
|
|
|
|
|
|
ret = GetDiskFreeSpaceA("\\", §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
|
|
|
ok(ret, "GetDiskFreeSpaceA error %ld", GetLastError());
|
|
|
|
|
|
|
|
ret = GetDiskFreeSpaceA("/", §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
|
|
|
ok(ret, "GetDiskFreeSpaceA error %ld", GetLastError());
|
|
|
|
|
|
|
|
logical_drives = GetLogicalDrives();
|
|
|
|
ok(logical_drives != 0, "GetLogicalDrives error %ld", GetLastError());
|
|
|
|
|
|
|
|
for (drive[0] = 'A'; drive[0] <= 'Z'; drive[0]++)
|
|
|
|
{
|
2002-11-30 20:02:53 +01:00
|
|
|
/* Skip floppy drives because NT pops up a MessageBox if no
|
|
|
|
* floppy is present
|
|
|
|
*/
|
|
|
|
if (GetDriveTypeA(drive)!=DRIVE_REMOVABLE)
|
|
|
|
{
|
|
|
|
ret = GetDiskFreeSpaceA(drive, §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
|
|
|
if (!(logical_drives & 1))
|
|
|
|
ok(!ret && (GetLastError() == ERROR_PATH_NOT_FOUND || GetLastError() == ERROR_INVALID_DRIVE),
|
|
|
|
"GetDiskFreeSpaceA(%s): ret=%d GetLastError=%ld",
|
|
|
|
drive, ret, GetLastError());
|
|
|
|
else
|
|
|
|
ok(ret ||
|
|
|
|
(!ret && (GetLastError() == ERROR_NOT_READY || GetLastError() == ERROR_INVALID_DRIVE)),
|
|
|
|
"GetDiskFreeSpaceA(%s): ret=%d GetLastError=%ld",
|
|
|
|
drive, ret, GetLastError());
|
|
|
|
}
|
2002-08-27 03:56:08 +02:00
|
|
|
logical_drives >>= 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void test_GetDiskFreeSpaceW(void)
|
|
|
|
{
|
|
|
|
BOOL ret;
|
|
|
|
DWORD sectors_per_cluster, bytes_per_sector, free_clusters, total_clusters;
|
|
|
|
WCHAR drive[] = {'?',':','\\',0};
|
|
|
|
DWORD logical_drives;
|
|
|
|
static const WCHAR empty_pathW[] = { 0 };
|
|
|
|
static const WCHAR root_pathW[] = { '\\', 0 };
|
|
|
|
static const WCHAR unix_style_root_pathW[] = { '/', 0 };
|
|
|
|
|
|
|
|
ret = GetDiskFreeSpaceW(NULL, §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
2002-11-30 20:02:53 +01:00
|
|
|
if (ret == 0 && GetLastError()==ERROR_CALL_NOT_IMPLEMENTED)
|
|
|
|
{
|
|
|
|
/* Must be Win9x which doesn't support the Unicode functions */
|
|
|
|
return;
|
|
|
|
}
|
2002-08-27 03:56:08 +02:00
|
|
|
ok(ret, "GetDiskFreeSpaceW error %ld", GetLastError());
|
|
|
|
|
|
|
|
ret = GetDiskFreeSpaceW(empty_pathW, §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
2002-11-30 20:02:53 +01:00
|
|
|
ok(!ret && GetLastError() == ERROR_PATH_NOT_FOUND,
|
|
|
|
"GetDiskFreeSpaceW(\"\"): ret=%d GetLastError=%ld",
|
|
|
|
ret, GetLastError());
|
2002-08-27 03:56:08 +02:00
|
|
|
|
|
|
|
ret = GetDiskFreeSpaceW(root_pathW, §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
2002-11-30 20:02:53 +01:00
|
|
|
ok(ret, "GetDiskFreeSpaceW(\"\") error %ld", GetLastError());
|
2002-08-27 03:56:08 +02:00
|
|
|
|
|
|
|
ret = GetDiskFreeSpaceW(unix_style_root_pathW, §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
|
|
|
ok(ret, "GetDiskFreeSpaceW error %ld", GetLastError());
|
|
|
|
|
|
|
|
logical_drives = GetLogicalDrives();
|
|
|
|
ok(logical_drives != 0, "GetLogicalDrives error %ld", GetLastError());
|
|
|
|
|
|
|
|
for (drive[0] = 'A'; drive[0] <= 'Z'; drive[0]++)
|
|
|
|
{
|
2002-11-30 20:02:53 +01:00
|
|
|
/* Skip floppy drives because NT4 pops up a MessageBox if no floppy is present */
|
|
|
|
if (GetDriveTypeW(drive)!=DRIVE_REMOVABLE)
|
|
|
|
{
|
|
|
|
ret = GetDiskFreeSpaceW(drive, §ors_per_cluster, &bytes_per_sector, &free_clusters, &total_clusters);
|
|
|
|
if (!(logical_drives & 1))
|
|
|
|
ok(!ret && GetLastError() == ERROR_PATH_NOT_FOUND,
|
|
|
|
"GetDiskFreeSpaceW(%c): ret=%d GetLastError=%ld",
|
|
|
|
drive[0], ret, GetLastError());
|
|
|
|
else
|
|
|
|
ok(ret || GetLastError() == ERROR_NOT_READY,
|
|
|
|
"GetDiskFreeSpaceW(%c): ret=%d GetLastError=%ld",
|
|
|
|
drive[0], ret, GetLastError());
|
|
|
|
}
|
2002-08-27 03:56:08 +02:00
|
|
|
logical_drives >>= 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
START_TEST(drive)
|
|
|
|
{
|
|
|
|
test_GetDriveTypeA();
|
|
|
|
test_GetDriveTypeW();
|
|
|
|
|
|
|
|
test_GetDiskFreeSpaceA();
|
|
|
|
test_GetDiskFreeSpaceW();
|
|
|
|
}
|