test_split_container.h 61 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475
  1. /**************************************************************************/
  2. /* test_split_container.h */
  3. /**************************************************************************/
  4. /* This file is part of: */
  5. /* GODOT ENGINE */
  6. /* https://godotengine.org */
  7. /**************************************************************************/
  8. /* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
  9. /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
  10. /* */
  11. /* Permission is hereby granted, free of charge, to any person obtaining */
  12. /* a copy of this software and associated documentation files (the */
  13. /* "Software"), to deal in the Software without restriction, including */
  14. /* without limitation the rights to use, copy, modify, merge, publish, */
  15. /* distribute, sublicense, and/or sell copies of the Software, and to */
  16. /* permit persons to whom the Software is furnished to do so, subject to */
  17. /* the following conditions: */
  18. /* */
  19. /* The above copyright notice and this permission notice shall be */
  20. /* included in all copies or substantial portions of the Software. */
  21. /* */
  22. /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
  23. /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
  24. /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
  25. /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
  26. /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
  27. /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
  28. /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
  29. /**************************************************************************/
  30. #pragma once
  31. #include "scene/gui/split_container.h"
  32. #include "scene/main/window.h"
  33. #include "tests/test_macros.h"
  34. namespace TestSplitContainer {
  35. static inline void check_positions(SplitContainer *p_sc, const Vector<int> &p_positions, int p_sep, bool p_horizontal = true) {
  36. // Checks the rects of each split container child.
  37. CHECK(p_sc->get_child_count(false) == p_positions.size() + 1);
  38. int last_pos = 0;
  39. for (int i = 0; i < p_sc->get_child_count(false); i++) {
  40. // Assuming there is no invalid children.
  41. Control *c = Object::cast_to<Control>(p_sc->get_child(i, false));
  42. int pos = i >= p_positions.size() ? p_sc->get_size()[p_horizontal ? 0 : 1] : p_positions[i];
  43. Rect2 rect;
  44. if (p_horizontal) {
  45. rect.size.y = p_sc->get_size().y;
  46. rect.position.x = last_pos;
  47. rect.size.x = pos - last_pos;
  48. } else {
  49. rect.size.x = p_sc->get_size().x;
  50. rect.position.y = last_pos;
  51. rect.size.y = pos - last_pos;
  52. }
  53. CHECK_MESSAGE(c->get_rect() == rect, vformat("Child %s is the wrong size.", i));
  54. last_pos = pos + p_sep;
  55. }
  56. }
  57. static inline void check_position(SplitContainer *p_sc, int p_position, int p_sep, bool p_horizontal = true) {
  58. check_positions(p_sc, { p_position }, p_sep, p_horizontal);
  59. }
  60. static inline void check_positions_rtl(SplitContainer *p_sc, const Vector<int> &p_positions, int p_sep) {
  61. // Checks the rects of each split container child. Right to left layout.
  62. CHECK(p_sc->get_child_count(false) == p_positions.size() + 1);
  63. int last_pos = p_sc->get_size().x;
  64. for (int i = 0; i < p_sc->get_child_count(false); i++) {
  65. // Assuming there is no invalid children.
  66. Control *c = Object::cast_to<Control>(p_sc->get_child(i, false));
  67. int pos = i >= p_positions.size() ? 0 : p_sc->get_size().x - p_positions[i];
  68. Rect2 rect;
  69. rect.size.y = p_sc->get_size().y;
  70. rect.position.x = pos;
  71. rect.size.x = last_pos - pos;
  72. CHECK_MESSAGE(c->get_rect() == rect, vformat("Child %s is the wrong size.", i));
  73. last_pos = pos - p_sep;
  74. }
  75. }
  76. static inline void check_position_rtl(SplitContainer *p_sc, int p_position, int p_sep) {
  77. check_positions_rtl(p_sc, { p_position }, p_sep);
  78. }
  79. TEST_CASE("[SceneTree][SplitContainer] Add children") {
  80. SplitContainer *split_container = memnew(SplitContainer);
  81. split_container->set_size(Size2(500, 500));
  82. SceneTree::get_singleton()->get_root()->add_child(split_container);
  83. SUBCASE("[SplitContainer] One child") {
  84. Control *child_a = memnew(Control);
  85. split_container->add_child(child_a);
  86. MessageQueue::get_singleton()->flush();
  87. // One child will fill the entire area.
  88. CHECK(child_a->get_rect() == split_container->get_rect());
  89. split_container->set_vertical(true);
  90. CHECK(child_a->get_rect() == split_container->get_rect());
  91. memdelete(child_a);
  92. }
  93. SUBCASE("[SplitContainer] Preserve split offset") {
  94. // The split offset is preserved through adding, removing, and changing visibility of children.
  95. split_container->set_split_offset(100);
  96. CHECK(split_container->get_split_offset() == 100);
  97. Control *child_a = memnew(Control);
  98. split_container->add_child(child_a);
  99. MessageQueue::get_singleton()->flush();
  100. CHECK(split_container->get_split_offset() == 100);
  101. Control *child_b = memnew(Control);
  102. split_container->add_child(child_b);
  103. MessageQueue::get_singleton()->flush();
  104. CHECK(split_container->get_split_offset() == 100);
  105. child_a->hide();
  106. MessageQueue::get_singleton()->flush();
  107. CHECK(split_container->get_split_offset() == 100);
  108. child_b->hide();
  109. MessageQueue::get_singleton()->flush();
  110. CHECK(split_container->get_split_offset() == 100);
  111. child_b->show();
  112. MessageQueue::get_singleton()->flush();
  113. CHECK(split_container->get_split_offset() == 100);
  114. child_a->show();
  115. MessageQueue::get_singleton()->flush();
  116. CHECK(split_container->get_split_offset() == 100);
  117. split_container->remove_child(child_a);
  118. MessageQueue::get_singleton()->flush();
  119. CHECK(split_container->get_split_offset() == 100);
  120. split_container->add_child(child_a);
  121. MessageQueue::get_singleton()->flush();
  122. CHECK(split_container->get_split_offset() == 100);
  123. memdelete(child_a);
  124. memdelete(child_b);
  125. }
  126. memdelete(split_container);
  127. }
  128. TEST_CASE("[SceneTree][SplitContainer] Dragger visibility") {
  129. SplitContainer *split_container = memnew(SplitContainer);
  130. split_container->set_size(Size2(500, 500));
  131. SceneTree::get_singleton()->get_root()->add_child(split_container);
  132. Control *child_a = memnew(Control);
  133. Control *child_b = memnew(Control);
  134. split_container->add_child(child_a);
  135. split_container->add_child(child_b);
  136. SplitContainerDragger *dragger = Object::cast_to<SplitContainerDragger>(split_container->get_child(2, true));
  137. split_container->add_theme_constant_override("autohide", 0);
  138. MessageQueue::get_singleton()->flush();
  139. const int sep_constant = split_container->get_theme_constant("separation");
  140. const Size2i separator_size = Size2i(MAX(sep_constant, split_container->get_theme_icon("h_grabber")->get_width()), MAX(sep_constant, split_container->get_theme_icon("v_grabber")->get_height()));
  141. SUBCASE("[SplitContainer] Visibility based on child count") {
  142. split_container->remove_child(child_a);
  143. split_container->remove_child(child_b);
  144. MessageQueue::get_singleton()->flush();
  145. // No children, not visible.
  146. CHECK_FALSE(dragger->is_visible());
  147. // Add one child, not visible.
  148. split_container->add_child(child_a);
  149. MessageQueue::get_singleton()->flush();
  150. CHECK_FALSE(dragger->is_visible());
  151. // Two children, visible.
  152. split_container->add_child(child_b);
  153. MessageQueue::get_singleton()->flush();
  154. CHECK(dragger->is_visible());
  155. // Remove a child, not visible.
  156. split_container->remove_child(child_b);
  157. MessageQueue::get_singleton()->flush();
  158. CHECK_FALSE(dragger->is_visible());
  159. }
  160. SUBCASE("[SplitContainer] Set dragger visibility") {
  161. split_container->set_dragger_visibility(SplitContainer::DRAGGER_HIDDEN);
  162. MessageQueue::get_singleton()->flush();
  163. check_position(split_container, 0, separator_size.x);
  164. // Can't check the visibility since it happens in draw.
  165. split_container->set_dragger_visibility(SplitContainer::DRAGGER_HIDDEN_COLLAPSED);
  166. MessageQueue::get_singleton()->flush();
  167. check_position(split_container, 0, 0);
  168. split_container->set_dragger_visibility(SplitContainer::DRAGGER_VISIBLE);
  169. MessageQueue::get_singleton()->flush();
  170. check_position(split_container, 0, separator_size.x);
  171. }
  172. SUBCASE("[SplitContainer] Not visible when collapsed") {
  173. split_container->set_collapsed(true);
  174. MessageQueue::get_singleton()->flush();
  175. CHECK_FALSE(dragger->is_visible());
  176. split_container->set_collapsed(false);
  177. MessageQueue::get_singleton()->flush();
  178. CHECK(dragger->is_visible());
  179. }
  180. memdelete(child_a);
  181. memdelete(child_b);
  182. memdelete(split_container);
  183. }
  184. TEST_CASE("[SceneTree][SplitContainer] Collapsed") {
  185. DisplayServerMock *DS = (DisplayServerMock *)(DisplayServer::get_singleton());
  186. SplitContainer *split_container = memnew(SplitContainer);
  187. split_container->set_size(Size2(500, 500));
  188. SceneTree::get_singleton()->get_root()->add_child(split_container);
  189. Control *child_a = memnew(Control);
  190. split_container->add_child(child_a);
  191. Control *child_b = memnew(Control);
  192. split_container->add_child(child_b);
  193. MessageQueue::get_singleton()->flush();
  194. const int sep_constant = split_container->get_theme_constant("separation");
  195. const Size2i separator_size = Size2i(MAX(sep_constant, split_container->get_theme_icon("h_grabber")->get_width()), MAX(sep_constant, split_container->get_theme_icon("v_grabber")->get_height()));
  196. SUBCASE("[SplitContainer] Dragging and cursor") {
  197. split_container->set_collapsed(true);
  198. // Cursor is default.
  199. SEND_GUI_MOUSE_MOTION_EVENT(Point2(1, 1), MouseButtonMask::NONE, Key::NONE);
  200. CHECK(DS->get_cursor_shape() == DisplayServer::CURSOR_ARROW);
  201. // Dragger is disabled, cannot drag.
  202. SEND_GUI_MOUSE_BUTTON_EVENT(Point2(1, 1), MouseButton::LEFT, MouseButtonMask::LEFT, Key::NONE);
  203. MessageQueue::get_singleton()->flush();
  204. check_position(split_container, 0, separator_size.x);
  205. CHECK(split_container->get_split_offset() == 0);
  206. SEND_GUI_MOUSE_MOTION_EVENT(Point2(10, 1), MouseButtonMask::LEFT, Key::NONE);
  207. MessageQueue::get_singleton()->flush();
  208. check_position(split_container, 0, separator_size.x);
  209. CHECK(split_container->get_split_offset() == 0);
  210. }
  211. SUBCASE("[SplitContainer] No expand flags") {
  212. int def_pos = 0;
  213. split_container->set_split_offset(10);
  214. MessageQueue::get_singleton()->flush();
  215. check_position(split_container, def_pos + 10, separator_size.x);
  216. split_container->set_collapsed(true);
  217. MessageQueue::get_singleton()->flush();
  218. // The split offset is treated as 0 when collapsed.
  219. check_position(split_container, def_pos, separator_size.x);
  220. CHECK(split_container->get_split_offset() == 10);
  221. }
  222. SUBCASE("[SplitContainer] First child expanded") {
  223. int def_pos = split_container->get_size().x - separator_size.x;
  224. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  225. split_container->set_split_offset(-10);
  226. MessageQueue::get_singleton()->flush();
  227. check_position(split_container, def_pos - 10, separator_size.x);
  228. split_container->set_collapsed(true);
  229. MessageQueue::get_singleton()->flush();
  230. // The split offset is treated as 0 when collapsed.
  231. check_position(split_container, def_pos, separator_size.x);
  232. CHECK(split_container->get_split_offset() == -10);
  233. }
  234. SUBCASE("[SplitContainer] Second child expanded") {
  235. int def_pos = 0;
  236. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  237. split_container->set_split_offset(10);
  238. MessageQueue::get_singleton()->flush();
  239. check_position(split_container, def_pos + 10, separator_size.x);
  240. split_container->set_collapsed(true);
  241. MessageQueue::get_singleton()->flush();
  242. // The split offset is treated as 0 when collapsed.
  243. check_position(split_container, def_pos, separator_size.x);
  244. CHECK(split_container->get_split_offset() == 10);
  245. }
  246. SUBCASE("[SplitContainer] Both children expanded") {
  247. int def_pos = (split_container->get_size().y - separator_size.y) / 2;
  248. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  249. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  250. split_container->set_split_offset(10);
  251. MessageQueue::get_singleton()->flush();
  252. check_position(split_container, def_pos + 10, separator_size.x);
  253. split_container->set_collapsed(true);
  254. MessageQueue::get_singleton()->flush();
  255. // The split offset is treated as 0 when collapsed.
  256. check_position(split_container, def_pos, separator_size.x);
  257. CHECK(split_container->get_split_offset() == 10);
  258. }
  259. memdelete(child_a);
  260. memdelete(child_b);
  261. memdelete(split_container);
  262. }
  263. TEST_CASE("[SceneTree][SplitContainer] Cursor shape") {
  264. DisplayServerMock *DS = (DisplayServerMock *)(DisplayServer::get_singleton());
  265. SplitContainer *split_container = memnew(SplitContainer);
  266. split_container->set_size(Size2(500, 500));
  267. SceneTree::get_singleton()->get_root()->add_child(split_container);
  268. Control *child_a = memnew(Control);
  269. split_container->add_child(child_a);
  270. Control *child_b = memnew(Control);
  271. split_container->add_child(child_b);
  272. MessageQueue::get_singleton()->flush();
  273. Point2 on_dragger = Point2(1, 1);
  274. Point2 not_on_dragger = Point2(50, 50);
  275. // Default cursor shape.
  276. SEND_GUI_MOUSE_MOTION_EVENT(not_on_dragger, MouseButtonMask::NONE, Key::NONE);
  277. CHECK(DS->get_cursor_shape() == DisplayServer::CURSOR_ARROW);
  278. // Horizontal cursor shape.
  279. SEND_GUI_MOUSE_MOTION_EVENT(on_dragger, MouseButtonMask::NONE, Key::NONE);
  280. CHECK(DS->get_cursor_shape() == DisplayServer::CURSOR_HSPLIT);
  281. // Vertical cursor shape.
  282. split_container->set_vertical(true);
  283. SEND_GUI_MOUSE_MOTION_EVENT(on_dragger, MouseButtonMask::NONE, Key::NONE);
  284. CHECK(DS->get_cursor_shape() == DisplayServer::CURSOR_VSPLIT);
  285. // Move off, default cursor shape.
  286. SEND_GUI_MOUSE_MOTION_EVENT(not_on_dragger, MouseButtonMask::NONE, Key::NONE);
  287. CHECK(DS->get_cursor_shape() == DisplayServer::CURSOR_ARROW);
  288. memdelete(child_a);
  289. memdelete(child_b);
  290. memdelete(split_container);
  291. }
  292. TEST_CASE("[SceneTree][SplitContainer] Two children") {
  293. SplitContainer *split_container = memnew(SplitContainer);
  294. split_container->set_size(Size2(500, 500));
  295. SceneTree::get_singleton()->get_root()->add_child(split_container);
  296. Control *child_a = memnew(Control);
  297. Control *child_b = memnew(Control);
  298. split_container->add_child(child_a);
  299. split_container->add_child(child_b);
  300. MessageQueue::get_singleton()->flush();
  301. const int sep_constant = split_container->get_theme_constant("separation");
  302. const Size2i separator_size = Size2i(MAX(sep_constant, split_container->get_theme_icon("h_grabber")->get_width()), MAX(sep_constant, split_container->get_theme_icon("v_grabber")->get_height()));
  303. SUBCASE("[SplitContainer] Minimum size") {
  304. // Minimum size is the sum of both children's minimum sizes and the separator depending on the vertical axis.
  305. child_a->set_custom_minimum_size(Size2(100, 200));
  306. child_b->set_custom_minimum_size(Size2(100, 200));
  307. MessageQueue::get_singleton()->flush();
  308. Size2 min_size = split_container->get_minimum_size();
  309. CHECK(min_size.x == 200 + separator_size.x);
  310. CHECK(min_size.y == 200);
  311. split_container->set_vertical(true);
  312. MessageQueue::get_singleton()->flush();
  313. min_size = split_container->get_minimum_size();
  314. CHECK(min_size.x == 100);
  315. CHECK(min_size.y == 400 + separator_size.y);
  316. }
  317. SUBCASE("[SplitContainer] Default position") {
  318. SUBCASE("[SplitContainer] Vertical") {
  319. // Make sure clamping the split offset doesn't change it or the position.
  320. split_container->set_vertical(true);
  321. // No expand flags set.
  322. MessageQueue::get_singleton()->flush();
  323. int def_pos = 0;
  324. check_position(split_container, def_pos, separator_size.y, false);
  325. split_container->clamp_split_offset();
  326. MessageQueue::get_singleton()->flush();
  327. CHECK(split_container->get_split_offset() == 0);
  328. check_position(split_container, def_pos, separator_size.y, false);
  329. // First expand flags set.
  330. child_a->set_v_size_flags(Control::SIZE_EXPAND_FILL);
  331. child_b->set_v_size_flags(Control::SIZE_FILL);
  332. MessageQueue::get_singleton()->flush();
  333. def_pos = split_container->get_size().y - separator_size.y;
  334. check_position(split_container, def_pos, separator_size.y, false);
  335. split_container->clamp_split_offset();
  336. MessageQueue::get_singleton()->flush();
  337. CHECK(split_container->get_split_offset() == 0);
  338. check_position(split_container, def_pos, separator_size.y, false);
  339. // Second expand flags set.
  340. child_a->set_v_size_flags(Control::SIZE_FILL);
  341. child_b->set_v_size_flags(Control::SIZE_EXPAND_FILL);
  342. MessageQueue::get_singleton()->flush();
  343. def_pos = 0;
  344. check_position(split_container, 0, separator_size.y, false);
  345. split_container->clamp_split_offset();
  346. MessageQueue::get_singleton()->flush();
  347. CHECK(split_container->get_split_offset() == 0);
  348. check_position(split_container, def_pos, separator_size.y, false);
  349. // Both expand flags set.
  350. child_a->set_v_size_flags(Control::SIZE_EXPAND_FILL);
  351. child_b->set_v_size_flags(Control::SIZE_EXPAND_FILL);
  352. MessageQueue::get_singleton()->flush();
  353. def_pos = (split_container->get_size().y - separator_size.y) / 2;
  354. check_position(split_container, def_pos, separator_size.y, false);
  355. split_container->clamp_split_offset();
  356. MessageQueue::get_singleton()->flush();
  357. CHECK(split_container->get_split_offset() == 0);
  358. check_position(split_container, def_pos, separator_size.y, false);
  359. // Unequal stretch ratios.
  360. child_a->set_stretch_ratio(2.0);
  361. MessageQueue::get_singleton()->flush();
  362. def_pos = (split_container->get_size().y * 2 / 3) - separator_size.y / 2;
  363. check_position(split_container, def_pos, separator_size.y, false);
  364. split_container->clamp_split_offset();
  365. MessageQueue::get_singleton()->flush();
  366. CHECK(split_container->get_split_offset() == 0);
  367. check_position(split_container, def_pos, separator_size.y, false);
  368. }
  369. SUBCASE("[SplitContainer] Right to left") {
  370. split_container->set_layout_direction(Control::LAYOUT_DIRECTION_RTL);
  371. split_container->set_position(Point2(0, 0));
  372. // No expand flags set.
  373. MessageQueue::get_singleton()->flush();
  374. int def_pos = 0;
  375. check_position_rtl(split_container, def_pos, separator_size.y);
  376. split_container->clamp_split_offset();
  377. MessageQueue::get_singleton()->flush();
  378. CHECK(split_container->get_split_offset() == 0);
  379. check_position_rtl(split_container, def_pos, separator_size.y);
  380. // First expand flags set.
  381. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  382. child_b->set_h_size_flags(Control::SIZE_FILL);
  383. MessageQueue::get_singleton()->flush();
  384. def_pos = split_container->get_size().y - separator_size.y;
  385. check_position_rtl(split_container, def_pos, separator_size.y);
  386. split_container->clamp_split_offset();
  387. MessageQueue::get_singleton()->flush();
  388. CHECK(split_container->get_split_offset() == 0);
  389. check_position_rtl(split_container, def_pos, separator_size.y);
  390. // Second expand flags set.
  391. child_a->set_h_size_flags(Control::SIZE_FILL);
  392. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  393. MessageQueue::get_singleton()->flush();
  394. def_pos = 0;
  395. check_position_rtl(split_container, 0, separator_size.y);
  396. split_container->clamp_split_offset();
  397. MessageQueue::get_singleton()->flush();
  398. CHECK(split_container->get_split_offset() == 0);
  399. check_position_rtl(split_container, def_pos, separator_size.y);
  400. // Both expand flags set.
  401. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  402. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  403. MessageQueue::get_singleton()->flush();
  404. def_pos = (split_container->get_size().y - separator_size.y) / 2;
  405. check_position_rtl(split_container, def_pos, separator_size.y);
  406. split_container->clamp_split_offset();
  407. MessageQueue::get_singleton()->flush();
  408. CHECK(split_container->get_split_offset() == 0);
  409. check_position_rtl(split_container, def_pos, separator_size.y);
  410. // Unequal stretch ratios.
  411. child_a->set_stretch_ratio(2.0);
  412. MessageQueue::get_singleton()->flush();
  413. def_pos = (split_container->get_size().y * 2 / 3) - separator_size.y / 2;
  414. check_position_rtl(split_container, def_pos, separator_size.y);
  415. split_container->clamp_split_offset();
  416. MessageQueue::get_singleton()->flush();
  417. CHECK(split_container->get_split_offset() == 0);
  418. check_position_rtl(split_container, def_pos, separator_size.y);
  419. }
  420. SUBCASE("[SplitContainer] No expand flags") {
  421. int def_pos = 0;
  422. check_position(split_container, def_pos, separator_size.x);
  423. split_container->clamp_split_offset();
  424. MessageQueue::get_singleton()->flush();
  425. CHECK(split_container->get_split_offset() == 0);
  426. check_position(split_container, def_pos, separator_size.x);
  427. // Minimum sizes affect default position.
  428. // First child with minimum size.
  429. child_a->set_custom_minimum_size(Size2(400, 0));
  430. MessageQueue::get_singleton()->flush();
  431. def_pos = 400;
  432. check_position(split_container, def_pos, separator_size.x);
  433. split_container->clamp_split_offset();
  434. MessageQueue::get_singleton()->flush();
  435. CHECK(split_container->get_split_offset() == def_pos);
  436. check_position(split_container, def_pos, separator_size.x);
  437. // Second child with minimum size.
  438. child_a->set_custom_minimum_size(Size2(0, 0));
  439. child_b->set_custom_minimum_size(Size2(400, 0));
  440. MessageQueue::get_singleton()->flush();
  441. def_pos = split_container->get_size().x - 400 - separator_size.x;
  442. check_position(split_container, def_pos, separator_size.x);
  443. split_container->clamp_split_offset();
  444. MessageQueue::get_singleton()->flush();
  445. CHECK(split_container->get_split_offset() == def_pos);
  446. check_position(split_container, def_pos, separator_size.x);
  447. // Both children with minimum size.
  448. child_a->set_custom_minimum_size(Size2(200, 0));
  449. child_b->set_custom_minimum_size(Size2(288, 0));
  450. MessageQueue::get_singleton()->flush();
  451. def_pos = 200;
  452. check_position(split_container, def_pos, separator_size.x);
  453. split_container->clamp_split_offset();
  454. MessageQueue::get_singleton()->flush();
  455. CHECK(split_container->get_split_offset() == def_pos);
  456. check_position(split_container, def_pos, separator_size.x);
  457. }
  458. SUBCASE("[SplitContainer] First child expanded") {
  459. const int def_pos = split_container->get_size().x - separator_size.x;
  460. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  461. MessageQueue::get_singleton()->flush();
  462. check_position(split_container, def_pos, separator_size.x);
  463. split_container->clamp_split_offset();
  464. MessageQueue::get_singleton()->flush();
  465. CHECK(split_container->get_split_offset() == 0);
  466. check_position(split_container, def_pos, separator_size.x);
  467. // Minimum sizes affect default position.
  468. // First child with minimum size.
  469. child_a->set_custom_minimum_size(Size2(400, 0));
  470. MessageQueue::get_singleton()->flush();
  471. check_position(split_container, def_pos, separator_size.x);
  472. split_container->clamp_split_offset();
  473. MessageQueue::get_singleton()->flush();
  474. CHECK(split_container->get_split_offset() == 0);
  475. check_position(split_container, def_pos, separator_size.x);
  476. // Second child with minimum size.
  477. child_a->set_custom_minimum_size(Size2(0, 0));
  478. child_b->set_custom_minimum_size(Size2(400, 0));
  479. MessageQueue::get_singleton()->flush();
  480. int pos = split_container->get_size().x - 400 - separator_size.x;
  481. check_position(split_container, pos, separator_size.x);
  482. split_container->clamp_split_offset();
  483. MessageQueue::get_singleton()->flush();
  484. CHECK(split_container->get_split_offset() == pos - def_pos);
  485. check_position(split_container, pos, separator_size.x);
  486. // Both children with minimum size.
  487. child_a->set_custom_minimum_size(Size2(200, 0));
  488. child_b->set_custom_minimum_size(Size2(288, 0));
  489. MessageQueue::get_singleton()->flush();
  490. pos = 200;
  491. check_position(split_container, pos, separator_size.x);
  492. split_container->clamp_split_offset();
  493. MessageQueue::get_singleton()->flush();
  494. CHECK(split_container->get_split_offset() == pos - def_pos);
  495. check_position(split_container, pos, separator_size.x);
  496. }
  497. SUBCASE("[SplitContainer] Second child expanded") {
  498. int def_pos = 0;
  499. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  500. MessageQueue::get_singleton()->flush();
  501. check_position(split_container, def_pos, separator_size.x);
  502. split_container->clamp_split_offset();
  503. MessageQueue::get_singleton()->flush();
  504. CHECK(split_container->get_split_offset() == 0);
  505. check_position(split_container, def_pos, separator_size.x);
  506. // Minimum sizes affect default position.
  507. // First child with minimum size.
  508. child_a->set_custom_minimum_size(Size2(400, 0));
  509. MessageQueue::get_singleton()->flush();
  510. def_pos = 400;
  511. check_position(split_container, def_pos, separator_size.x);
  512. split_container->clamp_split_offset();
  513. MessageQueue::get_singleton()->flush();
  514. CHECK(split_container->get_split_offset() == def_pos);
  515. check_position(split_container, def_pos, separator_size.x);
  516. // Second child with minimum size.
  517. child_a->set_custom_minimum_size(Size2(0, 0));
  518. child_b->set_custom_minimum_size(Size2(400, 0));
  519. MessageQueue::get_singleton()->flush();
  520. def_pos = 500 - 400 - separator_size.x;
  521. check_position(split_container, def_pos, separator_size.x);
  522. split_container->clamp_split_offset();
  523. MessageQueue::get_singleton()->flush();
  524. CHECK(split_container->get_split_offset() == def_pos);
  525. check_position(split_container, def_pos, separator_size.x);
  526. // Both children with minimum size.
  527. child_a->set_custom_minimum_size(Size2(200, 0));
  528. child_b->set_custom_minimum_size(Size2(288, 0));
  529. MessageQueue::get_singleton()->flush();
  530. def_pos = 200;
  531. check_position(split_container, def_pos, separator_size.x);
  532. split_container->clamp_split_offset();
  533. MessageQueue::get_singleton()->flush();
  534. CHECK(split_container->get_split_offset() == def_pos);
  535. check_position(split_container, def_pos, separator_size.x);
  536. }
  537. SUBCASE("[SplitContainer] Both children expanded") {
  538. const int def_pos = (split_container->get_size().x - separator_size.x) / 2;
  539. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  540. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  541. MessageQueue::get_singleton()->flush();
  542. check_position(split_container, def_pos, separator_size.x);
  543. split_container->clamp_split_offset();
  544. MessageQueue::get_singleton()->flush();
  545. CHECK(split_container->get_split_offset() == 0);
  546. check_position(split_container, def_pos, separator_size.x);
  547. // Minimum sizes affect default position.
  548. // First child with minimum size.
  549. child_a->set_custom_minimum_size(Size2(400, 0));
  550. MessageQueue::get_singleton()->flush();
  551. int pos = 400;
  552. check_position(split_container, pos, separator_size.x);
  553. split_container->clamp_split_offset();
  554. MessageQueue::get_singleton()->flush();
  555. CHECK(split_container->get_split_offset() == pos - def_pos);
  556. check_position(split_container, pos, separator_size.x);
  557. // Second child with minimum size.
  558. child_a->set_custom_minimum_size(Size2(0, 0));
  559. child_b->set_custom_minimum_size(Size2(400, 0));
  560. MessageQueue::get_singleton()->flush();
  561. pos = split_container->get_size().x - 400 - separator_size.x;
  562. check_position(split_container, pos, separator_size.x);
  563. split_container->clamp_split_offset();
  564. MessageQueue::get_singleton()->flush();
  565. CHECK(split_container->get_split_offset() == pos - def_pos);
  566. check_position(split_container, pos, separator_size.x);
  567. // Both children with minimum size.
  568. child_a->set_custom_minimum_size(Size2(200, 0));
  569. child_b->set_custom_minimum_size(Size2(288, 0));
  570. MessageQueue::get_singleton()->flush();
  571. pos = 200;
  572. check_position(split_container, pos, separator_size.x);
  573. split_container->clamp_split_offset();
  574. MessageQueue::get_singleton()->flush();
  575. CHECK(split_container->get_split_offset() == pos - def_pos);
  576. check_position(split_container, pos, separator_size.x);
  577. }
  578. SUBCASE("[SplitContainer] Unequal stretch ratios") {
  579. const int def_pos = (split_container->get_size().x * 2 / 3) - separator_size.x / 2;
  580. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  581. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  582. child_a->set_stretch_ratio(2.0);
  583. MessageQueue::get_singleton()->flush();
  584. check_position(split_container, def_pos, separator_size.x);
  585. split_container->clamp_split_offset();
  586. MessageQueue::get_singleton()->flush();
  587. CHECK(split_container->get_split_offset() == 0);
  588. check_position(split_container, def_pos, separator_size.x);
  589. // Minimum sizes affect default position.
  590. // First child with minimum size.
  591. child_a->set_custom_minimum_size(Size2(400, 0));
  592. MessageQueue::get_singleton()->flush();
  593. int pos = 400;
  594. check_position(split_container, pos, separator_size.x);
  595. split_container->clamp_split_offset();
  596. MessageQueue::get_singleton()->flush();
  597. CHECK(split_container->get_split_offset() == pos - def_pos);
  598. check_position(split_container, pos, separator_size.x);
  599. // Second child with minimum size.
  600. child_a->set_custom_minimum_size(Size2(0, 0));
  601. child_b->set_custom_minimum_size(Size2(400, 0));
  602. MessageQueue::get_singleton()->flush();
  603. pos = split_container->get_size().x - 400 - separator_size.x;
  604. check_position(split_container, pos, separator_size.x);
  605. split_container->clamp_split_offset();
  606. MessageQueue::get_singleton()->flush();
  607. CHECK(split_container->get_split_offset() == pos - def_pos);
  608. check_position(split_container, pos, separator_size.x);
  609. // Both children with minimum size.
  610. child_a->set_custom_minimum_size(Size2(200, 0));
  611. child_b->set_custom_minimum_size(Size2(288, 0));
  612. MessageQueue::get_singleton()->flush();
  613. pos = 200;
  614. check_position(split_container, pos, separator_size.x);
  615. split_container->clamp_split_offset();
  616. MessageQueue::get_singleton()->flush();
  617. CHECK(split_container->get_split_offset() == pos - def_pos);
  618. check_position(split_container, pos, separator_size.x);
  619. }
  620. }
  621. SUBCASE("[SplitContainer] Set split offset") {
  622. SUBCASE("[SplitContainer] Right to left") {
  623. split_container->set_layout_direction(Control::LAYOUT_DIRECTION_RTL);
  624. split_container->set_position(Point2(0, 0));
  625. int def_pos = 0;
  626. // Positive.
  627. split_container->set_split_offset(10);
  628. MessageQueue::get_singleton()->flush();
  629. CHECK(split_container->get_split_offset() == 10);
  630. check_position_rtl(split_container, def_pos + 10, separator_size.x);
  631. // Negative.
  632. split_container->set_split_offset(-10);
  633. MessageQueue::get_singleton()->flush();
  634. CHECK(split_container->get_split_offset() == -10);
  635. check_position_rtl(split_container, def_pos, separator_size.x);
  636. }
  637. SUBCASE("[SplitContainer] No expand flags") {
  638. int def_pos = 0;
  639. // Positive.
  640. split_container->set_split_offset(10);
  641. MessageQueue::get_singleton()->flush();
  642. CHECK(split_container->get_split_offset() == 10);
  643. check_position(split_container, def_pos + 10, separator_size.x);
  644. // Negative.
  645. split_container->set_split_offset(-10);
  646. MessageQueue::get_singleton()->flush();
  647. CHECK(split_container->get_split_offset() == -10);
  648. check_position(split_container, def_pos, separator_size.x);
  649. // Clamped.
  650. split_container->set_split_offset(1000);
  651. MessageQueue::get_singleton()->flush();
  652. CHECK(split_container->get_split_offset() == 1000);
  653. check_position(split_container, split_container->get_size().x - separator_size.x, separator_size.x);
  654. }
  655. SUBCASE("[SplitContainer] First child expanded") {
  656. int def_pos = split_container->get_size().x - separator_size.x;
  657. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  658. MessageQueue::get_singleton()->flush();
  659. // Positive.
  660. split_container->set_split_offset(10);
  661. MessageQueue::get_singleton()->flush();
  662. CHECK(split_container->get_split_offset() == 10);
  663. check_position(split_container, def_pos, separator_size.x);
  664. // Negative.
  665. split_container->set_split_offset(-10);
  666. MessageQueue::get_singleton()->flush();
  667. CHECK(split_container->get_split_offset() == -10);
  668. check_position(split_container, def_pos - 10, separator_size.x);
  669. // Clamped.
  670. split_container->set_split_offset(-1000);
  671. MessageQueue::get_singleton()->flush();
  672. CHECK(split_container->get_split_offset() == -1000);
  673. check_position(split_container, 0, separator_size.x);
  674. }
  675. SUBCASE("[SplitContainer] Second child expanded") {
  676. int def_pos = 0;
  677. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  678. MessageQueue::get_singleton()->flush();
  679. // Positive.
  680. split_container->set_split_offset(10);
  681. MessageQueue::get_singleton()->flush();
  682. CHECK(split_container->get_split_offset() == 10);
  683. check_position(split_container, def_pos + 10, separator_size.x);
  684. // Negative.
  685. split_container->set_split_offset(-10);
  686. MessageQueue::get_singleton()->flush();
  687. CHECK(split_container->get_split_offset() == -10);
  688. check_position(split_container, def_pos, separator_size.x);
  689. // Clamped.
  690. split_container->set_split_offset(1000);
  691. MessageQueue::get_singleton()->flush();
  692. CHECK(split_container->get_split_offset() == 1000);
  693. check_position(split_container, split_container->get_size().x - separator_size.x, separator_size.x);
  694. }
  695. SUBCASE("[SplitContainer] Both children expanded") {
  696. int def_pos = (split_container->get_size().x - separator_size.x) / 2;
  697. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  698. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  699. MessageQueue::get_singleton()->flush();
  700. // Positive.
  701. split_container->set_split_offset(10);
  702. MessageQueue::get_singleton()->flush();
  703. CHECK(split_container->get_split_offset() == 10);
  704. check_position(split_container, def_pos + 10, separator_size.x);
  705. // Negative.
  706. split_container->set_split_offset(-10);
  707. MessageQueue::get_singleton()->flush();
  708. CHECK(split_container->get_split_offset() == -10);
  709. check_position(split_container, def_pos - 10, separator_size.x);
  710. // Clamped positive.
  711. split_container->set_split_offset(1000);
  712. MessageQueue::get_singleton()->flush();
  713. CHECK(split_container->get_split_offset() == 1000);
  714. check_position(split_container, split_container->get_size().x - separator_size.x, separator_size.x);
  715. // Clamped negative.
  716. split_container->set_split_offset(-1000);
  717. MessageQueue::get_singleton()->flush();
  718. CHECK(split_container->get_split_offset() == -1000);
  719. check_position(split_container, 0, separator_size.x);
  720. }
  721. SUBCASE("[SplitContainer] Unequal stretch ratios") {
  722. int def_pos = (split_container->get_size().x * 2 / 3) - separator_size.x / 2;
  723. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  724. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  725. child_a->set_stretch_ratio(2.0);
  726. MessageQueue::get_singleton()->flush();
  727. // Positive.
  728. split_container->set_split_offset(10);
  729. MessageQueue::get_singleton()->flush();
  730. CHECK(split_container->get_split_offset() == 10);
  731. check_position(split_container, def_pos + 10, separator_size.x);
  732. // Negative.
  733. split_container->set_split_offset(-10);
  734. MessageQueue::get_singleton()->flush();
  735. CHECK(split_container->get_split_offset() == -10);
  736. check_position(split_container, def_pos - 10, separator_size.x);
  737. // Clamped positive.
  738. split_container->set_split_offset(1000);
  739. MessageQueue::get_singleton()->flush();
  740. CHECK(split_container->get_split_offset() == 1000);
  741. check_position(split_container, split_container->get_size().x - separator_size.x, separator_size.x);
  742. // Clamped negative.
  743. split_container->set_split_offset(-1000);
  744. MessageQueue::get_singleton()->flush();
  745. CHECK(split_container->get_split_offset() == -1000);
  746. check_position(split_container, 0, separator_size.x);
  747. }
  748. }
  749. SUBCASE("[SplitContainer] Keep split offset when changing minimum size") {
  750. SUBCASE("[SplitContainer] No expand flags") {
  751. int def_pos = 0;
  752. split_container->set_split_offset(100);
  753. child_a->set_custom_minimum_size(Size2(10, 0));
  754. MessageQueue::get_singleton()->flush();
  755. CHECK(split_container->get_split_offset() == 100);
  756. check_position(split_container, def_pos + 100, separator_size.x);
  757. child_a->set_custom_minimum_size(Size2(50, 0));
  758. MessageQueue::get_singleton()->flush();
  759. CHECK(split_container->get_split_offset() == 100);
  760. check_position(split_container, def_pos + 100, separator_size.x);
  761. }
  762. SUBCASE("[SplitContainer] First child expanded") {
  763. int def_pos = split_container->get_size().x - separator_size.x;
  764. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  765. MessageQueue::get_singleton()->flush();
  766. split_container->set_split_offset(-100);
  767. child_b->set_custom_minimum_size(Size2(10, 0));
  768. MessageQueue::get_singleton()->flush();
  769. CHECK(split_container->get_split_offset() == -100);
  770. check_position(split_container, def_pos - 100, separator_size.x);
  771. child_b->set_custom_minimum_size(Size2(50, 0));
  772. MessageQueue::get_singleton()->flush();
  773. CHECK(split_container->get_split_offset() == -100);
  774. check_position(split_container, def_pos - 100, separator_size.x);
  775. }
  776. SUBCASE("[SplitContainer] Second child expanded") {
  777. int def_pos = 0;
  778. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  779. MessageQueue::get_singleton()->flush();
  780. split_container->set_split_offset(100);
  781. child_a->set_custom_minimum_size(Size2(10, 0));
  782. MessageQueue::get_singleton()->flush();
  783. CHECK(split_container->get_split_offset() == 100);
  784. check_position(split_container, def_pos + 100, separator_size.x);
  785. child_a->set_custom_minimum_size(Size2(50, 0));
  786. MessageQueue::get_singleton()->flush();
  787. CHECK(split_container->get_split_offset() == 100);
  788. check_position(split_container, def_pos + 100, separator_size.x);
  789. }
  790. SUBCASE("[SplitContainer] Both children expanded") {
  791. int def_pos = (split_container->get_size().x - separator_size.x) / 2;
  792. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  793. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  794. MessageQueue::get_singleton()->flush();
  795. split_container->set_split_offset(20);
  796. child_a->set_custom_minimum_size(Size2(10, 0));
  797. child_b->set_custom_minimum_size(Size2(10, 0));
  798. MessageQueue::get_singleton()->flush();
  799. CHECK(split_container->get_split_offset() == 20);
  800. check_position(split_container, def_pos + 20, separator_size.x);
  801. child_a->set_custom_minimum_size(Size2(50, 0));
  802. child_b->set_custom_minimum_size(Size2(50, 0));
  803. MessageQueue::get_singleton()->flush();
  804. CHECK(split_container->get_split_offset() == 20);
  805. check_position(split_container, def_pos + 20, separator_size.x);
  806. }
  807. }
  808. SUBCASE("[SplitContainer] Resize split container") {
  809. SUBCASE("[SplitContainer] No expand flags") {
  810. int def_pos = 0;
  811. // Increase the size.
  812. split_container->set_size(Size2(600, 500));
  813. MessageQueue::get_singleton()->flush();
  814. check_position(split_container, def_pos, separator_size.x);
  815. // Decrease the size.
  816. split_container->set_size(Size2(400, 500));
  817. MessageQueue::get_singleton()->flush();
  818. check_position(split_container, def_pos, separator_size.x);
  819. // Change size with a split offset.
  820. split_container->set_split_offset(100);
  821. MessageQueue::get_singleton()->flush();
  822. check_position(split_container, def_pos + 100, separator_size.x);
  823. split_container->set_size(Size2(500, 500));
  824. MessageQueue::get_singleton()->flush();
  825. check_position(split_container, def_pos + 100, separator_size.x);
  826. CHECK(split_container->get_split_offset() == 100);
  827. // Change size so that the first child changes size.
  828. split_container->set_size(Size2(80, 500));
  829. MessageQueue::get_singleton()->flush();
  830. check_position(split_container, 80 - separator_size.x, separator_size.x);
  831. CHECK(split_container->get_split_offset() == 100);
  832. // Increase size again.
  833. split_container->set_size(Size2(500, 500));
  834. MessageQueue::get_singleton()->flush();
  835. check_position(split_container, def_pos + 100, separator_size.x);
  836. CHECK(split_container->get_split_offset() == 100);
  837. }
  838. SUBCASE("[SplitContainer] First child expanded") {
  839. int def_pos = split_container->get_size().x - separator_size.x;
  840. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  841. MessageQueue::get_singleton()->flush();
  842. // Increase the size.
  843. split_container->set_size(Size2(600, 500));
  844. def_pos = split_container->get_size().x - separator_size.x;
  845. MessageQueue::get_singleton()->flush();
  846. check_position(split_container, def_pos, separator_size.x);
  847. // Decrease the size.
  848. split_container->set_size(Size2(400, 500));
  849. def_pos = split_container->get_size().x - separator_size.x;
  850. MessageQueue::get_singleton()->flush();
  851. check_position(split_container, def_pos, separator_size.x);
  852. // Change size with a split offset.
  853. split_container->set_split_offset(-100);
  854. MessageQueue::get_singleton()->flush();
  855. check_position(split_container, def_pos - 100, separator_size.x);
  856. split_container->set_size(Size2(500, 500));
  857. def_pos = split_container->get_size().x - separator_size.x;
  858. MessageQueue::get_singleton()->flush();
  859. check_position(split_container, def_pos - 100, separator_size.x);
  860. CHECK(split_container->get_split_offset() == -100);
  861. // Change size so that the second child changes size.
  862. split_container->set_size(Size2(80, 500));
  863. MessageQueue::get_singleton()->flush();
  864. check_position(split_container, 0, separator_size.x);
  865. CHECK(split_container->get_split_offset() == -100);
  866. // Increase size again.
  867. split_container->set_size(Size2(500, 500));
  868. MessageQueue::get_singleton()->flush();
  869. check_position(split_container, def_pos - 100, separator_size.x);
  870. CHECK(split_container->get_split_offset() == -100);
  871. }
  872. SUBCASE("[SplitContainer] Second child expanded") {
  873. int def_pos = 0;
  874. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  875. MessageQueue::get_singleton()->flush();
  876. // Increase the size.
  877. split_container->set_size(Size2(600, 500));
  878. MessageQueue::get_singleton()->flush();
  879. check_position(split_container, def_pos, separator_size.x);
  880. // Decrease the size.
  881. split_container->set_size(Size2(400, 500));
  882. MessageQueue::get_singleton()->flush();
  883. check_position(split_container, def_pos, separator_size.x);
  884. // Change size with a split offset.
  885. split_container->set_split_offset(100);
  886. MessageQueue::get_singleton()->flush();
  887. check_position(split_container, def_pos + 100, separator_size.x);
  888. split_container->set_size(Size2(500, 500));
  889. MessageQueue::get_singleton()->flush();
  890. check_position(split_container, def_pos + 100, separator_size.x);
  891. CHECK(split_container->get_split_offset() == 100);
  892. // Change size so that the first child changes size.
  893. split_container->set_size(Size2(80, 500));
  894. MessageQueue::get_singleton()->flush();
  895. check_position(split_container, 80 - separator_size.x, separator_size.x);
  896. CHECK(split_container->get_split_offset() == 100);
  897. // Increase size again.
  898. split_container->set_size(Size2(500, 500));
  899. MessageQueue::get_singleton()->flush();
  900. check_position(split_container, def_pos + 100, separator_size.x);
  901. CHECK(split_container->get_split_offset() == 100);
  902. }
  903. SUBCASE("[SplitContainer] Both children expanded") {
  904. int def_pos = (split_container->get_size().x - separator_size.x) / 2;
  905. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  906. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  907. MessageQueue::get_singleton()->flush();
  908. // Increase the size.
  909. split_container->set_size(Size2(600, 500));
  910. def_pos = (split_container->get_size().x - separator_size.x) / 2;
  911. MessageQueue::get_singleton()->flush();
  912. check_position(split_container, def_pos, separator_size.x);
  913. // Decrease the size.
  914. split_container->set_size(Size2(400, 500));
  915. def_pos = (split_container->get_size().x - separator_size.x) / 2;
  916. MessageQueue::get_singleton()->flush();
  917. check_position(split_container, def_pos, separator_size.x);
  918. // Change size with a split offset.
  919. split_container->set_split_offset(100);
  920. MessageQueue::get_singleton()->flush();
  921. check_position(split_container, def_pos + 100, separator_size.x);
  922. split_container->set_size(Size2(500, 500));
  923. def_pos = (split_container->get_size().x - separator_size.x) / 2;
  924. MessageQueue::get_singleton()->flush();
  925. check_position(split_container, def_pos + 100, separator_size.x);
  926. CHECK(split_container->get_split_offset() == 100);
  927. // Change size so that the second child is minimized.
  928. split_container->set_size(Size2(80, 500));
  929. MessageQueue::get_singleton()->flush();
  930. check_position(split_container, 80 - separator_size.x, separator_size.x);
  931. CHECK(split_container->get_split_offset() == 100);
  932. // Increase size again.
  933. split_container->set_size(Size2(500, 500));
  934. def_pos = (split_container->get_size().x - separator_size.x) / 2;
  935. MessageQueue::get_singleton()->flush();
  936. check_position(split_container, def_pos + 100, separator_size.x);
  937. CHECK(split_container->get_split_offset() == 100);
  938. }
  939. SUBCASE("[SplitContainer] Unequal stretch ratios") {
  940. int def_pos = (split_container->get_size().x * 2 / 3) - separator_size.x / 2;
  941. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  942. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  943. child_a->set_stretch_ratio(2.0);
  944. MessageQueue::get_singleton()->flush();
  945. // Increase the size.
  946. split_container->set_size(Size2(600, 500));
  947. def_pos = (split_container->get_size().x * 2 / 3) - separator_size.x / 2;
  948. MessageQueue::get_singleton()->flush();
  949. check_position(split_container, def_pos, separator_size.x);
  950. // Decrease the size.
  951. split_container->set_size(Size2(400, 500));
  952. def_pos = (split_container->get_size().x * 2 / 3) - separator_size.x / 2;
  953. MessageQueue::get_singleton()->flush();
  954. check_position(split_container, def_pos, separator_size.x);
  955. // Change size with a split offset.
  956. split_container->set_split_offset(100);
  957. MessageQueue::get_singleton()->flush();
  958. check_position(split_container, def_pos + 100, separator_size.x);
  959. split_container->set_size(Size2(500, 500));
  960. def_pos = (split_container->get_size().x * 2 / 3) - separator_size.x / 2;
  961. MessageQueue::get_singleton()->flush();
  962. check_position(split_container, def_pos + 100, separator_size.x);
  963. CHECK(split_container->get_split_offset() == 100);
  964. // Change size so that the second child is minimized.
  965. split_container->set_size(Size2(80, 500));
  966. MessageQueue::get_singleton()->flush();
  967. check_position(split_container, 80 - separator_size.x, separator_size.x);
  968. CHECK(split_container->get_split_offset() == 100);
  969. // Increase size again.
  970. split_container->set_size(Size2(500, 500));
  971. def_pos = (split_container->get_size().x * 2 / 3) - separator_size.x / 2;
  972. MessageQueue::get_singleton()->flush();
  973. check_position(split_container, def_pos + 100, separator_size.x);
  974. CHECK(split_container->get_split_offset() == 100);
  975. }
  976. }
  977. SUBCASE("[SplitContainer] Drag") {
  978. SUBCASE("[SplitContainer] Vertical, no expand flags") {
  979. SIGNAL_WATCH(split_container, "dragged");
  980. Array signal_args = { { 0 } };
  981. split_container->set_vertical(true);
  982. Point2 mouse_offset = Point2(1, 1);
  983. int dragger_pos = 0;
  984. int split_dragger_ofs = 0;
  985. // Grab the dragger.
  986. SEND_GUI_MOUSE_BUTTON_EVENT(mouse_offset + Point2(0, dragger_pos), MouseButton::LEFT, MouseButtonMask::LEFT, Key::NONE);
  987. MessageQueue::get_singleton()->flush();
  988. check_position(split_container, dragger_pos, separator_size.y, false);
  989. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  990. SIGNAL_CHECK_FALSE("dragged");
  991. // Move the dragger.
  992. dragger_pos = 10;
  993. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(0, dragger_pos), MouseButtonMask::LEFT, Key::NONE);
  994. MessageQueue::get_singleton()->flush();
  995. check_position(split_container, dragger_pos, separator_size.y, false);
  996. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  997. // It is clamped.
  998. split_container->clamp_split_offset();
  999. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1000. ((Array)signal_args[0])[0] = split_container->get_split_offset();
  1001. SIGNAL_CHECK("dragged", signal_args);
  1002. // Move down.
  1003. dragger_pos = 400;
  1004. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(0, dragger_pos), MouseButtonMask::LEFT, Key::NONE);
  1005. MessageQueue::get_singleton()->flush();
  1006. check_position(split_container, dragger_pos, separator_size.y, false);
  1007. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1008. ((Array)signal_args[0])[0] = split_container->get_split_offset();
  1009. SIGNAL_CHECK("dragged", signal_args);
  1010. // Moves even when mouse is outside.
  1011. dragger_pos = split_container->get_size().y - separator_size.y;
  1012. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(0, 1000), MouseButtonMask::LEFT, Key::NONE);
  1013. MessageQueue::get_singleton()->flush();
  1014. check_position(split_container, dragger_pos, separator_size.y, false);
  1015. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1016. ((Array)signal_args[0])[0] = split_container->get_split_offset();
  1017. SIGNAL_CHECK("dragged", signal_args);
  1018. // Move up.
  1019. dragger_pos = 100;
  1020. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(0, dragger_pos), MouseButtonMask::LEFT, Key::NONE);
  1021. MessageQueue::get_singleton()->flush();
  1022. check_position(split_container, dragger_pos, separator_size.y, false);
  1023. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1024. ((Array)signal_args[0])[0] = split_container->get_split_offset();
  1025. SIGNAL_CHECK("dragged", signal_args);
  1026. // Release.
  1027. SEND_GUI_MOUSE_BUTTON_RELEASED_EVENT(mouse_offset + Point2(0, dragger_pos), MouseButton::LEFT, MouseButtonMask::NONE, Key::NONE);
  1028. MessageQueue::get_singleton()->flush();
  1029. check_position(split_container, dragger_pos, separator_size.y, false);
  1030. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1031. SIGNAL_CHECK_FALSE("dragged");
  1032. // No longer moves with the mouse.
  1033. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(0, 200), MouseButtonMask::NONE, Key::NONE);
  1034. MessageQueue::get_singleton()->flush();
  1035. check_position(split_container, dragger_pos, separator_size.y, false);
  1036. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1037. SIGNAL_CHECK_FALSE("dragged");
  1038. SIGNAL_UNWATCH(split_container, "dragged");
  1039. }
  1040. SUBCASE("[SplitContainer] No expand flags") {
  1041. Point2 mouse_offset = Point2(1, 1);
  1042. int dragger_pos = 0;
  1043. int split_dragger_ofs = 0;
  1044. // Grab the dragger.
  1045. SEND_GUI_MOUSE_BUTTON_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButton::LEFT, MouseButtonMask::LEFT, Key::NONE);
  1046. MessageQueue::get_singleton()->flush();
  1047. check_position(split_container, dragger_pos, separator_size.x);
  1048. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1049. // Move the dragger.
  1050. dragger_pos = 10;
  1051. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1052. MessageQueue::get_singleton()->flush();
  1053. check_position(split_container, dragger_pos, separator_size.x);
  1054. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1055. // It is clamped.
  1056. split_container->clamp_split_offset();
  1057. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1058. // Continue moving.
  1059. dragger_pos = 400;
  1060. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1061. MessageQueue::get_singleton()->flush();
  1062. check_position(split_container, dragger_pos, separator_size.x);
  1063. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1064. // Moves even when mouse is outside.
  1065. dragger_pos = split_container->get_size().x - separator_size.x;
  1066. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(1000, 0), MouseButtonMask::LEFT, Key::NONE);
  1067. MessageQueue::get_singleton()->flush();
  1068. check_position(split_container, dragger_pos, separator_size.x);
  1069. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1070. // Move back in.
  1071. dragger_pos = 100;
  1072. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1073. MessageQueue::get_singleton()->flush();
  1074. check_position(split_container, dragger_pos, separator_size.x);
  1075. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1076. // Release.
  1077. SEND_GUI_MOUSE_BUTTON_RELEASED_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButton::LEFT, MouseButtonMask::NONE, Key::NONE);
  1078. MessageQueue::get_singleton()->flush();
  1079. check_position(split_container, dragger_pos, separator_size.x);
  1080. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1081. // No longer moves with the mouse.
  1082. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(200, 0), MouseButtonMask::NONE, Key::NONE);
  1083. MessageQueue::get_singleton()->flush();
  1084. check_position(split_container, dragger_pos, separator_size.x);
  1085. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1086. }
  1087. SUBCASE("[SplitContainer] First child expanded") {
  1088. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  1089. MessageQueue::get_singleton()->flush();
  1090. Point2 mouse_offset = Point2(1, 1);
  1091. int dragger_pos = split_container->get_size().x - separator_size.x;
  1092. int split_dragger_ofs = -dragger_pos;
  1093. // Grab the dragger.
  1094. SEND_GUI_MOUSE_BUTTON_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButton::LEFT, MouseButtonMask::LEFT, Key::NONE);
  1095. MessageQueue::get_singleton()->flush();
  1096. check_position(split_container, dragger_pos, separator_size.x);
  1097. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1098. // Move the dragger.
  1099. dragger_pos -= 10;
  1100. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1101. MessageQueue::get_singleton()->flush();
  1102. check_position(split_container, dragger_pos, separator_size.x);
  1103. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1104. // It is clamped.
  1105. split_container->clamp_split_offset();
  1106. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1107. // Continue moving.
  1108. dragger_pos = 400;
  1109. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1110. MessageQueue::get_singleton()->flush();
  1111. check_position(split_container, dragger_pos, separator_size.x);
  1112. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1113. // Moves even when mouse is outside.
  1114. dragger_pos = split_container->get_size().x - separator_size.x;
  1115. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(1000, 0), MouseButtonMask::LEFT, Key::NONE);
  1116. MessageQueue::get_singleton()->flush();
  1117. check_position(split_container, dragger_pos, separator_size.x);
  1118. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1119. // Move back in.
  1120. dragger_pos = 100;
  1121. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1122. MessageQueue::get_singleton()->flush();
  1123. check_position(split_container, dragger_pos, separator_size.x);
  1124. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1125. // Release.
  1126. SEND_GUI_MOUSE_BUTTON_RELEASED_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButton::LEFT, MouseButtonMask::NONE, Key::NONE);
  1127. MessageQueue::get_singleton()->flush();
  1128. check_position(split_container, dragger_pos, separator_size.x);
  1129. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1130. // No longer moves with the mouse.
  1131. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(200, 0), MouseButtonMask::NONE, Key::NONE);
  1132. MessageQueue::get_singleton()->flush();
  1133. check_position(split_container, dragger_pos, separator_size.x);
  1134. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1135. }
  1136. SUBCASE("[SplitContainer] Second child expanded") {
  1137. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  1138. MessageQueue::get_singleton()->flush();
  1139. Point2 mouse_offset = Point2(1, 1);
  1140. int dragger_pos = 0;
  1141. int split_dragger_ofs = 0;
  1142. // Grab the dragger.
  1143. SEND_GUI_MOUSE_BUTTON_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButton::LEFT, MouseButtonMask::LEFT, Key::NONE);
  1144. MessageQueue::get_singleton()->flush();
  1145. check_position(split_container, dragger_pos, separator_size.x);
  1146. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1147. // Move the dragger.
  1148. dragger_pos = 10;
  1149. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1150. MessageQueue::get_singleton()->flush();
  1151. check_position(split_container, dragger_pos, separator_size.x);
  1152. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1153. // It is clamped.
  1154. split_container->clamp_split_offset();
  1155. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1156. // Continue moving.
  1157. dragger_pos = 400;
  1158. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1159. MessageQueue::get_singleton()->flush();
  1160. check_position(split_container, dragger_pos, separator_size.x);
  1161. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1162. // Moves even when mouse is outside.
  1163. dragger_pos = split_container->get_size().x - separator_size.x;
  1164. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(1000, 0), MouseButtonMask::LEFT, Key::NONE);
  1165. MessageQueue::get_singleton()->flush();
  1166. check_position(split_container, dragger_pos, separator_size.x);
  1167. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1168. // Move back in.
  1169. dragger_pos = 100;
  1170. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1171. MessageQueue::get_singleton()->flush();
  1172. check_position(split_container, dragger_pos, separator_size.x);
  1173. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1174. // Release.
  1175. SEND_GUI_MOUSE_BUTTON_RELEASED_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButton::LEFT, MouseButtonMask::NONE, Key::NONE);
  1176. MessageQueue::get_singleton()->flush();
  1177. check_position(split_container, dragger_pos, separator_size.x);
  1178. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1179. // No longer moves with the mouse.
  1180. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(200, 0), MouseButtonMask::NONE, Key::NONE);
  1181. MessageQueue::get_singleton()->flush();
  1182. check_position(split_container, dragger_pos, separator_size.x);
  1183. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1184. }
  1185. SUBCASE("[SplitContainer] Both children expanded") {
  1186. child_a->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  1187. child_b->set_h_size_flags(Control::SIZE_EXPAND_FILL);
  1188. MessageQueue::get_singleton()->flush();
  1189. Point2 mouse_offset = Point2(1, 1);
  1190. int dragger_pos = (split_container->get_size().x - separator_size.x) / 2;
  1191. int split_dragger_ofs = -dragger_pos;
  1192. // Grab the dragger.
  1193. SEND_GUI_MOUSE_BUTTON_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButton::LEFT, MouseButtonMask::LEFT, Key::NONE);
  1194. MessageQueue::get_singleton()->flush();
  1195. check_position(split_container, dragger_pos, separator_size.x);
  1196. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1197. // Move the dragger.
  1198. dragger_pos += 10;
  1199. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1200. MessageQueue::get_singleton()->flush();
  1201. check_position(split_container, dragger_pos, separator_size.x);
  1202. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1203. // It is clamped.
  1204. split_container->clamp_split_offset();
  1205. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1206. // Continue moving.
  1207. dragger_pos = 400;
  1208. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1209. MessageQueue::get_singleton()->flush();
  1210. check_position(split_container, dragger_pos, separator_size.x);
  1211. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1212. // Moves even when mouse is outside.
  1213. dragger_pos = split_container->get_size().x - separator_size.x;
  1214. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(1000, 0), MouseButtonMask::LEFT, Key::NONE);
  1215. MessageQueue::get_singleton()->flush();
  1216. check_position(split_container, dragger_pos, separator_size.x);
  1217. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1218. // Move back in.
  1219. dragger_pos = 100;
  1220. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButtonMask::LEFT, Key::NONE);
  1221. MessageQueue::get_singleton()->flush();
  1222. check_position(split_container, dragger_pos, separator_size.x);
  1223. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1224. // Release.
  1225. SEND_GUI_MOUSE_BUTTON_RELEASED_EVENT(mouse_offset + Point2(dragger_pos, 0), MouseButton::LEFT, MouseButtonMask::NONE, Key::NONE);
  1226. MessageQueue::get_singleton()->flush();
  1227. check_position(split_container, dragger_pos, separator_size.x);
  1228. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1229. // No longer moves with the mouse.
  1230. SEND_GUI_MOUSE_MOTION_EVENT(mouse_offset + Point2(200, 0), MouseButtonMask::NONE, Key::NONE);
  1231. MessageQueue::get_singleton()->flush();
  1232. check_position(split_container, dragger_pos, separator_size.x);
  1233. CHECK(split_container->get_split_offset() == dragger_pos + split_dragger_ofs);
  1234. }
  1235. }
  1236. memdelete(child_b);
  1237. memdelete(child_a);
  1238. memdelete(split_container);
  1239. }
  1240. } // namespace TestSplitContainer