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);
 }