Alexandre Julliard : kernel32/tests: Added tests for FindFirstVolume/ FindNextVolume.
Alexandre Julliard
julliard at winehq.org
Mon Jan 7 08:38:57 CST 2008
Module: wine
Branch: master
Commit: d17b29303cd9075123033f159339f9872c14b227
URL: http://source.winehq.org/git/wine.git/?a=commit;h=d17b29303cd9075123033f159339f9872c14b227
Author: Alexandre Julliard <julliard at winehq.org>
Date: Fri Jan 4 14:31:55 2008 +0100
kernel32/tests: Added tests for FindFirstVolume/FindNextVolume.
---
dlls/kernel32/tests/volume.c | 33 +++++++++++++++++++++++++++++++++
1 files changed, 33 insertions(+), 0 deletions(-)
diff --git a/dlls/kernel32/tests/volume.c b/dlls/kernel32/tests/volume.c
index 0811ce5..94ace87 100644
--- a/dlls/kernel32/tests/volume.c
+++ b/dlls/kernel32/tests/volume.c
@@ -24,6 +24,9 @@
static HINSTANCE hdll;
static BOOL (WINAPI * pGetVolumeNameForVolumeMountPointA)(LPCSTR, LPSTR, DWORD);
static BOOL (WINAPI * pGetVolumeNameForVolumeMountPointW)(LPCWSTR, LPWSTR, DWORD);
+static HANDLE (WINAPI *pFindFirstVolumeA)(LPSTR,DWORD);
+static BOOL (WINAPI *pFindNextVolumeA)(HANDLE,LPSTR,DWORD);
+static BOOL (WINAPI *pFindVolumeClose)(HANDLE);
/* ############################### */
@@ -44,6 +47,32 @@ static void test_query_dos_deviceA(void)
todo_wine ok(found, "expected at least one devicename to contain HARDDISK or RAMDISK\n");
}
+static void test_FindFirstVolume(void)
+{
+ char volume[50];
+ HANDLE handle;
+
+ handle = pFindFirstVolumeA( volume, 0 );
+ ok( handle == INVALID_HANDLE_VALUE, "succeeded with short buffer\n" );
+ ok( GetLastError() == ERROR_FILENAME_EXCED_RANGE, "wrong error %u\n", GetLastError() );
+ handle = pFindFirstVolumeA( volume, 49 );
+ ok( handle == INVALID_HANDLE_VALUE, "succeeded with short buffer\n" );
+ ok( GetLastError() == ERROR_FILENAME_EXCED_RANGE, "wrong error %u\n", GetLastError() );
+ handle = pFindFirstVolumeA( volume, 50 );
+ ok( handle != INVALID_HANDLE_VALUE, "failed err %u\n", GetLastError() );
+ if (handle != INVALID_HANDLE_VALUE)
+ {
+ do
+ {
+ ok( strlen(volume) == 49, "bad volume name %s\n", volume );
+ ok( !memcmp( volume, "\\\\?\\Volume{", 11 ), "bad volume name %s\n", volume );
+ ok( !memcmp( volume + 47, "}\\", 2 ), "bad volume name %s\n", volume );
+ } while (pFindNextVolumeA( handle, volume, MAX_PATH ));
+ ok( GetLastError() == ERROR_NO_MORE_FILES, "wrong error %u\n", GetLastError() );
+ pFindVolumeClose( handle );
+ }
+}
+
static void test_GetVolumeNameForVolumeMountPointA(void)
{
BOOL ret;
@@ -103,8 +132,12 @@ START_TEST(volume)
hdll = GetModuleHandleA("kernel32.dll");
pGetVolumeNameForVolumeMountPointA = (void *) GetProcAddress(hdll, "GetVolumeNameForVolumeMountPointA");
pGetVolumeNameForVolumeMountPointW = (void *) GetProcAddress(hdll, "GetVolumeNameForVolumeMountPointW");
+ pFindFirstVolumeA = (void *) GetProcAddress(hdll, "FindFirstVolumeA");
+ pFindNextVolumeA = (void *) GetProcAddress(hdll, "FindNextVolumeA");
+ pFindVolumeClose = (void *) GetProcAddress(hdll, "FindVolumeClose");
test_query_dos_deviceA();
+ test_FindFirstVolume();
test_GetVolumeNameForVolumeMountPointA();
test_GetVolumeNameForVolumeMountPointW();
}
More information about the wine-cvs
mailing list