https://git.reactos.org/?p=reactos.git;a=commitdiff;h=1ad9a1deabfdd592c4eed…
commit 1ad9a1deabfdd592c4eeda8059c5839dee646ffa
Author: Katayama Hirofumi MZ <katayama.hirofumi.mz(a)gmail.com>
AuthorDate: Sun Jan 27 17:17:09 2019 +0900
Commit: GitHub <noreply(a)github.com>
CommitDate: Sun Jan 27 17:17:09 2019 +0900
[WIN32KNT_APITEST] NtGdiSetBitmapBits: Add tests for max buffer size 2 (#1312)
Improve NtGdiSetBitmapBits testcase again and again. CORE-15657
---
.../apitests/win32nt/ntgdi/NtGdiSetBitmapBits.c | 38 ++++++++++++++++++++++
1 file changed, 38 insertions(+)
diff --git a/modules/rostests/apitests/win32nt/ntgdi/NtGdiSetBitmapBits.c
b/modules/rostests/apitests/win32nt/ntgdi/NtGdiSetBitmapBits.c
index 4544c8de33..fa668acf04 100644
--- a/modules/rostests/apitests/win32nt/ntgdi/NtGdiSetBitmapBits.c
+++ b/modules/rostests/apitests/win32nt/ntgdi/NtGdiSetBitmapBits.c
@@ -94,6 +94,20 @@ START_TEST(NtGdiSetBitmapBits)
ok_long(NtGdiSetBitmapBits(hBitmap, 565, Bits), 0);
ok_long(GetLastError(), 0xDEADFACE);
+ {
+ BYTE dummy[256] = { 1 };
+
+ SetLastError(0xDEADFACE);
+ ok_long(NtGdiSetBitmapBits(hBitmap, 564, Bits), 0xC);
+ ok_long(GetLastError(), 0xDEADFACE);
+
+ SetLastError(0xDEADFACE);
+ ok_long(NtGdiSetBitmapBits(hBitmap, 565, Bits), 0);
+ ok_long(GetLastError(), 0xDEADFACE);
+
+ ok_int(dummy[0], 1);
+ }
+
SetLastError(0xDEADFACE);
ok_long(NtGdiSetBitmapBits(hBitmap, 0x7FFF, Bits), 0);
ok_long(GetLastError(), 0xDEADFACE);
@@ -206,6 +220,14 @@ START_TEST(NtGdiSetBitmapBits)
ok_int(Bits[3], 0x33);
ok_int(Bits[4], 0x55);
+ SetLastError(0xDEADFACE);
+ ok_long(NtGdiSetBitmapBits(hBitmap, 564, Bits), 0x20);
+ ok_long(GetLastError(), 0xDEADFACE);
+
+ SetLastError(0xDEADFACE);
+ ok_long(NtGdiSetBitmapBits(hBitmap, 565, Bits), 0);
+ ok_long(GetLastError(), 0xDEADFACE);
+
DeleteObject(hBitmap);
/* ------------------------- */
@@ -304,6 +326,14 @@ START_TEST(NtGdiSetBitmapBits)
ok_int(Bits[3], 0x33);
ok_int(Bits[4], 0x55);
+ SetLastError(0xDEADFACE);
+ ok_long(NtGdiSetBitmapBits(hBitmap, 564, Bits), 0x234);
+ ok_long(GetLastError(), 0xDEADFACE);
+
+ SetLastError(0xDEADFACE);
+ ok_long(NtGdiSetBitmapBits(hBitmap, 565, Bits), 0);
+ ok_long(GetLastError(), 0xDEADFACE);
+
DeleteObject(hBitmap);
DeleteDC(hDC);
@@ -403,6 +433,14 @@ START_TEST(NtGdiSetBitmapBits)
ok_int(Bits[3], 0x33);
ok_int(Bits[4], 0x55);
+ SetLastError(0xDEADFACE);
+ ok_long(NtGdiSetBitmapBits(hBitmap, 564, Bits), 0x234);
+ ok_long(GetLastError(), 0xDEADFACE);
+
+ SetLastError(0xDEADFACE);
+ ok_long(NtGdiSetBitmapBits(hBitmap, 565, Bits), 0);
+ ok_long(GetLastError(), 0xDEADFACE);
+
DeleteObject(hBitmap);
DeleteDC(hDC);
}