Author: ilardig
Date: Tue May 10 16:11:30 2011
New Revision: 51669

URL: http://svn.reactos.org/svn/reactos?rev=51669&view=rev
Log:
[KERNEL32_WINETEST]
Sam Arun Raj Seeniraj: Update kernel32 winetests for dos device.
See bug 993 for details.

Modified:
    trunk/rostests/winetests/kernel32/dosdev.c

Modified: trunk/rostests/winetests/kernel32/dosdev.c
URL: 
http://svn.reactos.org/svn/reactos/trunk/rostests/winetests/kernel32/dosdev.c?rev=51669&r1=51668&r2=51669&view=diff
==============================================================================
--- trunk/rostests/winetests/kernel32/dosdev.c [iso-8859-1] (original)
+++ trunk/rostests/winetests/kernel32/dosdev.c [iso-8859-1] Tue May 10 16:11:30 
2011
@@ -25,204 +25,362 @@
 #include "winbase.h"
 #include "winerror.h"
 
-static void test_DefineDosDeviceA1(void)
+#define SUBST_DRIVE_LETTER 'M'
+#define SUBST_DRIVE "M:"
+#define SUBST_DRIVE_NON_EXIST_DIR "M:\\deadbeef"
+#define SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR "M:\\"
+#define SUBST_DRIVE_SEARCH "M:\\*"
+#define SUBST_DRIVE_LOWERCASE "m:"
+#define SUBST_DRIVE_LOWERCASE_SEARCH "m:\\*"
+#define SUBST_DRIVE2_LETTER 'R'
+#define SUBST_DRIVE2 "R:"
+#define SUBST_DRIVE2_WITH_TRAILING_PATH_SEPERATOR "R:\\"
+#define SUBST_DRIVE2_SEARCH "R:\\*"
+
+static void test_DefineDosDeviceA(void)
 {
-    /* Test using lowercase drive letters */
-    CHAR Target[MAX_PATH];
-    CHAR Drive[] = "m:";
+    CHAR Buffer[MAX_PATH], Target[MAX_PATH];
     BOOL Result;
-
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp");
+    UINT CharCount;
+    HANDLE hnd;
+    WIN32_FIND_DATAA Data;
+    UINT SystemDriveType, DriveType1, DriveType2;
+    DWORD dwMaskPrev, dwMaskCur;
+    CHAR c;
+
+    /* Choose the symbolic link target */
+    CharCount = GetSystemWindowsDirectoryA(Target, MAX_PATH);
+    ok(CharCount > 0, "Failed to get windows directory\n");
+    c = Target[3];
+    Target[3] = '\0';
+    SystemDriveType = GetDriveTypeA(Target);
+    Target[3] = c;
+
+    /* Test with a subst drive pointing to another substed drive */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, Target);
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    Result = DefineDosDeviceA(0, SUBST_DRIVE2, SUBST_DRIVE);
+    ok(Result, "Failed to subst drive\n");
+    DriveType2 = GetDriveTypeA(SUBST_DRIVE2_WITH_TRAILING_PATH_SEPERATOR);
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE2_LETTER - 'A'))), "Drive bit is not 
set\n");
+    hnd = FindFirstFileA(SUBST_DRIVE2_SEARCH, &Data);
+    ok(hnd != INVALID_HANDLE_VALUE, "Failed to open subst drive\n");
+    if (hnd) FindClose(hnd);
+    ok(DriveType1 == DriveType2, "subst drive types don't match\n");
+    ok(DriveType1 == SystemDriveType, "subst drive types don't match\n");
+    ok(DriveType2 == SystemDriveType, "subst drive types don't match\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, Target);
+    ok(Result, "Failed to remove subst drive using NULL Target name\n");
+    hnd = FindFirstFileA(SUBST_DRIVE2_SEARCH, &Data);
+    ok(hnd == INVALID_HANDLE_VALUE, "Opened subst drive when it should fail, 
we removed the target\n");
+    if (hnd) FindClose(hnd);
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE2, SUBST_DRIVE);
+    ok(Result, "Failed to remove subst drive using NULL Target name\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE2, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test using lowercase drive letter */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE_LOWERCASE, Target);
     ok(Result, "Failed to subst drive using lowercase drive letter\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 == SystemDriveType, "subst drive types don't match\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    hnd = FindFirstFileA(SUBST_DRIVE_SEARCH, &Data);
+    ok(hnd != INVALID_HANDLE_VALUE, "Failed to open subst drive\n");
+    if (hnd) FindClose(hnd);
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE_LOWERCASE, Target);
     ok(Result, "Failed to remove subst drive using lowercase drive letter\n");
-
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(!Result, "Subst drive is present even after remove attempt\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE_LOWERCASE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test remove without using DDD_EXACT_MATCH_ON_REMOVE */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, Target);
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 == SystemDriveType, "subst drive types don't match\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    hnd = FindFirstFileA(SUBST_DRIVE_SEARCH, &Data);
+    ok(hnd != INVALID_HANDLE_VALUE, "Failed to open subst drive\n");
+    if (hnd) FindClose(hnd);
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION, SUBST_DRIVE, NULL);
+    ok(Result, "Failed to remove subst drive using NULL Target name\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test multiple adds and multiple removes in add order */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp1");
+    ok(Result, "Failed to subst drive\n");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp2");
+    ok(Result, "Failed to subst drive\n");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp3");
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 != SystemDriveType, "subst drive types match when it 
shouldn't\n");
+    ok(GetLastError() == ERROR_FILE_NOT_FOUND, "GetLastError() reports 
unexpected error code\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp1");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "Failed to query subst drive\n");
+    if (Result) ok((_stricmp(Buffer, "\\??\\C:\\temp3") == 0), "Subst drive is 
not pointing to correct target\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp2");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "Failed to query subst drive\n");
+    if (Result) ok((_stricmp(Buffer, "\\??\\C:\\temp3") == 0), "Subst drive is 
not pointing to correct target\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp3");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test multiple adds and multiple removes in reverse order */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp1");
+    ok(Result, "Failed to subst drive\n");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp2");
+    ok(Result, "Failed to subst drive\n");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp3");
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 != SystemDriveType, "subst drive types match when it 
shouldn't\n");
+    ok(GetLastError() == ERROR_FILE_NOT_FOUND, "GetLastError() reports 
unexpected error code\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp3");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "Failed to query subst drive\n");
+    if (Result) ok((_stricmp(Buffer, "\\??\\C:\\temp2") == 0), "Subst drive is 
not pointing to correct target\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp2");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "Failed to query subst drive\n");
+    if (Result) ok((_stricmp(Buffer, "\\??\\C:\\temp1") == 0), "Subst drive is 
not pointing to correct target\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp1");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test multiple adds and multiple removes out of order */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp1");
+    ok(Result, "Failed to subst drive\n");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp2");
+    ok(Result, "Failed to subst drive\n");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp3");
+    ok(Result, "Failed to subst drive\n");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp4");
+    ok(Result, "Failed to subst drive\n");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, "C:\\temp5");
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 != SystemDriveType, "subst drive types match when it 
shouldn't\n");
+    ok(GetLastError() == ERROR_FILE_NOT_FOUND, "GetLastError() reports 
unexpected error code\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp2");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "Failed to query subst drive\n");
+    if (Result) ok((_stricmp(Buffer, "\\??\\C:\\temp5") == 0), "Subst drive is 
not pointing to correct target\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp5");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "Failed to query subst drive\n");
+    if (Result) ok((_stricmp(Buffer, "\\??\\C:\\temp4") == 0), "Subst drive is 
not pointing to correct target\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp1");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "Failed to query subst drive\n");
+    if (Result) ok((_stricmp(Buffer, "\\??\\C:\\temp4") == 0), "Subst drive is 
not pointing to correct target\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp3");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "Failed to query subst drive\n");
+    if (Result) ok((_stricmp(Buffer, "\\??\\C:\\temp4") == 0), "Subst drive is 
not pointing to correct target");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, "C:\\temp4");
+    ok(Result, "Failed to remove subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test with trailing '\' appended to TargetPath */
+    dwMaskPrev = GetLogicalDrives();
+    strcpy_s(Buffer, MAX_PATH, Target);
+    strcat_s(Buffer, MAX_PATH, "\\\\\\");
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, Buffer);
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 == SystemDriveType, "subst drive types don't match\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    hnd = FindFirstFileA(SUBST_DRIVE_SEARCH, &Data);
+    ok(hnd != INVALID_HANDLE_VALUE, "Failed to open subst drive\n");
+    if (hnd) FindClose(hnd);
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, Buffer);
+    ok(Result, "Failed to remove subst drive using NULL Target name\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test with trailing '\' appended to TargetPath and DDD_RAW_TARGET_PATH 
flag */
+    dwMaskPrev = GetLogicalDrives();
+    strcpy_s(Buffer, MAX_PATH, "\\??\\");
+    strcat_s(Buffer, MAX_PATH, Target);
+    strcat_s(Buffer, MAX_PATH, "\\\\\\");
+    Result = DefineDosDeviceA(DDD_RAW_TARGET_PATH, SUBST_DRIVE, Buffer);
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 != SystemDriveType, "subst drive types match when they 
shouldn't\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    hnd = FindFirstFileA(SUBST_DRIVE_SEARCH, &Data);
+    ok(hnd == INVALID_HANDLE_VALUE, "Opened subst drive when it should 
fail\n");
+    ok(GetLastError() == ERROR_INVALID_NAME, "GetLastError() reports 
unexpected error code\n");
+    if (hnd) FindClose(hnd);
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION, SUBST_DRIVE, NULL);
+    ok(Result, "Failed to remove subst drive using NULL Target name\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test using trailing \ against drive letter */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR, 
Target);
+    ok(!Result, "Subst drive using trailing path seperator, this should not 
happen\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 != SystemDriveType, "subst drive types match when it 
shouldn't\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+    ok(!(dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is set 
when it shouldn't\n");
+    hnd = FindFirstFileA(SUBST_DRIVE_SEARCH, &Data);
+    ok(hnd == INVALID_HANDLE_VALUE, "Opened subst drive when it should 
fail\n");
+    if (hnd) FindClose(hnd);
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR, Target);
+    ok(!Result, "Removing Subst drive using trailing path seperator passed 
when it should fail\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR, Buffer, 
MAX_PATH);
+    ok(!Result, "Subst drive is present when it should not be created in the 
first place\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test using arbitary string, not necessarily a DOS drive letter */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, "!QHello:", Target);
+    ok(Result, "Failed to subst drive using non-DOS drive name\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, "!QHello:", Target);
+    ok(Result, "Failed to subst drive using non-DOS drive name\n");
+    Result = QueryDosDeviceA("!QHello:", Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test by subst a drive to itself */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, SUBST_DRIVE);
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 != SystemDriveType, "subst drive types match when it 
shouldn't\n");
+    ok(GetLastError() == ERROR_FILE_NOT_FOUND, "GetLastError() reports 
unexpected error code\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    hnd = FindFirstFileA(SUBST_DRIVE_SEARCH, &Data);
+    ok(hnd == INVALID_HANDLE_VALUE, "Opened subst drive when it should 
fail\n");
+    if (hnd) FindClose(hnd);
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, SUBST_DRIVE);
+    ok(Result, "Failed to remove subst drive using lowercase drive letter\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
+
+    /* Test by subst a drive to an non-existent folder under itself */
+    dwMaskPrev = GetLogicalDrives();
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, SUBST_DRIVE_NON_EXIST_DIR);
+    ok(Result, "Failed to subst drive\n");
+    DriveType1 = GetDriveTypeA(SUBST_DRIVE_WITH_TRAILING_PATH_SEPERATOR);
+    ok(DriveType1 != SystemDriveType, "subst drive types match when it 
shouldn't\n");
+    ok(GetLastError() == ERROR_FILE_NOT_FOUND, "GetLastError() reports 
unexpected error code\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur != dwMaskPrev, "Drive masks match when it shouldn't\n");
+    ok((dwMaskCur & (1 << (SUBST_DRIVE_LETTER - 'A'))), "Drive bit is not 
set\n");
+    hnd = FindFirstFileA(SUBST_DRIVE_SEARCH, &Data);
+    ok(hnd == INVALID_HANDLE_VALUE, "Opened subst drive when it should 
fail\n");
+    if (hnd) FindClose(hnd);
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, SUBST_DRIVE_NON_EXIST_DIR);
+    ok(Result, "Failed to remove subst drive using lowercase drive letter\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(!Result, "Subst drive is present even after remove attempt\n");
+    dwMaskCur = GetLogicalDrives();
+    ok(dwMaskCur == dwMaskPrev, "Drive masks don't match\n");
 }
 
-static void test_DefineDosDeviceA2(void)
+static void test_QueryDosDeviceA(void)
 {
-    /* Test using trailing \ against drive letter */
-    CHAR Target[MAX_PATH];
-    CHAR Drive[] = "Q:\\";
+    CHAR Buffer[MAX_PATH], Target[MAX_PATH];
     BOOL Result;
-
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp");
-    ok(!Result, "Subst drive using trailing path seperator\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp");
-    ok(!Result, "Subst drive using trailing path seperator\n");
-
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(!Result, "Subst drive is present when it should not be created in the 
first place\n");
-}
-
-static void test_DefineDosDeviceA3(void)
-{
-    /* Test using arbitary string, not necessarily a DOS drive letter */
-    CHAR Target[MAX_PATH];
-    CHAR Drive[] = "!QHello:";
-    BOOL Result;
-
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp");
-    ok(Result, "Failed to subst drive using non-DOS drive name\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp");
-    ok(Result, "Failed to subst drive using non-DOS drive name\n");
-
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(!Result, "Subst drive is present even after remove attempt\n");
-}
-
-static void test_DefineDosDeviceA4(void)
-{
-    /* Test remove without using DDD_EXACT_MATCH_ON_REMOVE */
-    CHAR Target[MAX_PATH];
-    CHAR Drive[] = "M:";
-    BOOL Result;
-
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp");
-    ok(Result, "Failed to subst drive\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION, Drive, NULL);
-    ok(Result, "Failed to remove subst drive using NULL Target name\n");
-
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(!Result, "Subst drive is present even after remove attempt\n");
-}
-
-static void test_DefineDosDeviceA5(void)
-{
-    /* Test multiple adds and multiple removes in add order */
-    CHAR Target[MAX_PATH];
-    CHAR Drive[] = "M:";
-    BOOL Result;
-
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp1");
-    ok(Result, "Failed to subst drive\n");
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp2");
-    ok(Result, "Failed to subst drive\n");
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp3");
-    ok(Result, "Failed to subst drive\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp1");
-    ok(Result, "Failed to remove subst drive\n");
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(Result, "Failed to query subst drive\n");
-    if (Result)
-        ok((_stricmp(Target, "\\??\\C:\\temp3") == 0), "Subst drive is not 
pointing to correct target\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp2");
-    ok(Result, "Failed to remove subst drive\n");
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(Result, "Failed to query subst drive\n");
-    if (Result)
-        ok((_stricmp(Target, "\\??\\C:\\temp3") == 0), "Subst drive is not 
pointing to correct target\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp3");
-    ok(Result, "Failed to remove subst drive\n");
-
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(!Result, "Subst drive is present even after remove attempt\n");
-}
-
-static void test_DefineDosDeviceA6(void)
-{
-    /* Test multiple adds and multiple removes in reverse order */
-    CHAR Target[MAX_PATH];
-    CHAR Drive[] = "M:";
-    BOOL Result;
-
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp1");
-    ok(Result, "Failed to subst drive\n");
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp2");
-    ok(Result, "Failed to subst drive\n");
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp3");
-    ok(Result, "Failed to subst drive\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp3");
-    ok(Result, "Failed to remove subst drive\n");
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(Result, "Failed to query subst drive\n");
-    if (Result)
-        ok((_stricmp(Target, "\\??\\C:\\temp2") == 0), "Subst drive is not 
pointing to correct target\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp2");
-    ok(Result, "Failed to remove subst drive\n");
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(Result, "Failed to query subst drive\n");
-    if (Result)
-        ok((_stricmp(Target, "\\??\\C:\\temp1") == 0), "Subst drive is not 
pointing to correct target\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp1");
-    ok(Result, "Failed to remove subst drive\n");
-
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(!Result, "Subst drive is present even after remove attempt\n");
-}
-
-static void test_DefineDosDeviceA7(void)
-{
-    /* Test multiple adds and multiple removes out of order */
-    CHAR Target[MAX_PATH];
-    CHAR Drive[] = "M:";
-    BOOL Result;
-
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp1");
-    ok(Result, "Failed to subst drive\n");
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp2");
-    ok(Result, "Failed to subst drive\n");
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp3");
-    ok(Result, "Failed to subst drive\n");
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp4");
-    ok(Result, "Failed to subst drive\n");
-    Result = DefineDosDeviceA(0, Drive, "C:\\temp5");
-    ok(Result, "Failed to subst drive\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp2");
-    ok(Result, "Failed to remove subst drive\n");
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(Result, "Failed to query subst drive\n");
-    if (Result)
-        ok((_stricmp(Target, "\\??\\C:\\temp5") == 0), "Subst drive is not 
pointing to correct target\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp5");
-    ok(Result, "Failed to remove subst drive\n");
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(Result, "Failed to query subst drive\n");
-    if (Result)
-        ok((_stricmp(Target, "\\??\\C:\\temp4") == 0), "Subst drive is not 
pointing to correct target\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp1");
-    ok(Result, "Failed to remove subst drive\n");
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(Result, "Failed to query subst drive\n");
-    if (Result)
-        ok((_stricmp(Target, "\\??\\C:\\temp4") == 0), "Subst drive is not 
pointing to correct target\n");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp3");
-    ok(Result, "Failed to remove subst drive\n");
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(Result, "Failed to query subst drive\n");
-    if (Result)
-        ok((_stricmp(Target, "\\??\\C:\\temp4") == 0), "Subst drive is not 
pointing to correct target");
-
-    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, Drive, "C:\\temp4");
-    ok(Result, "Failed to remove subst drive\n");
-
-    Result = QueryDosDeviceA(Drive, Target, MAX_PATH);
-    ok(!Result, "Subst drive is present even after remove attempt\n");
+    UINT CharCount;
+
+    /* Choose the symbolic link target */
+    CharCount = GetSystemWindowsDirectoryA(Target, MAX_PATH);
+    ok(CharCount > 0, "Failed to get windows directory\n");
+
+    Result = DefineDosDeviceA(0, SUBST_DRIVE, Target);
+    ok(Result, "Failed to subst drive\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, 0);
+    ok(!Result, "Should fail as the buffer passed is supposed to be small\n");
+    ok(GetLastError() == ERROR_INSUFFICIENT_BUFFER, "GetLastError() reports 
unexpected error code\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+    ok(Result, "failed to get target path\n");
+    ok(_strnicmp(Buffer, "\\??\\", 4) == 0, "The target returned does have 
correct prefix set\n");
+    ok(stricmp(&Buffer[4], Target) == 0, "The target returned does not match 
the one set\n");
+    Result = DefineDosDeviceA(DDD_REMOVE_DEFINITION | 
DDD_EXACT_MATCH_ON_REMOVE, SUBST_DRIVE, Target);
+    ok(Result, "Failed to remove subst drive using lowercase drive letter\n");
+    Result = QueryDosDeviceA(SUBST_DRIVE, Buffer, MAX_PATH);
+
+    /* This will try to retrieve all existing MS-DOS device names */
+    Result = QueryDosDeviceA(NULL, Buffer, 0);
+    ok(!Result, "Should fail as the buffer passed is supposed to be small\n");
+    ok(GetLastError() == ERROR_INSUFFICIENT_BUFFER, "GetLastError() reports 
unexpected error code\n");
 }
 
 START_TEST(dosdev)
 {
-    test_DefineDosDeviceA1();
-    test_DefineDosDeviceA2();
-    test_DefineDosDeviceA3();
-    test_DefineDosDeviceA4();
-    test_DefineDosDeviceA5();
-    test_DefineDosDeviceA6();
-    test_DefineDosDeviceA7();
+    test_DefineDosDeviceA();
+    test_QueryDosDeviceA();
 }


Reply via email to