Author: gadamopoulos Date: Thu Oct 6 12:46:21 2011 New Revision: 54022
URL: http://svn.reactos.org/svn/reactos?rev=54022&view=rev Log: [user32_apitest] - Add some more tests for SetWindowPos with or without SWP_NOOWNERZORDER. This clears the misunderstanding on changing owner window z-order once and for all
Modified: trunk/rostests/apitests/user32/DeferWindowPos.c
Modified: trunk/rostests/apitests/user32/DeferWindowPos.c URL: http://svn.reactos.org/svn/reactos/trunk/rostests/apitests/user32/DeferWindo... ============================================================================== --- trunk/rostests/apitests/user32/DeferWindowPos.c [iso-8859-1] (original) +++ trunk/rostests/apitests/user32/DeferWindowPos.c [iso-8859-1] Thu Oct 6 12:46:21 2011 @@ -11,13 +11,15 @@ #include "helper.h" #include <undocuser.h>
-HWND hWnd1, hWnd2; +HWND hWnd1, hWnd2, hWnd3, hWnd4;
/* FIXME: test for HWND_TOP, etc...*/ static int get_iwnd(HWND hWnd) { if(hWnd == hWnd1) return 1; else if(hWnd == hWnd2) return 2; + else if(hWnd == hWnd3) return 3; + else if(hWnd == hWnd4) return 4; else return 0; }
@@ -62,16 +64,57 @@ } }
+/* unfortunately sometimes MSCTF windows get between the expected chain of windows + so just checking the next window does not work*/ +static BOOL IsNext(HWND hWnd1, HWND hWnd2) +{ + HWND hWndNext; + + hWndNext=hWnd1; + while((hWndNext = GetWindow(hWndNext,GW_HWNDNEXT))) + { + if(hWndNext == hWnd2) + { + return TRUE; + } + } + return FALSE; +} + +#define EXPECT_NEXT(hWnd1, hWnd2) \ + ok(IsNext(hWnd1, hWnd2), \ + "After hwnd%d, expected hwnd%d not hwnd%d\n", \ + get_iwnd(hWnd1), get_iwnd(hWnd2),get_iwnd(GetWindow(hWnd1,GW_HWNDNEXT)) ) + +#define EXPECT_CHAIN(A,B,C,D) \ + EXPECT_NEXT(hWnd##A, hWnd##B); \ + EXPECT_NEXT(hWnd##B, hWnd##C); \ + EXPECT_NEXT(hWnd##C, hWnd##D); + #define ok_windowpos(hwnd, x, y, w, h, wnd) do { RECT rt; GetWindowRect(hwnd, &rt); \ ok(rt.left == (x) && rt.top == (y) && rt.right == (x)+(w) && rt.bottom == (y)+(h), \ "Unexpected %s position: (%ld, %ld) - (%ld, %ld)\n", wnd, rt.left, rt.top, rt.right, rt.bottom); } while (0)
#define ok_lasterr(err, s) ok(GetLastError() == (err), "%s error = %lu\n", s, GetLastError())
+static void set_default_pos() +{ + SetWindowPos(hWnd1, 0, 10,20,200,210, SWP_NOOWNERZORDER|SWP_SHOWWINDOW|SWP_NOACTIVATE); + SetWindowPos(hWnd2, 0, 30,40,220,230, SWP_NOOWNERZORDER|SWP_SHOWWINDOW|SWP_NOACTIVATE); + SetWindowPos(hWnd3, 0, 20,350,300,300, SWP_NOOWNERZORDER|SWP_SHOWWINDOW|SWP_NOACTIVATE); + SetWindowPos(hWnd4, 0, 250,250,200,200, SWP_NOOWNERZORDER|SWP_SHOWWINDOW|SWP_NOACTIVATE); + SetActiveWindow(hWnd4); + FlushMessages(); + empty_message_cache(); +} + static void Test_DWP_Error(HWND hWnd, HWND hWnd2) { HDWP hDwp; BOOL ret; + + ok_windowpos(hWnd1, 10, 20, 200, 210, "Window 1"); + ok_windowpos(hWnd2, 30, 40, 220, 230, "Window 2");
/* close invalid handles */ SetLastError(DNS_ERROR_RCODE_NXRRSET); @@ -209,29 +252,29 @@ }
MSG_ENTRY move1_chain[]={ - {1,WM_WINDOWPOSCHANGING, SENT, 0, SWP_NOACTIVATE}, + {1,WM_WINDOWPOSCHANGING, SENT, 0, SWP_NOACTIVATE|SWP_NOOWNERZORDER}, {1,WM_GETMINMAXINFO}, - {1,WM_WINDOWPOSCHANGED, SENT, 0, SWP_NOSIZE | SWP_NOACTIVATE | SWP_NOCLIENTSIZE}, + {1,WM_WINDOWPOSCHANGED, SENT, 0, SWP_NOSIZE | SWP_NOACTIVATE|SWP_NOOWNERZORDER | SWP_NOCLIENTSIZE}, {1,WM_MOVE}, {0,0}};
MSG_ENTRY resize1_chain[]={ - {1,WM_WINDOWPOSCHANGING, SENT, 0, SWP_NOACTIVATE}, + {1,WM_WINDOWPOSCHANGING, SENT, 0, SWP_NOACTIVATE|SWP_NOOWNERZORDER}, {1,WM_GETMINMAXINFO}, {1,WM_NCCALCSIZE}, - {1,WM_WINDOWPOSCHANGED, SENT, 0, SWP_NOMOVE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOCLIENTMOVE}, + {1,WM_WINDOWPOSCHANGED, SENT, 0, SWP_NOMOVE | SWP_NOZORDER | SWP_NOACTIVATE|SWP_NOOWNERZORDER | SWP_NOCLIENTMOVE}, {1,WM_SIZE}, {1,WM_NCCALCSIZE}, {0,0}};
MSG_ENTRY move1_2_chain[]={ - {1,WM_WINDOWPOSCHANGING, SENT, 0, SWP_NOACTIVATE}, + {1,WM_WINDOWPOSCHANGING, SENT, 0, SWP_NOACTIVATE|SWP_NOOWNERZORDER}, {1,WM_GETMINMAXINFO}, - {2,WM_WINDOWPOSCHANGING, SENT, 0, SWP_NOACTIVATE}, + {2,WM_WINDOWPOSCHANGING, SENT, 0, SWP_NOACTIVATE|SWP_NOOWNERZORDER}, {2,WM_GETMINMAXINFO}, - {1,WM_WINDOWPOSCHANGED, SENT, 0, SWP_NOSIZE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOCLIENTSIZE}, + {1,WM_WINDOWPOSCHANGED, SENT, 0, SWP_NOSIZE | SWP_NOZORDER | SWP_NOACTIVATE|SWP_NOOWNERZORDER | SWP_NOCLIENTSIZE}, {1,WM_MOVE}, - {2,WM_WINDOWPOSCHANGED, SENT, 0, SWP_NOSIZE | SWP_NOACTIVATE | SWP_NOCLIENTSIZE}, + {2,WM_WINDOWPOSCHANGED, SENT, 0, SWP_NOSIZE | SWP_NOACTIVATE|SWP_NOOWNERZORDER | SWP_NOCLIENTSIZE}, {2,WM_MOVE}, {0,0}};
@@ -239,13 +282,18 @@ { HDWP hdwp; BOOL ret; + + SetWindowPos(hWnd1, 0, 10,20,100,100,0); + SetWindowPos(hWnd2, 0, 10,20,100,100,0); + FlushMessages(); + empty_message_cache();
/* move hWnd1 */ hdwp = BeginDeferWindowPos(1); ok(hdwp != NULL, "BeginDeferWindowPos failed\n"); FlushMessages(); COMPARE_CACHE(empty_chain); - hdwp = DeferWindowPos(hdwp, hWnd1, HWND_TOP, 20, 30, 100, 100, SWP_NOACTIVATE); + hdwp = DeferWindowPos(hdwp, hWnd1, HWND_TOP, 20, 30, 100, 100, SWP_NOACTIVATE|SWP_NOOWNERZORDER); ok(hdwp != NULL, "DeferWindowPos failed\n"); FlushMessages(); COMPARE_CACHE(empty_chain); @@ -259,7 +307,7 @@ ok(hdwp != NULL, "BeginDeferWindowPos failed\n"); FlushMessages(); COMPARE_CACHE(empty_chain); - hdwp = DeferWindowPos(hdwp, hWnd1, HWND_TOP, 20, 30, 110, 110, SWP_NOACTIVATE); + hdwp = DeferWindowPos(hdwp, hWnd1, HWND_TOP, 20, 30, 110, 110, SWP_NOACTIVATE|SWP_NOOWNERZORDER); ok(hdwp != NULL, "DeferWindowPos failed\n"); FlushMessages(); COMPARE_CACHE(empty_chain); @@ -274,11 +322,11 @@ ok(hdwp != NULL, "BeginDeferWindowPos failed\n"); FlushMessages(); COMPARE_CACHE(empty_chain); - hdwp = DeferWindowPos(hdwp, hWnd1, HWND_TOP, 30, 40, 110, 110, SWP_NOACTIVATE); + hdwp = DeferWindowPos(hdwp, hWnd1, HWND_TOP, 30, 40, 110, 110, SWP_NOACTIVATE|SWP_NOOWNERZORDER); ok(hdwp != NULL, "DeferWindowPos failed\n"); FlushMessages(); COMPARE_CACHE(empty_chain); - hdwp = DeferWindowPos(hdwp, hWnd2, HWND_TOP, 30, 40, 100, 100, SWP_NOACTIVATE); + hdwp = DeferWindowPos(hdwp, hWnd2, HWND_TOP, 30, 40, 100, 100, SWP_NOACTIVATE|SWP_NOOWNERZORDER); ok(hdwp != NULL, "DeferWindowPos failed\n"); FlushMessages(); COMPARE_CACHE(empty_chain); @@ -286,6 +334,136 @@ ok(ret != 0, "EndDeferWindowPos failed\n"); FlushMessages(); COMPARE_CACHE(move1_2_chain); +} + +#define OwnerZOrderAParams SWP_NOMOVE|SWP_NOACTIVATE|SWP_NOSIZE + +MSG_ENTRY OwnerZOrder1A_chain[]={ + {4,WM_WINDOWPOSCHANGING, SENT,0, OwnerZOrderAParams}, + {3,WM_WINDOWPOSCHANGING, SENT,4, OwnerZOrderAParams}, + {1,WM_WINDOWPOSCHANGING, SENT,3, OwnerZOrderAParams}, + {0,0}}; + +MSG_ENTRY OwnerZOrder2A_chain[]={ + {2,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderAParams}, + {2,WM_WINDOWPOSCHANGED , SENT, 0, OwnerZOrderAParams | SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {0,0}}; + +MSG_ENTRY OwnerZOrder3A_chain[]={ + {3,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderAParams}, + {4,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderAParams}, + {1,WM_WINDOWPOSCHANGING, SENT, 4, OwnerZOrderAParams}, + {3,WM_WINDOWPOSCHANGED, SENT, 0, OwnerZOrderAParams |SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {4,WM_WINDOWPOSCHANGED, SENT, 0, OwnerZOrderAParams |SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {1,WM_WINDOWPOSCHANGED, SENT, 4, OwnerZOrderAParams |SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {0,0}}; + +MSG_ENTRY OwnerZOrder4A_chain[]={ + {3,WM_WINDOWPOSCHANGING, SENT, 0 ,OwnerZOrderAParams}, + {4,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderAParams} , + {1,WM_WINDOWPOSCHANGING, SENT, 4, OwnerZOrderAParams}, + {0,0}}; + +MSG_ENTRY OwnerZOrder5A_chain[]={ + {4,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderAParams}, + {3,WM_WINDOWPOSCHANGING, SENT, 4, OwnerZOrderAParams}, + {1,WM_WINDOWPOSCHANGING, SENT, 3, OwnerZOrderAParams}, + {4,WM_WINDOWPOSCHANGED, SENT, 0, OwnerZOrderAParams|SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {0,0}}; + +#define OwnerZOrderBParams SWP_NOMOVE|SWP_NOACTIVATE|SWP_NOSIZE|SWP_NOOWNERZORDER + +MSG_ENTRY OwnerZOrder1B_chain[]={ + {1,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderBParams}, + {1,WM_WINDOWPOSCHANGED, SENT, 0, OwnerZOrderBParams | SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {0,0}}; + +MSG_ENTRY OwnerZOrder2B_chain[]={ + {2,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderBParams}, + {2,WM_WINDOWPOSCHANGED, SENT, 0, OwnerZOrderBParams | SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {0,0}}; + +MSG_ENTRY OwnerZOrder3B_chain[]={ + {3,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderBParams}, + {3,WM_WINDOWPOSCHANGED, SENT, 0, OwnerZOrderBParams | SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {0,0}}; + +MSG_ENTRY OwnerZOrder4B_chain[]={ + {1,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderBParams}, + {1,WM_WINDOWPOSCHANGED, SENT, 0, OwnerZOrderBParams | SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {0,0}}; + +MSG_ENTRY OwnerZOrder5B_chain[]={ + {4,WM_WINDOWPOSCHANGING, SENT, 0, OwnerZOrderBParams}, + {4,WM_WINDOWPOSCHANGED, SENT, 0, OwnerZOrderBParams | SWP_NOCLIENTMOVE|SWP_NOCLIENTSIZE}, + {0,0}}; + +static void Test_DWP_OwnerZOrder() +{ + EXPECT_CHAIN(4,3,1,2); + + /* test how SetWindowPos can change the z order of owner windows */ + /* note that SWP_NOACTIVATE must be used because otherwise + SetWindowPos will call SetWindowPos again with different parameters */ + SetWindowPos(hWnd1, 0, 0,0,0,0, OwnerZOrderAParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder1A_chain); + EXPECT_CHAIN(4,3,1,2); + + SetWindowPos(hWnd2, 0, 0,0,0,0, OwnerZOrderAParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder2A_chain); + EXPECT_CHAIN(2,4,3,1); + + SetWindowPos(hWnd3, 0, 0,0,0,0, OwnerZOrderAParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder3A_chain); + EXPECT_CHAIN(3,4,1,2); + + SetWindowPos(hWnd1, 0, 0,0,0,0, OwnerZOrderAParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder4A_chain); + EXPECT_CHAIN(3,4,1,2); + + SetWindowPos(hWnd4, 0, 0,0,0,0, OwnerZOrderAParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder5A_chain); + EXPECT_CHAIN(4,3,1,2); + + /* now do the same thing one more time with SWP_NOOWNERZORDER */ + /* SWP_NOACTIVATE is needed because without it SetActiveWindow + will be calledit and it will call SetWindowPos again + WITHOUT SWP_NOOWNERZORDER. that means that + in order for SWP_NOOWNERZORDER to have effect we have to use + SWP_NOACTIVATE as well */ + set_default_pos(); + EXPECT_CHAIN(4,3,2,1); + + SetWindowPos(hWnd1, 0, 0,0,0,0, OwnerZOrderBParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder1B_chain); + EXPECT_CHAIN(1,4,3,2); + + SetWindowPos(hWnd2, 0, 0,0,0,0, OwnerZOrderBParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder2B_chain); + EXPECT_CHAIN(2,1,4,3); + + SetWindowPos(hWnd3, 0, 0,0,0,0, OwnerZOrderBParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder3B_chain); + EXPECT_CHAIN(3,2,1,4); + + SetWindowPos(hWnd1, 0, 0,0,0,0, OwnerZOrderBParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder4B_chain); + EXPECT_CHAIN(1,3,2,4); + + SetWindowPos(hWnd4, 0, 0,0,0,0, OwnerZOrderBParams); + FlushMessages(); + COMPARE_CACHE(OwnerZOrder5B_chain); + EXPECT_CHAIN(4,1,3,2); + }
START_TEST(DeferWindowPos) @@ -295,24 +473,27 @@ 200, 210, NULL, NULL, 0, NULL); hWnd2 = CreateWindowExW(0, L"ownertest", L"def", 0, 30, 40, 220, 230, NULL, NULL, 0, NULL); + hWnd3 = CreateWindowW(L"ownertest", L"ownertest", WS_OVERLAPPEDWINDOW, + 20, 350, 300, 300, hWnd1, NULL, 0, NULL); + hWnd4 = CreateWindowW(L"ownertest", L"ownertest", WS_OVERLAPPEDWINDOW, + 250, 250, 200, 200, hWnd1, NULL, 0, NULL); + ok(hWnd1 != NULL, "CreateWindow failed\n"); ok(hWnd2 != NULL, "CreateWindow failed\n"); - ShowWindow(hWnd1, SW_SHOW); - ShowWindow(hWnd2, SW_SHOW); - ok_windowpos(hWnd1, 10, 20, 200, 210, "Window 1"); - ok_windowpos(hWnd2, 30, 40, 220, 230, "Window 2"); - FlushMessages(); - empty_message_cache(); - + ok(hWnd3 != NULL, "CreateWindow failed\n"); + ok(hWnd4 != NULL, "CreateWindow failed\n"); + + set_default_pos(); Test_DWP_Error(hWnd1, hWnd2);
- SetWindowPos(hWnd1, 0, 10,20,100,100,0); - SetWindowPos(hWnd2, 0, 10,20,100,100,0); - FlushMessages(); - empty_message_cache(); - + set_default_pos(); Test_DWP_SimpleMsg(hWnd1, hWnd2);
+ set_default_pos(); + Test_DWP_OwnerZOrder(); + + DestroyWindow(hWnd4); + DestroyWindow(hWnd3); DestroyWindow(hWnd2); DestroyWindow(hWnd1); }