From 42ecb0ec15f28ee0a5acc24d60c3bdb5416d71d0 Mon Sep 17 00:00:00 2001 From: Damjan Jovanovic Date: Fri, 30 Apr 2021 07:39:13 +0200 Subject: [PATCH] shell32/tests: Test what Shell_MergeMenus() does with a negative adjustment. Signed-off-by: Damjan Jovanovic Signed-off-by: Alexandre Julliard --- dlls/shell32/tests/shlfileop.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/dlls/shell32/tests/shlfileop.c b/dlls/shell32/tests/shlfileop.c index dc3572abf3d..9eab928c12f 100644 --- a/dlls/shell32/tests/shlfileop.c +++ b/dlls/shell32/tests/shlfileop.c @@ -2673,6 +2673,7 @@ test_shlmenu(void) { src_menu = CreatePopupMenu (); ok (src_menu != NULL, "CreatePopupMenu() failed, error %d\n", GetLastError ()); + dst_menu = CreatePopupMenu (); ok (dst_menu != NULL, "CreatePopupMenu() failed, error %d\n", GetLastError ()); bres = InsertMenuA (src_menu, -1, MF_BYPOSITION | MF_STRING, 10, "item1"); @@ -2690,6 +2691,16 @@ test_shlmenu(void) { ok (bres, "GetMenuItemInfoA failed, error %d\n", GetLastError ()); ok (item_info.wID == 133, "got %d\n", item_info.wID); DestroyMenu (dst_menu); + + /* integer overflow: Shell_MergeMenus() return value is wrong, but items are still added */ + dst_menu = CreatePopupMenu (); + ok (dst_menu != NULL, "CreatePopupMenu() failed, error %d\n", GetLastError ()); + hres = Shell_MergeMenus (dst_menu, src_menu, 0, -1, 133, MM_SUBMENUSHAVEIDS); + ok (hres == -1, "got %d\n", hres); + count = GetMenuItemCount (dst_menu); + ok (count == 2, "got %d\n", count); + DestroyMenu (dst_menu); + DestroyMenu (src_menu); }