mirror of
https://github.com/reactos/reactos.git
synced 2025-01-01 03:54:02 +00:00
0707475f69
For SOME reason comctl32 has been synched manually multiple times to different versions and different pots This PR aims to fix that With the exception of button.c which all in all is a massive fork over wines code entirely. and datetime.c which is at wine 6.0 Comctl32 is now at wine-5.0
1011 lines
34 KiB
C
1011 lines
34 KiB
C
/* Unit tests for the up-down control
|
|
*
|
|
* Copyright 2005 C. Scott Ananian
|
|
* Copyright (C) 2007 James Hawkins
|
|
* Copyright (C) 2007 Leslie Choong
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|
*/
|
|
|
|
/* TO TEST:
|
|
* - send click messages to the up-down control, check the current position
|
|
* - up-down control automatically positions itself next to its buddy window
|
|
* - up-down control sets the caption of the buddy window
|
|
* - test CreateUpDownControl API
|
|
* - check UDS_AUTOBUDDY style, up-down control selects previous window in z-order
|
|
* - check UDM_SETBUDDY message
|
|
* - check UDM_GETBUDDY message
|
|
* - up-down control and buddy control must have the same parent
|
|
* - check UDS_ALIGN[LEFT,RIGHT]...check that width of buddy window is decreased
|
|
* - check that UDS_SETBUDDYINT sets the caption of the buddy window when it is changed
|
|
* - check that the thousands operator is set for large numbers
|
|
* - check that the thousands operator is not set with UDS_NOTHOUSANDS
|
|
* - check UDS_ARROWKEYS, control subclasses the buddy window so that it processes the keys when it has focus
|
|
* - check UDS_HORZ
|
|
* - check changing past min/max values
|
|
* - check UDS_WRAP wraps values past min/max, incrementing past upper value wraps position to lower value
|
|
* - can change control's position, min/max pos, radix
|
|
* - check UDM_GETPOS, for up-down control with a buddy window, position is the caption of the buddy window, so change the
|
|
* caption of the buddy window then call UDM_GETPOS
|
|
* - check UDM_SETRANGE, max can be less than min, so clicking the up arrow decreases the current position
|
|
* - more stuff to test
|
|
*/
|
|
|
|
#include <windows.h>
|
|
#include <commctrl.h>
|
|
#include <stdio.h>
|
|
|
|
#include "wine/test.h"
|
|
#include "msg.h"
|
|
|
|
#define expect(EXPECTED,GOT) ok((GOT)==(EXPECTED), "Expected %d, got %d\n", (EXPECTED), (GOT))
|
|
|
|
#define NUM_MSG_SEQUENCES 3
|
|
#define PARENT_SEQ_INDEX 0
|
|
#define EDIT_SEQ_INDEX 1
|
|
#define UPDOWN_SEQ_INDEX 2
|
|
|
|
#define UPDOWN_ID 0
|
|
#define BUDDY_ID 1
|
|
|
|
static HWND parent_wnd, g_edit;
|
|
|
|
static HWND (WINAPI *pCreateUpDownControl)(DWORD, INT, INT, INT, INT,
|
|
HWND, INT, HINSTANCE, HWND, INT, INT, INT);
|
|
static BOOL (WINAPI *pSetWindowSubclass)(HWND, SUBCLASSPROC, UINT_PTR, DWORD_PTR);
|
|
|
|
static struct msg_sequence *sequences[NUM_MSG_SEQUENCES];
|
|
|
|
static const struct message add_updown_with_edit_seq[] = {
|
|
{ WM_WINDOWPOSCHANGING, sent },
|
|
{ WM_NCCALCSIZE, sent|wparam, TRUE },
|
|
{ WM_WINDOWPOSCHANGED, sent },
|
|
{ WM_SIZE, sent|wparam|defwinproc, SIZE_RESTORED /*, MAKELONG(91, 75) exact size depends on font */ },
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message add_updown_to_parent_seq[] = {
|
|
{ WM_NOTIFYFORMAT, sent|lparam, 0, NF_QUERY },
|
|
{ WM_QUERYUISTATE, sent|optional },
|
|
{ WM_PARENTNOTIFY, sent|wparam, MAKELONG(WM_CREATE, WM_CREATE) },
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message get_edit_text_seq[] = {
|
|
{ WM_GETTEXT, sent },
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message test_updown_pos_seq[] = {
|
|
{ UDM_SETRANGE, sent|lparam, 0, MAKELONG(100,0) },
|
|
{ UDM_GETRANGE, sent},
|
|
{ UDM_SETPOS, sent|lparam, 0, 5},
|
|
{ UDM_GETPOS, sent},
|
|
{ UDM_SETPOS, sent|lparam, 0, 0},
|
|
{ UDM_GETPOS, sent},
|
|
{ UDM_SETPOS, sent|lparam, 0, MAKELONG(-1,0)},
|
|
{ UDM_GETPOS, sent},
|
|
{ UDM_SETPOS, sent|lparam, 0, 100},
|
|
{ UDM_GETPOS, sent},
|
|
{ UDM_SETPOS, sent|lparam, 0, 101},
|
|
{ UDM_GETPOS, sent},
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message test_updown_pos32_seq[] = {
|
|
{ UDM_SETRANGE32, sent|lparam, 0, 1000 },
|
|
{ UDM_GETRANGE32, sent}, /* Cannot check wparam and lparam as they are ptrs */
|
|
{ UDM_SETPOS32, sent|lparam, 0, 500 },
|
|
{ UDM_GETPOS32, sent},
|
|
{ UDM_SETPOS32, sent|lparam, 0, 0 },
|
|
{ UDM_GETPOS32, sent},
|
|
{ UDM_SETPOS32, sent|lparam, 0, -1 },
|
|
{ UDM_GETPOS32, sent},
|
|
{ UDM_SETPOS32, sent|lparam, 0, 1000 },
|
|
{ UDM_GETPOS32, sent},
|
|
{ UDM_SETPOS32, sent|lparam, 0, 1001 },
|
|
{ UDM_GETPOS32, sent},
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message test_updown_buddy_seq[] = {
|
|
{ UDM_GETBUDDY, sent },
|
|
{ UDM_SETBUDDY, sent },
|
|
{ WM_STYLECHANGING, sent|defwinproc },
|
|
{ WM_STYLECHANGED, sent|defwinproc },
|
|
{ WM_STYLECHANGING, sent|defwinproc },
|
|
{ WM_STYLECHANGED, sent|defwinproc },
|
|
{ WM_WINDOWPOSCHANGING, sent|defwinproc },
|
|
{ WM_NCCALCSIZE, sent|wparam|optional|defwinproc, 1 },
|
|
{ WM_WINDOWPOSCHANGED, sent|defwinproc },
|
|
{ WM_MOVE, sent|defwinproc },
|
|
{ UDM_GETBUDDY, sent },
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message test_updown_base_seq[] = {
|
|
{ UDM_SETBASE, sent|wparam, 10 },
|
|
{ UDM_GETBASE, sent },
|
|
{ UDM_SETBASE, sent|wparam, 80 },
|
|
{ UDM_GETBASE, sent },
|
|
{ UDM_SETBASE, sent|wparam, 16 },
|
|
{ UDM_GETBASE, sent },
|
|
{ UDM_SETBASE, sent|wparam, 80 },
|
|
{ UDM_GETBASE, sent },
|
|
{ UDM_SETBASE, sent|wparam, 10 },
|
|
{ UDM_GETBASE, sent },
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message test_updown_unicode_seq[] = {
|
|
{ UDM_SETUNICODEFORMAT, sent|wparam, 0 },
|
|
{ UDM_GETUNICODEFORMAT, sent },
|
|
{ UDM_SETUNICODEFORMAT, sent|wparam, 1 },
|
|
{ UDM_GETUNICODEFORMAT, sent },
|
|
{ UDM_SETUNICODEFORMAT, sent|wparam, 0 },
|
|
{ UDM_GETUNICODEFORMAT, sent },
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message test_updown_pos_nochange_seq[] = {
|
|
{ WM_GETTEXT, sent|id, 0, 0, BUDDY_ID },
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message test_updown_pos_notifications_seq[] = {
|
|
{ WM_CTLCOLOREDIT, sent|optional },
|
|
{ WM_COMMAND, sent|wparam, MAKELONG(0, EN_SETFOCUS) },
|
|
{ WM_NOTIFY, sent|id, 0, 0, UDN_DELTAPOS },
|
|
{ WM_COMMAND, sent|wparam, MAKELONG(0, EN_UPDATE) },
|
|
{ WM_COMMAND, sent|wparam, MAKELONG(0, EN_CHANGE) },
|
|
{ WM_VSCROLL, sent|wparam, MAKELONG(SB_THUMBPOSITION, 51) },
|
|
{ WM_CTLCOLOREDIT, sent|optional },
|
|
{ WM_VSCROLL, sent|wparam, MAKELONG(SB_ENDSCROLL, 51) },
|
|
/* no WM_NOTIFY(NM_RELEASEDCAPTURE) message */
|
|
{ 0 }
|
|
};
|
|
|
|
static const struct message test_updown_pos_notifications_horz_seq[] = {
|
|
{ WM_CTLCOLOREDIT, sent|optional },
|
|
{ WM_COMMAND, sent|wparam, MAKELONG(0, EN_SETFOCUS) },
|
|
{ WM_NOTIFY, sent|id, 0, 0, UDN_DELTAPOS },
|
|
{ WM_COMMAND, sent|wparam, MAKELONG(0, EN_UPDATE) },
|
|
{ WM_COMMAND, sent|wparam, MAKELONG(0, EN_CHANGE) },
|
|
{ WM_HSCROLL, sent|wparam, MAKELONG(SB_THUMBPOSITION, 51) },
|
|
{ WM_CTLCOLOREDIT, sent|optional },
|
|
{ WM_HSCROLL, sent|wparam, MAKELONG(SB_ENDSCROLL, 51) },
|
|
/* no WM_NOTIFY(NM_RELEASEDCAPTURE) message */
|
|
{ 0 }
|
|
};
|
|
|
|
static LRESULT WINAPI parent_wnd_proc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
static LONG defwndproc_counter = 0;
|
|
struct message msg = { 0 };
|
|
LRESULT ret;
|
|
|
|
/* log system messages, except for painting */
|
|
if (message < WM_USER &&
|
|
message != WM_PAINT &&
|
|
message != WM_ERASEBKGND &&
|
|
message != WM_NCPAINT &&
|
|
message != WM_NCHITTEST &&
|
|
message != WM_GETTEXT &&
|
|
message != WM_GETICON &&
|
|
message != WM_DEVICECHANGE)
|
|
{
|
|
msg.message = message;
|
|
msg.flags = sent|wparam|lparam;
|
|
if (defwndproc_counter) msg.flags |= defwinproc;
|
|
msg.wParam = wParam;
|
|
msg.lParam = lParam;
|
|
if (message == WM_NOTIFY && lParam)
|
|
msg.id = ((NMHDR*)lParam)->code;
|
|
add_message(sequences, PARENT_SEQ_INDEX, &msg);
|
|
}
|
|
|
|
defwndproc_counter++;
|
|
ret = DefWindowProcA(hwnd, message, wParam, lParam);
|
|
defwndproc_counter--;
|
|
|
|
return ret;
|
|
}
|
|
|
|
static BOOL register_parent_wnd_class(void)
|
|
{
|
|
WNDCLASSA cls;
|
|
|
|
cls.style = 0;
|
|
cls.lpfnWndProc = parent_wnd_proc;
|
|
cls.cbClsExtra = 0;
|
|
cls.cbWndExtra = 0;
|
|
cls.hInstance = GetModuleHandleA(NULL);
|
|
cls.hIcon = 0;
|
|
cls.hCursor = LoadCursorA(0, (LPCSTR)IDC_ARROW);
|
|
cls.hbrBackground = GetStockObject(WHITE_BRUSH);
|
|
cls.lpszMenuName = NULL;
|
|
cls.lpszClassName = "Up-Down test parent class";
|
|
return RegisterClassA(&cls);
|
|
}
|
|
|
|
static HWND create_parent_window(void)
|
|
{
|
|
if (!register_parent_wnd_class())
|
|
return NULL;
|
|
|
|
return CreateWindowExA(0, "Up-Down test parent class",
|
|
"Up-Down test parent window",
|
|
WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX |
|
|
WS_MAXIMIZEBOX | WS_VISIBLE,
|
|
0, 0, 100, 100,
|
|
GetDesktopWindow(), NULL, GetModuleHandleA(NULL), NULL);
|
|
}
|
|
|
|
static LRESULT WINAPI edit_subclass_proc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
WNDPROC oldproc = (WNDPROC)GetWindowLongPtrA(hwnd, GWLP_USERDATA);
|
|
static LONG defwndproc_counter = 0;
|
|
struct message msg = { 0 };
|
|
LRESULT ret;
|
|
|
|
msg.message = message;
|
|
msg.flags = sent|wparam|lparam;
|
|
if (defwndproc_counter) msg.flags |= defwinproc;
|
|
msg.wParam = wParam;
|
|
msg.lParam = lParam;
|
|
msg.id = BUDDY_ID;
|
|
add_message(sequences, EDIT_SEQ_INDEX, &msg);
|
|
|
|
defwndproc_counter++;
|
|
ret = CallWindowProcA(oldproc, hwnd, message, wParam, lParam);
|
|
defwndproc_counter--;
|
|
return ret;
|
|
}
|
|
|
|
static HWND create_edit_control(void)
|
|
{
|
|
WNDPROC oldproc;
|
|
HWND hwnd;
|
|
RECT rect;
|
|
|
|
GetClientRect(parent_wnd, &rect);
|
|
hwnd = CreateWindowExA(0, WC_EDITA, NULL, WS_CHILD | WS_BORDER | WS_VISIBLE,
|
|
0, 0, rect.right, rect.bottom,
|
|
parent_wnd, NULL, GetModuleHandleA(NULL), NULL);
|
|
if (!hwnd) return NULL;
|
|
|
|
oldproc = (WNDPROC)SetWindowLongPtrA(hwnd, GWLP_WNDPROC,
|
|
(LONG_PTR)edit_subclass_proc);
|
|
SetWindowLongPtrA(hwnd, GWLP_USERDATA, (LONG_PTR)oldproc);
|
|
|
|
return hwnd;
|
|
}
|
|
|
|
static LRESULT WINAPI updown_subclass_proc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
WNDPROC oldproc = (WNDPROC)GetWindowLongPtrA(hwnd, GWLP_USERDATA);
|
|
static LONG defwndproc_counter = 0;
|
|
struct message msg = { 0 };
|
|
LRESULT ret;
|
|
|
|
msg.message = message;
|
|
msg.flags = sent|wparam|lparam;
|
|
if (defwndproc_counter) msg.flags |= defwinproc;
|
|
msg.wParam = wParam;
|
|
msg.lParam = lParam;
|
|
msg.id = UPDOWN_ID;
|
|
add_message(sequences, UPDOWN_SEQ_INDEX, &msg);
|
|
|
|
defwndproc_counter++;
|
|
ret = CallWindowProcA(oldproc, hwnd, message, wParam, lParam);
|
|
defwndproc_counter--;
|
|
|
|
return ret;
|
|
}
|
|
|
|
static HWND create_updown_control(DWORD style, HWND buddy)
|
|
{
|
|
WNDPROC oldproc;
|
|
HWND updown;
|
|
RECT rect;
|
|
|
|
GetClientRect(parent_wnd, &rect);
|
|
updown = CreateWindowExA(0, UPDOWN_CLASSA, NULL, WS_CHILD | WS_BORDER | WS_VISIBLE | style,
|
|
0, 0, rect.right, rect.bottom,
|
|
parent_wnd, (HMENU)1, GetModuleHandleA(NULL), NULL);
|
|
ok(updown != NULL, "Failed to create UpDown control.\n");
|
|
if (!updown) return NULL;
|
|
|
|
SendMessageA(updown, UDM_SETBUDDY, (WPARAM)buddy, 0);
|
|
SendMessageA(updown, UDM_SETRANGE, 0, MAKELONG(100, 0));
|
|
SendMessageA(updown, UDM_SETPOS, 0, MAKELONG(50, 0));
|
|
|
|
oldproc = (WNDPROC)SetWindowLongPtrA(updown, GWLP_WNDPROC,
|
|
(LONG_PTR)updown_subclass_proc);
|
|
SetWindowLongPtrA(updown, GWLP_USERDATA, (LONG_PTR)oldproc);
|
|
|
|
return updown;
|
|
}
|
|
|
|
static void test_updown_pos(void)
|
|
{
|
|
HWND updown;
|
|
int r;
|
|
|
|
updown = create_updown_control(UDS_ALIGNRIGHT, g_edit);
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
/* Set Range from 0 to 100 */
|
|
SendMessageA(updown, UDM_SETRANGE, 0 , MAKELONG(100,0) );
|
|
r = SendMessageA(updown, UDM_GETRANGE, 0,0);
|
|
expect(100,LOWORD(r));
|
|
expect(0,HIWORD(r));
|
|
|
|
/* Set the position to 5, return is not checked as it was set before func call */
|
|
SendMessageA(updown, UDM_SETPOS, 0 , MAKELONG(5,0) );
|
|
/* Since UDM_SETBUDDYINT was not set at creation HIWORD(r) will always be 1 as a return from UDM_GETPOS */
|
|
/* Get the position, which should be 5 */
|
|
r = SendMessageA(updown, UDM_GETPOS, 0 , 0 );
|
|
expect(5,LOWORD(r));
|
|
expect(1,HIWORD(r));
|
|
|
|
/* Set the position to 0, return should be 5 */
|
|
r = SendMessageA(updown, UDM_SETPOS, 0 , MAKELONG(0,0) );
|
|
expect(5,r);
|
|
/* Get the position, which should be 0 */
|
|
r = SendMessageA(updown, UDM_GETPOS, 0 , 0 );
|
|
expect(0,LOWORD(r));
|
|
expect(1,HIWORD(r));
|
|
|
|
/* Set the position to -1, return should be 0 */
|
|
r = SendMessageA(updown, UDM_SETPOS, 0 , MAKELONG(-1,0) );
|
|
expect(0,r);
|
|
/* Get the position, which should be 0 */
|
|
r = SendMessageA(updown, UDM_GETPOS, 0 , 0 );
|
|
expect(0,LOWORD(r));
|
|
expect(1,HIWORD(r));
|
|
|
|
/* Set the position to 100, return should be 0 */
|
|
r = SendMessageA(updown, UDM_SETPOS, 0 , MAKELONG(100,0) );
|
|
expect(0,r);
|
|
/* Get the position, which should be 100 */
|
|
r = SendMessageA(updown, UDM_GETPOS, 0 , 0 );
|
|
expect(100,LOWORD(r));
|
|
expect(1,HIWORD(r));
|
|
|
|
/* Set the position to 101, return should be 100 */
|
|
r = SendMessageA(updown, UDM_SETPOS, 0 , MAKELONG(101,0) );
|
|
expect(100,r);
|
|
/* Get the position, which should be 100 */
|
|
r = SendMessageA(updown, UDM_GETPOS, 0 , 0 );
|
|
expect(100,LOWORD(r));
|
|
expect(1,HIWORD(r));
|
|
|
|
ok_sequence(sequences, UPDOWN_SEQ_INDEX, test_updown_pos_seq , "test updown pos", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
|
|
/* there's no attempt to update buddy Edit if text didn't change */
|
|
SetWindowTextA(g_edit, "50");
|
|
updown = create_updown_control(UDS_ALIGNRIGHT | UDS_SETBUDDYINT | UDS_ARROWKEYS, g_edit);
|
|
|
|
/* test sequence only on 5.8x versions */
|
|
r = SendMessageA(updown, UDM_GETPOS32, 0, 0);
|
|
if (r)
|
|
{
|
|
UDACCEL accel;
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
r = SendMessageA(updown, UDM_SETPOS, 0, 50);
|
|
expect(50,r);
|
|
|
|
ok_sequence(sequences, EDIT_SEQ_INDEX, test_updown_pos_nochange_seq,
|
|
"test updown pos, no change", FALSE);
|
|
|
|
SendMessageA(updown, UDM_SETRANGE, 0, MAKELONG(1, 40));
|
|
r = SendMessageA(updown, UDM_GETRANGE, 0, 0);
|
|
expect(1, LOWORD(r));
|
|
expect(40, HIWORD(r));
|
|
|
|
accel.nSec = 0;
|
|
accel.nInc = 5;
|
|
r = SendMessageA(updown, UDM_SETACCEL, 1, (LPARAM)&accel);
|
|
expect(TRUE, r);
|
|
|
|
r = SendMessageA(updown, UDM_GETPOS, 0, 0);
|
|
expect(40, LOWORD(r));
|
|
expect(1, HIWORD(r));
|
|
|
|
r = SendMessageA(updown, UDM_SETPOS, 0, MAKELONG(0, 0));
|
|
expect(40, LOWORD(r));
|
|
expect(0, HIWORD(r));
|
|
|
|
r = SendMessageA(updown, UDM_GETPOS, 0, 0);
|
|
expect(1, LOWORD(r));
|
|
expect(0, HIWORD(r));
|
|
|
|
r = SendMessageA(updown, UDM_SETPOS, 0, MAKELONG(2, 0));
|
|
expect(1, LOWORD(r));
|
|
expect(0, HIWORD(r));
|
|
|
|
r = SendMessageA(g_edit, WM_KEYDOWN, VK_UP, 0);
|
|
expect(0, r);
|
|
r = SendMessageA(updown, UDM_GETPOS, 0, 0);
|
|
expect(1, LOWORD(r));
|
|
expect(0, HIWORD(r));
|
|
|
|
r = SendMessageA(updown, UDM_SETPOS, 0, MAKELONG(50, 0));
|
|
expect(1, LOWORD(r));
|
|
expect(0, HIWORD(r));
|
|
|
|
r = SendMessageA(updown, UDM_GETPOS, 0, 0);
|
|
expect(40, LOWORD(r));
|
|
expect(0, HIWORD(r));
|
|
}
|
|
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void test_updown_pos32(void)
|
|
{
|
|
HWND updown;
|
|
int r;
|
|
int low, high;
|
|
|
|
updown = create_updown_control(UDS_ALIGNRIGHT, g_edit);
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
/* Set the position to 0 to 1000 */
|
|
SendMessageA(updown, UDM_SETRANGE32, 0 , 1000 );
|
|
|
|
low = high = -1;
|
|
r = SendMessageA(updown, UDM_GETRANGE32, (WPARAM) &low , (LPARAM) &high );
|
|
expect(0,r);
|
|
if (low == -1)
|
|
{
|
|
win_skip("UDM_SETRANGE32/UDM_GETRANGE32 not available\n");
|
|
DestroyWindow(updown);
|
|
return;
|
|
}
|
|
|
|
expect(0,low);
|
|
expect(1000,high);
|
|
|
|
/* Set position to 500 */
|
|
r = SendMessageA(updown, UDM_SETPOS32, 0 , 500 );
|
|
if (!r)
|
|
{
|
|
win_skip("UDM_SETPOS32 and UDM_GETPOS32 need 5.80\n");
|
|
DestroyWindow(updown);
|
|
return;
|
|
}
|
|
expect(50,r);
|
|
|
|
/* Since UDM_SETBUDDYINT was not set at creation bRet will always be true as a return from UDM_GETPOS32 */
|
|
|
|
r = SendMessageA(updown, UDM_GETPOS32, 0 , (LPARAM) &high );
|
|
expect(500,r);
|
|
expect(1,high);
|
|
|
|
/* Set position to 0, return should be 500 */
|
|
r = SendMessageA(updown, UDM_SETPOS32, 0 , 0 );
|
|
expect(500,r);
|
|
r = SendMessageA(updown, UDM_GETPOS32, 0 , (LPARAM) &high );
|
|
expect(0,r);
|
|
expect(1,high);
|
|
|
|
/* Set position to -1 which should become 0, return should be 0 */
|
|
r = SendMessageA(updown, UDM_SETPOS32, 0 , -1 );
|
|
expect(0,r);
|
|
r = SendMessageA(updown, UDM_GETPOS32, 0 , (LPARAM) &high );
|
|
expect(0,r);
|
|
expect(1,high);
|
|
|
|
/* Set position to 1000, return should be 0 */
|
|
r = SendMessageA(updown, UDM_SETPOS32, 0 , 1000 );
|
|
expect(0,r);
|
|
r = SendMessageA(updown, UDM_GETPOS32, 0 , (LPARAM) &high );
|
|
expect(1000,r);
|
|
expect(1,high);
|
|
|
|
/* Set position to 1001 which should become 1000, return should be 1000 */
|
|
r = SendMessageA(updown, UDM_SETPOS32, 0 , 1001 );
|
|
expect(1000,r);
|
|
r = SendMessageA(updown, UDM_GETPOS32, 0 , (LPARAM) &high );
|
|
expect(1000,r);
|
|
expect(1,high);
|
|
|
|
ok_sequence(sequences, UPDOWN_SEQ_INDEX, test_updown_pos32_seq, "test updown pos32", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
|
|
/* there's no attempt to update buddy Edit if text didn't change */
|
|
SetWindowTextA(g_edit, "50");
|
|
updown = create_updown_control(UDS_ALIGNRIGHT | UDS_SETBUDDYINT, g_edit);
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
r = SendMessageA(updown, UDM_SETPOS32, 0, 50);
|
|
expect(50,r);
|
|
ok_sequence(sequences, EDIT_SEQ_INDEX, test_updown_pos_nochange_seq,
|
|
"test updown pos, no change", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void test_updown_buddy(void)
|
|
{
|
|
HWND updown, buddyReturn, buddy;
|
|
RECT rect, rect2;
|
|
WNDPROC proc;
|
|
DWORD style;
|
|
|
|
updown = create_updown_control(UDS_ALIGNRIGHT, g_edit);
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_GETBUDDY, 0 , 0 );
|
|
ok(buddyReturn == g_edit, "Expected edit handle\n");
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_SETBUDDY, (WPARAM) g_edit, 0);
|
|
ok(buddyReturn == g_edit, "Expected edit handle\n");
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_GETBUDDY, 0 , 0 );
|
|
ok(buddyReturn == g_edit, "Expected edit handle\n");
|
|
|
|
ok_sequence(sequences, UPDOWN_SEQ_INDEX, test_updown_buddy_seq, "test updown buddy", TRUE);
|
|
ok_sequence(sequences, EDIT_SEQ_INDEX, add_updown_with_edit_seq, "test updown buddy_edit", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
|
|
buddy = create_edit_control();
|
|
proc = (WNDPROC)GetWindowLongPtrA(buddy, GWLP_WNDPROC);
|
|
|
|
updown= create_updown_control(UDS_ALIGNRIGHT, buddy);
|
|
ok(proc == (WNDPROC)GetWindowLongPtrA(buddy, GWLP_WNDPROC), "No subclassing expected\n");
|
|
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
SetWindowLongA(updown, GWL_STYLE, style | UDS_ARROWKEYS);
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
ok(style & UDS_ARROWKEYS, "Expected UDS_ARROWKEYS\n");
|
|
/* no subclass if UDS_ARROWKEYS set after creation */
|
|
ok(proc == (WNDPROC)GetWindowLongPtrA(buddy, GWLP_WNDPROC), "No subclassing expected\n");
|
|
|
|
DestroyWindow(updown);
|
|
|
|
updown= create_updown_control(UDS_ALIGNRIGHT | UDS_ARROWKEYS, buddy);
|
|
ok(proc != (WNDPROC)GetWindowLongPtrA(buddy, GWLP_WNDPROC), "Subclassing expected\n");
|
|
|
|
if (pSetWindowSubclass)
|
|
{
|
|
/* updown uses subclass helpers for buddy on >5.8x systems */
|
|
ok(GetPropA(buddy, "CC32SubclassInfo") != NULL, "Expected CC32SubclassInfo property\n");
|
|
}
|
|
|
|
DestroyWindow(updown);
|
|
DestroyWindow(buddy);
|
|
|
|
/* Create with buddy and UDS_HORZ, reset buddy. */
|
|
updown = create_updown_control(UDS_HORZ, g_edit);
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_GETBUDDY, 0, 0);
|
|
ok(buddyReturn == g_edit, "Unexpected buddy window.\n");
|
|
|
|
GetClientRect(updown, &rect);
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_SETBUDDY, 0, 0);
|
|
ok(buddyReturn == g_edit, "Unexpected buddy window.\n");
|
|
|
|
GetClientRect(updown, &rect2);
|
|
ok(EqualRect(&rect, &rect2), "Unexpected window rect.\n");
|
|
|
|
/* Remove UDS_HORZ, reset buddy again. */
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
SetWindowLongA(updown, GWL_STYLE, style & ~UDS_HORZ);
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
ok(!(style & UDS_HORZ), "Unexpected style.\n");
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_SETBUDDY, 0, 0);
|
|
ok(buddyReturn == NULL, "Unexpected buddy window.\n");
|
|
|
|
GetClientRect(updown, &rect2);
|
|
ok(EqualRect(&rect, &rect2), "Unexpected window rect.\n");
|
|
|
|
DestroyWindow(updown);
|
|
|
|
/* Without UDS_HORZ. */
|
|
updown = create_updown_control(0, g_edit);
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_GETBUDDY, 0, 0);
|
|
ok(buddyReturn == g_edit, "Unexpected buddy window.\n");
|
|
|
|
GetClientRect(updown, &rect);
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_SETBUDDY, 0, 0);
|
|
ok(buddyReturn == g_edit, "Unexpected buddy window.\n");
|
|
|
|
GetClientRect(updown, &rect2);
|
|
ok(EqualRect(&rect, &rect2), "Unexpected window rect.\n");
|
|
|
|
DestroyWindow(updown);
|
|
|
|
/* Create without buddy. */
|
|
GetClientRect(parent_wnd, &rect);
|
|
updown = CreateWindowExA(0, UPDOWN_CLASSA, NULL, WS_CHILD | WS_BORDER | WS_VISIBLE | UDS_HORZ,
|
|
0, 0, rect.right, rect.bottom, parent_wnd, (HMENU)1, GetModuleHandleA(NULL), NULL);
|
|
ok(updown != NULL, "Failed to create UpDown control.\n");
|
|
|
|
GetClientRect(updown, &rect);
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_SETBUDDY, 0, 0);
|
|
ok(buddyReturn == NULL, "Unexpected buddy window.\n");
|
|
GetClientRect(updown, &rect2);
|
|
|
|
ok(EqualRect(&rect, &rect2), "Unexpected window rect.\n");
|
|
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
SetWindowLongA(updown, GWL_STYLE, style & ~UDS_HORZ);
|
|
|
|
GetClientRect(updown, &rect2);
|
|
ok(EqualRect(&rect, &rect2), "Unexpected window rect.\n");
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_SETBUDDY, (WPARAM)g_edit, 0);
|
|
ok(buddyReturn == NULL, "Unexpected buddy window.\n");
|
|
GetClientRect(updown, &rect);
|
|
|
|
buddyReturn = (HWND)SendMessageA(updown, UDM_SETBUDDY, 0, 0);
|
|
ok(buddyReturn == g_edit, "Unexpected buddy window.\n");
|
|
GetClientRect(updown, &rect2);
|
|
todo_wine
|
|
ok(EqualRect(&rect, &rect2), "Unexpected window rect.\n");
|
|
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void test_updown_base(void)
|
|
{
|
|
HWND updown;
|
|
int r;
|
|
CHAR text[10];
|
|
|
|
updown = create_updown_control(UDS_ALIGNRIGHT, g_edit);
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
SendMessageA(updown, UDM_SETBASE, 10 , 0);
|
|
r = SendMessageA(updown, UDM_GETBASE, 0 , 0);
|
|
expect(10,r);
|
|
|
|
/* Set base to an invalid value, should return 0 and stay at 10 */
|
|
r = SendMessageA(updown, UDM_SETBASE, 80 , 0);
|
|
expect(0,r);
|
|
r = SendMessageA(updown, UDM_GETBASE, 0 , 0);
|
|
expect(10,r);
|
|
|
|
/* Set base to 16 now, should get 16 as the return */
|
|
r = SendMessageA(updown, UDM_SETBASE, 16 , 0);
|
|
expect(10,r);
|
|
r = SendMessageA(updown, UDM_GETBASE, 0 , 0);
|
|
expect(16,r);
|
|
|
|
/* Set base to an invalid value, should return 0 and stay at 16 */
|
|
r = SendMessageA(updown, UDM_SETBASE, 80 , 0);
|
|
expect(0,r);
|
|
r = SendMessageA(updown, UDM_GETBASE, 0 , 0);
|
|
expect(16,r);
|
|
|
|
/* Set base back to 10, return should be 16 */
|
|
r = SendMessageA(updown, UDM_SETBASE, 10 , 0);
|
|
expect(16,r);
|
|
r = SendMessageA(updown, UDM_GETBASE, 0 , 0);
|
|
expect(10,r);
|
|
|
|
ok_sequence(sequences, UPDOWN_SEQ_INDEX, test_updown_base_seq, "test updown base", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
|
|
/* switch base with buddy attached */
|
|
updown = create_updown_control(UDS_SETBUDDYINT | UDS_ALIGNRIGHT, g_edit);
|
|
|
|
r = SendMessageA(updown, UDM_SETPOS, 0, 10);
|
|
expect(50, r);
|
|
|
|
GetWindowTextA(g_edit, text, ARRAY_SIZE(text));
|
|
ok(lstrcmpA(text, "10") == 0, "Expected '10', got '%s'\n", text);
|
|
|
|
r = SendMessageA(updown, UDM_SETBASE, 16, 0);
|
|
expect(10, r);
|
|
|
|
GetWindowTextA(g_edit, text, ARRAY_SIZE(text));
|
|
/* FIXME: currently hex output isn't properly formatted, but for this
|
|
test only change from initial text matters */
|
|
ok(lstrcmpA(text, "10") != 0, "Expected '0x000A', got '%s'\n", text);
|
|
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void test_updown_unicode(void)
|
|
{
|
|
HWND updown;
|
|
int r;
|
|
|
|
updown = create_updown_control(UDS_ALIGNRIGHT, g_edit);
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
/* Set it to ANSI, don't check return as we don't know previous state */
|
|
SendMessageA(updown, UDM_SETUNICODEFORMAT, 0 , 0);
|
|
r = SendMessageA(updown, UDM_GETUNICODEFORMAT, 0 , 0);
|
|
expect(0,r);
|
|
|
|
/* Now set it to Unicode format */
|
|
r = SendMessageA(updown, UDM_SETUNICODEFORMAT, 1 , 0);
|
|
expect(0,r);
|
|
r = SendMessageA(updown, UDM_GETUNICODEFORMAT, 0 , 0);
|
|
if (!r)
|
|
{
|
|
win_skip("UDM_SETUNICODEFORMAT not available\n");
|
|
DestroyWindow(updown);
|
|
return;
|
|
}
|
|
expect(1,r);
|
|
|
|
/* And now set it back to ANSI */
|
|
r = SendMessageA(updown, UDM_SETUNICODEFORMAT, 0 , 0);
|
|
expect(1,r);
|
|
r = SendMessageA(updown, UDM_GETUNICODEFORMAT, 0 , 0);
|
|
expect(0,r);
|
|
|
|
ok_sequence(sequences, UPDOWN_SEQ_INDEX, test_updown_unicode_seq, "test updown unicode", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void test_updown_create(void)
|
|
{
|
|
CHAR text[MAX_PATH];
|
|
HWND updown;
|
|
RECT r;
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
updown = create_updown_control(UDS_ALIGNRIGHT, g_edit);
|
|
ok(updown != NULL, "Failed to create updown control\n");
|
|
ok_sequence(sequences, PARENT_SEQ_INDEX, add_updown_to_parent_seq, "add updown control to parent", TRUE);
|
|
ok_sequence(sequences, EDIT_SEQ_INDEX, add_updown_with_edit_seq, "add updown control with edit", FALSE);
|
|
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
GetWindowTextA(g_edit, text, MAX_PATH);
|
|
ok(!*text, "Expected empty string\n");
|
|
ok_sequence(sequences, EDIT_SEQ_INDEX, get_edit_text_seq, "get edit text", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
|
|
/* create with zero width */
|
|
updown = CreateWindowA (UPDOWN_CLASSA, 0, WS_CHILD | WS_BORDER | WS_VISIBLE, 0, 0, 0, 0,
|
|
parent_wnd, (HMENU)(DWORD_PTR)1, GetModuleHandleA(NULL), 0);
|
|
ok(updown != NULL, "Failed to create updown control\n");
|
|
r.right = 0;
|
|
GetClientRect(updown, &r);
|
|
ok(r.right > 0, "Expected default width, got %d\n", r.right);
|
|
DestroyWindow(updown);
|
|
/* create with really small width */
|
|
updown = CreateWindowA (UPDOWN_CLASSA, 0, WS_CHILD | WS_BORDER | WS_VISIBLE, 0, 0, 2, 0,
|
|
parent_wnd, (HMENU)(DWORD_PTR)1, GetModuleHandleA(NULL), 0);
|
|
ok(updown != NULL, "Failed to create updown control\n");
|
|
r.right = 0;
|
|
GetClientRect(updown, &r);
|
|
ok(r.right != 2 && r.right > 0, "Expected default width, got %d\n", r.right);
|
|
DestroyWindow(updown);
|
|
/* create with width greater than default */
|
|
updown = CreateWindowA (UPDOWN_CLASSA, 0, WS_CHILD | WS_BORDER | WS_VISIBLE, 0, 0, 100, 0,
|
|
parent_wnd, (HMENU)(DWORD_PTR)1, GetModuleHandleA(NULL), 0);
|
|
ok(updown != NULL, "Failed to create updown control\n");
|
|
r.right = 0;
|
|
GetClientRect(updown, &r);
|
|
ok(r.right < 100 && r.right > 0, "Expected default width, got %d\n", r.right);
|
|
DestroyWindow(updown);
|
|
/* create with zero height, UDS_HORZ */
|
|
updown = CreateWindowA (UPDOWN_CLASSA, 0, UDS_HORZ | WS_CHILD | WS_BORDER | WS_VISIBLE, 0, 0, 0, 0,
|
|
parent_wnd, (HMENU)(DWORD_PTR)1, GetModuleHandleA(NULL), 0);
|
|
ok(updown != NULL, "Failed to create updown control\n");
|
|
r.bottom = 0;
|
|
GetClientRect(updown, &r);
|
|
ok(r.bottom == 0, "Expected zero height, got %d\n", r.bottom);
|
|
DestroyWindow(updown);
|
|
/* create with really small height, UDS_HORZ */
|
|
updown = CreateWindowA (UPDOWN_CLASSA, 0, UDS_HORZ | WS_CHILD | WS_BORDER | WS_VISIBLE, 0, 0, 0, 2,
|
|
parent_wnd, (HMENU)(DWORD_PTR)1, GetModuleHandleA(NULL), 0);
|
|
ok(updown != NULL, "Failed to create updown control\n");
|
|
r.bottom = 0;
|
|
GetClientRect(updown, &r);
|
|
ok(r.bottom == 0, "Expected zero height, got %d\n", r.bottom);
|
|
DestroyWindow(updown);
|
|
/* create with height greater than default, UDS_HORZ */
|
|
updown = CreateWindowA (UPDOWN_CLASSA, 0, UDS_HORZ | WS_CHILD | WS_BORDER | WS_VISIBLE, 0, 0, 0, 100,
|
|
parent_wnd, (HMENU)(DWORD_PTR)1, GetModuleHandleA(NULL), 0);
|
|
ok(updown != NULL, "Failed to create updown control\n");
|
|
r.bottom = 0;
|
|
GetClientRect(updown, &r);
|
|
ok(r.bottom < 100 && r.bottom > 0, "Expected default height, got %d\n", r.bottom);
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void test_UDS_SETBUDDYINT(void)
|
|
{
|
|
HWND updown;
|
|
DWORD style, ret;
|
|
CHAR text[10];
|
|
|
|
/* cleanup buddy */
|
|
text[0] = '\0';
|
|
SetWindowTextA(g_edit, text);
|
|
|
|
/* creating without UDS_SETBUDDYINT */
|
|
updown = create_updown_control(UDS_ALIGNRIGHT, g_edit);
|
|
/* try to set UDS_SETBUDDYINT after creation */
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
SetWindowLongA(updown, GWL_STYLE, style | UDS_SETBUDDYINT);
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
ok(style & UDS_SETBUDDYINT, "Expected UDS_SETBUDDY to be set\n");
|
|
SendMessageA(updown, UDM_SETPOS, 0, 20);
|
|
GetWindowTextA(g_edit, text, ARRAY_SIZE(text));
|
|
ok(!*text, "Expected empty string\n");
|
|
DestroyWindow(updown);
|
|
|
|
/* creating with UDS_SETBUDDYINT */
|
|
updown = create_updown_control(UDS_SETBUDDYINT | UDS_ALIGNRIGHT, g_edit);
|
|
GetWindowTextA(g_edit, text, ARRAY_SIZE(text));
|
|
/* 50 is initial value here */
|
|
ok(lstrcmpA(text, "50") == 0, "Expected '50', got '%s'\n", text);
|
|
/* now remove style flag */
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
SetWindowLongA(updown, GWL_STYLE, style & ~UDS_SETBUDDYINT);
|
|
SendMessageA(updown, UDM_SETPOS, 0, 20);
|
|
GetWindowTextA(g_edit, text, ARRAY_SIZE(text));
|
|
ok(lstrcmpA(text, "20") == 0, "Expected '20', got '%s'\n", text);
|
|
/* set edit text directly, check position */
|
|
strcpy(text, "10");
|
|
SetWindowTextA(g_edit, text);
|
|
ret = SendMessageA(updown, UDM_GETPOS, 0, 0);
|
|
expect(10, ret);
|
|
strcpy(text, "11");
|
|
SetWindowTextA(g_edit, text);
|
|
ret = SendMessageA(updown, UDM_GETPOS, 0, 0);
|
|
expect(11, LOWORD(ret));
|
|
expect(0, HIWORD(ret));
|
|
/* set to invalid value */
|
|
strcpy(text, "21st");
|
|
SetWindowTextA(g_edit, text);
|
|
ret = SendMessageA(updown, UDM_GETPOS, 0, 0);
|
|
expect(11, LOWORD(ret));
|
|
expect(TRUE, HIWORD(ret));
|
|
/* set style back */
|
|
style = GetWindowLongA(updown, GWL_STYLE);
|
|
SetWindowLongA(updown, GWL_STYLE, style | UDS_SETBUDDYINT);
|
|
SendMessageA(updown, UDM_SETPOS, 0, 30);
|
|
GetWindowTextA(g_edit, text, ARRAY_SIZE(text));
|
|
ok(lstrcmpA(text, "30") == 0, "Expected '30', got '%s'\n", text);
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void test_CreateUpDownControl(void)
|
|
{
|
|
HWND updown, buddy;
|
|
DWORD range, pos;
|
|
RECT rect;
|
|
|
|
GetClientRect(parent_wnd, &rect);
|
|
updown = pCreateUpDownControl(WS_CHILD | WS_BORDER | WS_VISIBLE,
|
|
0, 0, rect.right, rect.bottom, parent_wnd, 1, GetModuleHandleA(NULL), g_edit, 100, 10, 50);
|
|
ok(updown != NULL, "Failed to create control.\n");
|
|
|
|
buddy = (HWND)SendMessageA(updown, UDM_GETBUDDY, 0, 0);
|
|
ok(buddy == g_edit, "Unexpected buddy window.\n");
|
|
|
|
range = SendMessageA(updown, UDM_GETRANGE, 0, 0);
|
|
ok(range == MAKELONG(100, 10), "Unexpected range.\n");
|
|
|
|
pos = SendMessageA(updown, UDM_GETPOS, 0, 0);
|
|
ok(pos == MAKELONG(50, 1), "Unexpected position.\n");
|
|
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void test_updown_pos_notifications(void)
|
|
{
|
|
HWND updown;
|
|
RECT rect;
|
|
UINT x, y;
|
|
int result;
|
|
|
|
/* test updown control notifications without UDS_HORZ style */
|
|
updown = create_updown_control(UDS_ALIGNRIGHT | UDS_SETBUDDYINT, g_edit);
|
|
SetFocus(updown);
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
/* click on the up-arrow button */
|
|
GetClientRect(updown, &rect);
|
|
x = rect.left + (rect.right - rect.left) / 2;
|
|
y = rect.top + (rect.bottom - rect.top) / 4;
|
|
result = SendMessageA(updown, WM_LBUTTONDOWN, 0, MAKELPARAM(x, y));
|
|
expect(result, 0);
|
|
result = SendMessageA(updown, WM_LBUTTONUP, 0, MAKELPARAM(x, y));
|
|
expect(result, 0);
|
|
|
|
ok_sequence(sequences, PARENT_SEQ_INDEX, test_updown_pos_notifications_seq,
|
|
"test updown to parent notify (vertical)", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
|
|
/* test updown control notifications with UDS_HORZ style */
|
|
updown = create_updown_control(UDS_ALIGNRIGHT | UDS_SETBUDDYINT | UDS_HORZ, g_edit);
|
|
SetFocus(updown);
|
|
flush_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
/* click on the right-arrow button */
|
|
GetClientRect(updown, &rect);
|
|
x = rect.left + (rect.right - rect.left) * 3 / 4;
|
|
y = rect.top + (rect.bottom - rect.top) / 2;
|
|
result = SendMessageA(updown, WM_LBUTTONDOWN, 0, MAKELPARAM(x, y));
|
|
expect(result, 0);
|
|
result = SendMessageA(updown, WM_LBUTTONUP, 0, MAKELPARAM(x, y));
|
|
expect(result, 0);
|
|
|
|
ok_sequence(sequences, PARENT_SEQ_INDEX, test_updown_pos_notifications_horz_seq,
|
|
"test updown to parent notify (horizontal)", FALSE);
|
|
|
|
DestroyWindow(updown);
|
|
}
|
|
|
|
static void init_functions(void)
|
|
{
|
|
HMODULE hComCtl32 = LoadLibraryA("comctl32.dll");
|
|
|
|
#define X(f) p##f = (void*)GetProcAddress(hComCtl32, #f);
|
|
#define X2(f, ord) p##f = (void*)GetProcAddress(hComCtl32, (const char *)ord);
|
|
X(CreateUpDownControl);
|
|
X2(SetWindowSubclass, 410);
|
|
#undef X
|
|
#undef X2
|
|
}
|
|
|
|
START_TEST(updown)
|
|
{
|
|
init_functions();
|
|
|
|
init_msg_sequences(sequences, NUM_MSG_SEQUENCES);
|
|
|
|
parent_wnd = create_parent_window();
|
|
ok(parent_wnd != NULL, "Failed to create parent window!\n");
|
|
g_edit = create_edit_control();
|
|
ok(g_edit != NULL, "Failed to create edit control\n");
|
|
|
|
test_updown_create();
|
|
test_updown_pos();
|
|
test_updown_pos32();
|
|
test_updown_buddy();
|
|
test_updown_base();
|
|
test_updown_unicode();
|
|
test_UDS_SETBUDDYINT();
|
|
test_CreateUpDownControl();
|
|
test_updown_pos_notifications();
|
|
|
|
DestroyWindow(g_edit);
|
|
DestroyWindow(parent_wnd);
|
|
}
|