mirror of
https://github.com/reactos/reactos.git
synced 2024-11-06 14:44:19 +00:00
2923acd08c
svn path=/trunk/; revision=66801
321 lines
9.5 KiB
C
321 lines
9.5 KiB
C
/*
|
|
* Misc tests
|
|
*
|
|
* Copyright 2006 Paul Vriens
|
|
*
|
|
* 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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|
*/
|
|
|
|
//#include <stdio.h>
|
|
//#include <windows.h>
|
|
|
|
#include <wine/test.h>
|
|
#include <wingdi.h>
|
|
#include <winuser.h>
|
|
#include <commctrl.h>
|
|
#include "v6util.h"
|
|
|
|
static PVOID (WINAPI * pAlloc)(LONG);
|
|
static PVOID (WINAPI * pReAlloc)(PVOID, LONG);
|
|
static BOOL (WINAPI * pFree)(PVOID);
|
|
static LONG (WINAPI * pGetSize)(PVOID);
|
|
|
|
static INT (WINAPI * pStr_GetPtrA)(LPCSTR, LPSTR, INT);
|
|
static BOOL (WINAPI * pStr_SetPtrA)(LPSTR, LPCSTR);
|
|
static INT (WINAPI * pStr_GetPtrW)(LPCWSTR, LPWSTR, INT);
|
|
static BOOL (WINAPI * pStr_SetPtrW)(LPWSTR, LPCWSTR);
|
|
|
|
static HRESULT (WINAPI * LoadIconMetric)(HINSTANCE, PCWSTR, INT, HICON*);
|
|
|
|
static HMODULE hComctl32 = 0;
|
|
|
|
#define COMCTL32_GET_PROC(ordinal, func) \
|
|
p ## func = (void*)GetProcAddress(hComctl32, (LPSTR)ordinal); \
|
|
if(!p ## func) { \
|
|
trace("GetProcAddress(%d)(%s) failed\n", ordinal, #func); \
|
|
FreeLibrary(hComctl32); \
|
|
}
|
|
|
|
static BOOL InitFunctionPtrs(void)
|
|
{
|
|
hComctl32 = LoadLibraryA("comctl32.dll");
|
|
|
|
if(!hComctl32)
|
|
{
|
|
trace("Could not load comctl32.dll\n");
|
|
return FALSE;
|
|
}
|
|
|
|
COMCTL32_GET_PROC(71, Alloc);
|
|
COMCTL32_GET_PROC(72, ReAlloc);
|
|
COMCTL32_GET_PROC(73, Free);
|
|
COMCTL32_GET_PROC(74, GetSize);
|
|
|
|
COMCTL32_GET_PROC(233, Str_GetPtrA)
|
|
COMCTL32_GET_PROC(234, Str_SetPtrA)
|
|
COMCTL32_GET_PROC(235, Str_GetPtrW)
|
|
COMCTL32_GET_PROC(236, Str_SetPtrW)
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
static void test_GetPtrAW(void)
|
|
{
|
|
if (pStr_GetPtrA)
|
|
{
|
|
static const char source[] = "Just a source string";
|
|
static const char desttest[] = "Just a destination string";
|
|
static char dest[MAX_PATH];
|
|
int sourcelen;
|
|
int destsize = MAX_PATH;
|
|
int count;
|
|
|
|
sourcelen = strlen(source) + 1;
|
|
|
|
count = pStr_GetPtrA(NULL, NULL, 0);
|
|
ok (count == 0, "Expected count to be 0, it was %d\n", count);
|
|
|
|
if (0)
|
|
{
|
|
/* Crashes on W98, NT4, W2K, XP, W2K3
|
|
* Our implementation also crashes and we should probably leave
|
|
* it like that.
|
|
*/
|
|
count = pStr_GetPtrA(NULL, NULL, destsize);
|
|
trace("count : %d\n", count);
|
|
}
|
|
|
|
count = pStr_GetPtrA(source, NULL, 0);
|
|
ok (count == sourcelen ||
|
|
broken(count == sourcelen - 1), /* win9x */
|
|
"Expected count to be %d, it was %d\n", sourcelen, count);
|
|
|
|
strcpy(dest, desttest);
|
|
count = pStr_GetPtrA(source, dest, 0);
|
|
ok (count == sourcelen ||
|
|
broken(count == 0), /* win9x */
|
|
"Expected count to be %d, it was %d\n", sourcelen, count);
|
|
ok (!lstrcmpA(dest, desttest) ||
|
|
broken(!lstrcmpA(dest, "")), /* Win7 */
|
|
"Expected destination to not have changed\n");
|
|
|
|
count = pStr_GetPtrA(source, NULL, destsize);
|
|
ok (count == sourcelen ||
|
|
broken(count == sourcelen - 1), /* win9x */
|
|
"Expected count to be %d, it was %d\n", sourcelen, count);
|
|
|
|
count = pStr_GetPtrA(source, dest, destsize);
|
|
ok (count == sourcelen ||
|
|
broken(count == sourcelen - 1), /* win9x */
|
|
"Expected count to be %d, it was %d\n", sourcelen, count);
|
|
ok (!lstrcmpA(source, dest), "Expected source and destination to be the same\n");
|
|
|
|
strcpy(dest, desttest);
|
|
count = pStr_GetPtrA(NULL, dest, destsize);
|
|
ok (count == 0, "Expected count to be 0, it was %d\n", count);
|
|
ok (dest[0] == '\0', "Expected destination to be cut-off and 0 terminated\n");
|
|
|
|
destsize = 15;
|
|
count = pStr_GetPtrA(source, dest, destsize);
|
|
ok (count == 15 ||
|
|
broken(count == 14), /* win9x */
|
|
"Expected count to be 15, it was %d\n", count);
|
|
ok (!memcmp(source, dest, 14), "Expected first part of source and destination to be the same\n");
|
|
ok (dest[14] == '\0', "Expected destination to be cut-off and 0 terminated\n");
|
|
}
|
|
}
|
|
|
|
static void test_Alloc(void)
|
|
{
|
|
PCHAR p;
|
|
BOOL res;
|
|
DWORD size, min;
|
|
|
|
/* allocate size 0 */
|
|
p = pAlloc(0);
|
|
ok(p != NULL, "Expected non-NULL ptr\n");
|
|
|
|
/* get the minimum size */
|
|
min = pGetSize(p);
|
|
|
|
/* free the block */
|
|
res = pFree(p);
|
|
ok(res == TRUE, "Expected TRUE, got %d\n", res);
|
|
|
|
/* allocate size 1 */
|
|
p = pAlloc(1);
|
|
ok(p != NULL, "Expected non-NULL ptr\n");
|
|
|
|
/* get the allocated size */
|
|
size = pGetSize(p);
|
|
ok(size == 1 ||
|
|
broken(size == min), /* win9x */
|
|
"Expected 1, got %d\n", size);
|
|
|
|
/* reallocate the block */
|
|
p = pReAlloc(p, 2);
|
|
ok(p != NULL, "Expected non-NULL ptr\n");
|
|
|
|
/* get the new size */
|
|
size = pGetSize(p);
|
|
ok(size == 2 ||
|
|
broken(size == min), /* win9x */
|
|
"Expected 2, got %d\n", size);
|
|
|
|
/* free the block */
|
|
res = pFree(p);
|
|
ok(res == TRUE, "Expected TRUE, got %d\n", res);
|
|
|
|
/* free a NULL ptr */
|
|
res = pFree(NULL);
|
|
ok(res == TRUE ||
|
|
broken(res == FALSE), /* win9x */
|
|
"Expected TRUE, got %d\n", res);
|
|
|
|
/* reallocate a NULL ptr */
|
|
p = pReAlloc(NULL, 2);
|
|
ok(p != NULL, "Expectd non-NULL ptr\n");
|
|
|
|
res = pFree(p);
|
|
ok(res == TRUE, "Expected TRUE, got %d\n", res);
|
|
}
|
|
|
|
static void test_TaskDialogIndirect(void)
|
|
{
|
|
HINSTANCE hinst;
|
|
void *ptr, *ptr2;
|
|
|
|
hinst = LoadLibraryA("comctl32.dll");
|
|
|
|
ptr = GetProcAddress(hinst, "TaskDialogIndirect");
|
|
if (!ptr)
|
|
{
|
|
#ifdef __REACTOS__
|
|
/* Skipped on 2k3 */
|
|
skip("TaskDialogIndirect not exported by name\n");
|
|
#else
|
|
win_skip("TaskDialogIndirect not exported by name\n");
|
|
#endif
|
|
return;
|
|
}
|
|
|
|
ptr2 = GetProcAddress(hinst, (const CHAR*)345);
|
|
ok(ptr == ptr2, "got wrong pointer for ordinal 345, %p expected %p\n", ptr2, ptr);
|
|
}
|
|
|
|
static void test_LoadIconMetric(void)
|
|
{
|
|
static const WCHAR nonExistingFile[] = {'d','o','e','s','n','o','t','e','x','i','s','t','.','i','c','o','\0'};
|
|
HINSTANCE hinst;
|
|
void *ptr;
|
|
HICON icon;
|
|
HRESULT result;
|
|
ICONINFO info;
|
|
BOOL res;
|
|
INT bytes;
|
|
BITMAP bmp;
|
|
|
|
hinst = LoadLibraryA("comctl32.dll");
|
|
|
|
LoadIconMetric = (void *)GetProcAddress(hinst, "LoadIconMetric");
|
|
if (!LoadIconMetric)
|
|
{
|
|
#ifdef __REACTOS__
|
|
/* Skipped on 2k3 */
|
|
skip("TaskDialogIndirect not exported by name\n");
|
|
#else
|
|
win_skip("LoadIconMetric not exported by name\n");
|
|
#endif
|
|
return;
|
|
}
|
|
|
|
ptr = GetProcAddress(hinst, (const CHAR*)380);
|
|
ok(ptr == LoadIconMetric, "got wrong pointer for ordinal 380, %p expected %p\n",
|
|
ptr, LoadIconMetric);
|
|
|
|
result = LoadIconMetric(NULL, (PCWSTR)IDI_APPLICATION, LIM_SMALL, &icon);
|
|
ok(result == S_OK, "Expected S_OK, got %x\n", result);
|
|
if (result == S_OK)
|
|
{
|
|
res = GetIconInfo(icon, &info);
|
|
ok(res, "Failed to get icon info\n");
|
|
if (res && info.hbmColor)
|
|
{
|
|
bytes = GetObjectA(info.hbmColor, sizeof(bmp), &bmp);
|
|
ok(bytes > 0, "Failed to get bitmap info for icon\n");
|
|
if (bytes > 0)
|
|
{
|
|
ok(bmp.bmWidth == GetSystemMetrics( SM_CXSMICON ), "Wrong icon width\n");
|
|
ok(bmp.bmHeight == GetSystemMetrics( SM_CYSMICON ), "Wrong icon height\n");
|
|
}
|
|
}
|
|
DestroyIcon(icon);
|
|
}
|
|
|
|
result = LoadIconMetric(NULL, (PCWSTR)IDI_APPLICATION, LIM_LARGE, &icon);
|
|
ok(result == S_OK, "Expected S_OK, got %x\n", result);
|
|
if (result == S_OK)
|
|
{
|
|
res = GetIconInfo(icon, &info);
|
|
ok(res, "Failed to get icon info\n");
|
|
if (res && info.hbmColor)
|
|
{
|
|
bytes = GetObjectA(info.hbmColor, sizeof(bmp), &bmp);
|
|
ok(bytes > 0, "Failed to get bitmap info for icon\n");
|
|
if (bytes > 0)
|
|
{
|
|
ok(bmp.bmWidth == GetSystemMetrics( SM_CXICON ), "Wrong icon width\n");
|
|
ok(bmp.bmHeight == GetSystemMetrics( SM_CYICON ), "Wrong icon height\n");
|
|
}
|
|
}
|
|
DestroyIcon(icon);
|
|
}
|
|
|
|
result = LoadIconMetric(NULL, (PCWSTR)IDI_APPLICATION, 0x100, &icon);
|
|
ok(result == E_INVALIDARG, "Expected E_INVALIDARG, got %x\n", result);
|
|
if (result == S_OK) DestroyIcon(icon);
|
|
|
|
icon = (HICON)0x1234;
|
|
result = LoadIconMetric(NULL, NULL, LIM_LARGE, &icon);
|
|
ok(result == E_INVALIDARG, "Expected E_INVALIDARG, got %x\n", result);
|
|
ok(icon == (HICON)0, "Expected 0x0, got %p\n", icon);
|
|
if (result == S_OK) DestroyIcon(icon);
|
|
|
|
result = LoadIconMetric(NULL, nonExistingFile, LIM_LARGE, &icon);
|
|
ok(result == HRESULT_FROM_WIN32(ERROR_RESOURCE_TYPE_NOT_FOUND),
|
|
"Expected 80070715, got %x\n", result);
|
|
if (result == S_OK) DestroyIcon(icon);
|
|
}
|
|
|
|
|
|
START_TEST(misc)
|
|
{
|
|
ULONG_PTR ctx_cookie;
|
|
HANDLE hCtx;
|
|
|
|
if(!InitFunctionPtrs())
|
|
return;
|
|
|
|
test_GetPtrAW();
|
|
test_Alloc();
|
|
|
|
if (!load_v6_module(&ctx_cookie, &hCtx))
|
|
return;
|
|
|
|
test_TaskDialogIndirect();
|
|
test_LoadIconMetric();
|
|
|
|
unload_v6_module(ctx_cookie, hCtx);
|
|
}
|