mirror of
https://github.com/reactos/reactos.git
synced 2025-08-07 05:52:57 +00:00
[USER32_APTEST][USER32] CopyImage improve regression test and function. (#7524)
CORE-19806 and CORE-17902.
* Follow-up of PR #6886 and commit d3ec7cd
to remove hack.
This commit is contained in:
parent
1ea3af8959
commit
1c55924045
2 changed files with 93 additions and 6 deletions
|
@ -3,6 +3,7 @@
|
|||
* LICENSE: LGPL-2.1+ (https://spdx.org/licenses/LGPL-2.1+)
|
||||
* PURPOSE: Test for SetFocus/GetFocus/GetGUIThreadInfo
|
||||
* COPYRIGHT: Copyright 2024 Katayama Hirofumi MZ <katayama.hirofumi.mz@gmail.com>
|
||||
* Copyright 2024 Doug Lyons <douglyons@douglyons.com>
|
||||
*/
|
||||
|
||||
#include "precomp.h"
|
||||
|
@ -76,9 +77,61 @@ Test_CopyImage_Flags(UINT uType)
|
|||
DeleteObject(hImage);
|
||||
}
|
||||
|
||||
static VOID
|
||||
Test_CopyImage_hImage_NULL(void)
|
||||
{
|
||||
HANDLE hImg;
|
||||
DWORD LastError;
|
||||
|
||||
/* Test NULL HANDLE return and GetLastError return. */
|
||||
SetLastError(0xdeadbeef);
|
||||
hImg = CopyImage(NULL, IMAGE_ICON, 16, 16, LR_COPYFROMRESOURCE);
|
||||
LastError = GetLastError();
|
||||
ok(LastError == ERROR_INVALID_CURSOR_HANDLE, "Wrong error 0x%08lx returned\n", LastError);
|
||||
ok(!hImg, "Image returned should have been NULL, hImg was %p\n", hImg);
|
||||
|
||||
SetLastError(0xdeadbeef);
|
||||
hImg = CopyImage(NULL, IMAGE_BITMAP, 16, 16, LR_COPYFROMRESOURCE);
|
||||
LastError = GetLastError();
|
||||
ok(LastError == ERROR_INVALID_HANDLE, "Wrong error 0x%08lx returned\n", LastError);
|
||||
ok(!hImg, "Image returned should have been NULL, hImg was %p\n", hImg);
|
||||
|
||||
|
||||
SetLastError(0xdeadbeef);
|
||||
hImg = CopyImage(NULL, IMAGE_CURSOR, 16, 16, LR_COPYFROMRESOURCE);
|
||||
LastError = GetLastError();
|
||||
ok(LastError == ERROR_INVALID_CURSOR_HANDLE, "Wrong error 0x%08lx returned\n", LastError);
|
||||
ok(!hImg, "Image returned should have been NULL, hImg was %p\n", hImg);
|
||||
|
||||
/* Test bad Flags for Invalid Parameter return */
|
||||
SetLastError(0xdeadbeef);
|
||||
/* 0x80000000 is an invalid flag value */
|
||||
hImg = CopyImage(NULL, IMAGE_BITMAP, 16, 16, 0x80000000);
|
||||
LastError = GetLastError();
|
||||
ok(LastError == ERROR_INVALID_PARAMETER, "Wrong error 0x%08lx returned\n", LastError);
|
||||
ok(!hImg, "Image returned should have been NULL, hImg was %p\n", hImg);
|
||||
|
||||
/* Test bad Type (5) GetLastError return value. Not Icon, Cursor, or Bitmap. */
|
||||
SetLastError(0xdeadbeef);
|
||||
hImg = CopyImage(NULL, 5, 16, 16, LR_COPYFROMRESOURCE);
|
||||
LastError = GetLastError();
|
||||
ok(LastError == ERROR_INVALID_PARAMETER, "Wrong error 0x%08lx returned\n", LastError);
|
||||
ok(!hImg, "Image returned should have been NULL, hImg was %p\n", hImg);
|
||||
|
||||
/* Test bad type (5) GetLastError return value with good HANDLE */
|
||||
hImg = CreateTestImage(IMAGE_ICON);
|
||||
SetLastError(0xdeadbeef);
|
||||
hImg = CopyImage(hImg, 5, 16, 16, LR_COPYFROMRESOURCE);
|
||||
LastError = GetLastError();
|
||||
ok(LastError == ERROR_INVALID_PARAMETER, "Wrong error 0x%08lx returned\n", LastError);
|
||||
ok(!hImg, "Image returned should have been NULL, hImg was %p\n", hImg);
|
||||
DeleteObject(hImg);
|
||||
}
|
||||
|
||||
START_TEST(CopyImage)
|
||||
{
|
||||
Test_CopyImage_Flags(IMAGE_BITMAP);
|
||||
Test_CopyImage_Flags(IMAGE_CURSOR);
|
||||
Test_CopyImage_Flags(IMAGE_ICON);
|
||||
Test_CopyImage_hImage_NULL();
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue