kernel32/tests: GetVolumeNameForMountPoint not present before w2k
Detlef Riekenberg
wine.dev at web.de
Sat Jan 20 05:46:34 CST 2007
Changelog:
kernel32/tests: GetVolumeNameForMountPoint not present before w2k
--
By by ... Detlef
-------------- next part --------------
>From 2342f00be8dac7da71e19aac17eb3e4b8dbed3f9 Mon Sep 17 00:00:00 2001
From: Detlef Riekenberg <wine.dev at web.de>
Date: Sat, 20 Jan 2007 12:30:41 +0100
Subject: [PATCH] kernel32/tests: GetVolumeNameForMountPoint not present before w2k
---
dlls/kernel32/tests/volume.c | 38 ++++++++++++++++++++++++++++++--------
1 files changed, 30 insertions(+), 8 deletions(-)
diff --git a/dlls/kernel32/tests/volume.c b/dlls/kernel32/tests/volume.c
index e940a4b..b673947 100644
--- a/dlls/kernel32/tests/volume.c
+++ b/dlls/kernel32/tests/volume.c
@@ -27,6 +27,12 @@ #define HARDISK "HARDDISK"
#define LANMAN "LANMANREDIRECTOR"
#define RAMDISK "RAMDISK"
+static HINSTANCE hdll;
+static BOOL (WINAPI * pGetVolumeNameForVolumeMountPointA)(LPCSTR, LPSTR, DWORD);
+static BOOL (WINAPI * pGetVolumeNameForVolumeMountPointW)(LPCWSTR, LPWSTR, DWORD);
+
+/* ############################### */
+
static void test_query_dos_deviceA(void)
{
char drivestr[] = "a:";
@@ -51,18 +57,24 @@ static void test_GetVolumeNameForVolumeM
char volume[MAX_PATH], path[] = "c:\\";
DWORD len = sizeof(volume);
- ret = GetVolumeNameForVolumeMountPointA(path, volume, 0);
+ /* not present before w2k */
+ if (!pGetVolumeNameForVolumeMountPointA) {
+ skip("GetVolumeNameForVolumeMountPointA not found\n");
+ return;
+ }
+
+ ret = pGetVolumeNameForVolumeMountPointA(path, volume, 0);
ok(ret == FALSE, "GetVolumeNameForVolumeMountPointA succeeded\n");
if (0) { /* these crash on XP */
- ret = GetVolumeNameForVolumeMountPointA(path, NULL, len);
+ ret = pGetVolumeNameForVolumeMountPointA(path, NULL, len);
ok(ret == FALSE, "GetVolumeNameForVolumeMountPointA succeeded\n");
- ret = GetVolumeNameForVolumeMountPointA(NULL, volume, len);
+ ret = pGetVolumeNameForVolumeMountPointA(NULL, volume, len);
ok(ret == FALSE, "GetVolumeNameForVolumeMountPointA succeeded\n");
}
- ret = GetVolumeNameForVolumeMountPointA(path, volume, len);
+ ret = pGetVolumeNameForVolumeMountPointA(path, volume, len);
ok(ret == TRUE, "GetVolumeNameForVolumeMountPointA failed\n");
}
@@ -72,23 +84,33 @@ static void test_GetVolumeNameForVolumeM
WCHAR volume[MAX_PATH], path[] = {'c',':','\\',0};
DWORD len = sizeof(volume) / sizeof(WCHAR);
- ret = GetVolumeNameForVolumeMountPointW(path, volume, 0);
+ /* not present before w2k */
+ if (!pGetVolumeNameForVolumeMountPointW) {
+ skip("GetVolumeNameForVolumeMountPointW not found\n");
+ return;
+ }
+
+ ret = pGetVolumeNameForVolumeMountPointW(path, volume, 0);
ok(ret == FALSE, "GetVolumeNameForVolumeMountPointA succeeded\n");
if (0) { /* these crash on XP */
- ret = GetVolumeNameForVolumeMountPointW(path, NULL, len);
+ ret = pGetVolumeNameForVolumeMountPointW(path, NULL, len);
ok(ret == FALSE, "GetVolumeNameForVolumeMountPointW succeeded\n");
- ret = GetVolumeNameForVolumeMountPointW(NULL, volume, len);
+ ret = pGetVolumeNameForVolumeMountPointW(NULL, volume, len);
ok(ret == FALSE, "GetVolumeNameForVolumeMountPointW succeeded\n");
}
- ret = GetVolumeNameForVolumeMountPointW(path, volume, len);
+ ret = pGetVolumeNameForVolumeMountPointW(path, volume, len);
ok(ret == TRUE, "GetVolumeNameForVolumeMountPointW failed\n");
}
START_TEST(volume)
{
+ hdll = GetModuleHandleA("kernel32.dll");
+ pGetVolumeNameForVolumeMountPointA = (void *) GetProcAddress(hdll, "GetVolumeNameForVolumeMountPointA");
+ pGetVolumeNameForVolumeMountPointW = (void *) GetProcAddress(hdll, "GetVolumeNameForVolumeMountPointW");
+
test_query_dos_deviceA();
test_GetVolumeNameForVolumeMountPointA();
test_GetVolumeNameForVolumeMountPointW();
--
1.4.1
More information about the wine-patches
mailing list