MootoolsEngineHelperTest.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. <?php
  2. /**
  3. * MooEngineTestCase
  4. *
  5. * PHP 5
  6. *
  7. * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
  8. * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
  9. *
  10. * Licensed under The MIT License
  11. * For full copyright and license information, please see the LICENSE.txt
  12. * Redistributions of files must retain the above copyright notice.
  13. *
  14. * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
  15. * @link http://cakephp.org CakePHP Project
  16. * @package Cake.Test.Case.View.Helper
  17. * @license http://www.opensource.org/licenses/mit-license.php MIT License
  18. */
  19. App::uses('View', 'View');
  20. App::uses('HtmlHelper', 'View/Helper');
  21. App::uses('JsHelper', 'View/Helper');
  22. App::uses('MootoolsEngineHelper', 'View/Helper');
  23. /**
  24. * Class MootoolsEngineHelperTest
  25. *
  26. * @package Cake.Test.Case.View.Helper
  27. */
  28. class MootoolsEngineHelperTest extends CakeTestCase {
  29. /**
  30. * setUp
  31. *
  32. * @return void
  33. */
  34. public function setUp() {
  35. parent::setUp();
  36. $controller = null;
  37. $this->View = $this->getMock('View', array('addScript'), array(&$controller));
  38. $this->Moo = new MootoolsEngineHelper($this->View);
  39. }
  40. /**
  41. * tearDown
  42. *
  43. * @return void
  44. */
  45. public function tearDown() {
  46. parent::tearDown();
  47. unset($this->Moo);
  48. }
  49. /**
  50. * test selector method
  51. *
  52. * @return void
  53. */
  54. public function testSelector() {
  55. $result = $this->Moo->get('#content');
  56. $this->assertEquals($this->Moo, $result);
  57. $this->assertEquals($this->Moo->selection, '$("content")');
  58. $result = $this->Moo->get('a .remove');
  59. $this->assertEquals($this->Moo, $result);
  60. $this->assertEquals($this->Moo->selection, '$$("a .remove")');
  61. $result = $this->Moo->get('document');
  62. $this->assertEquals($this->Moo, $result);
  63. $this->assertEquals($this->Moo->selection, "$(document)");
  64. $result = $this->Moo->get('window');
  65. $this->assertEquals($this->Moo, $result);
  66. $this->assertEquals($this->Moo->selection, "$(window)");
  67. $result = $this->Moo->get('ul');
  68. $this->assertEquals($this->Moo, $result);
  69. $this->assertEquals($this->Moo->selection, '$$("ul")');
  70. $result = $this->Moo->get('#some_long-id.class');
  71. $this->assertEquals($this->Moo, $result);
  72. $this->assertEquals($this->Moo->selection, '$$("#some_long-id.class")');
  73. }
  74. /**
  75. * test event binding
  76. *
  77. * @return void
  78. */
  79. public function testEvent() {
  80. $this->Moo->get('#myLink');
  81. $result = $this->Moo->event('click', 'doClick', array('wrap' => false));
  82. $expected = '$("myLink").addEvent("click", doClick);';
  83. $this->assertEquals($expected, $result);
  84. $result = $this->Moo->event('click', 'this.setStyle("display", "");', array('stop' => false));
  85. $expected = '$("myLink").addEvent("click", function (event) {this.setStyle("display", "");});';
  86. $this->assertEquals($expected, $result);
  87. $result = $this->Moo->event('click', 'this.setStyle("display", "none");');
  88. $expected = "\$(\"myLink\").addEvent(\"click\", function (event) {event.stop();\nthis.setStyle(\"display\", \"none\");});";
  89. $this->assertEquals($expected, $result);
  90. }
  91. /**
  92. * test dom ready event creation
  93. *
  94. * @return void
  95. */
  96. public function testDomReady() {
  97. $result = $this->Moo->domReady('foo.name = "bar";');
  98. $expected = 'window.addEvent("domready", function (event) {foo.name = "bar";});';
  99. $this->assertEquals($expected, $result);
  100. }
  101. /**
  102. * test Each method
  103. *
  104. * @return void
  105. */
  106. public function testEach() {
  107. $this->Moo->get('#foo');
  108. $result = $this->Moo->each('item.setStyle("display", "none");');
  109. $expected = '$("foo").each(function (item, index) {item.setStyle("display", "none");});';
  110. $this->assertEquals($expected, $result);
  111. }
  112. /**
  113. * test Effect generation
  114. *
  115. * @return void
  116. */
  117. public function testEffect() {
  118. $this->Moo->get('#foo');
  119. $result = $this->Moo->effect('show');
  120. $expected = '$("foo").setStyle("display", "");';
  121. $this->assertEquals($expected, $result);
  122. $result = $this->Moo->effect('hide');
  123. $expected = '$("foo").setStyle("display", "none");';
  124. $this->assertEquals($expected, $result);
  125. $result = $this->Moo->effect('fadeIn');
  126. $expected = '$("foo").fade("in");';
  127. $this->assertEquals($expected, $result);
  128. $result = $this->Moo->effect('fadeOut');
  129. $expected = '$("foo").fade("out");';
  130. $this->assertEquals($expected, $result);
  131. $result = $this->Moo->effect('slideIn');
  132. $expected = '$("foo").slide("in");';
  133. $this->assertEquals($expected, $result);
  134. $result = $this->Moo->effect('slideOut');
  135. $expected = '$("foo").slide("out");';
  136. $this->assertEquals($expected, $result);
  137. $result = $this->Moo->effect('slideOut', array('speed' => 'fast'));
  138. $expected = '$("foo").set("slide", {duration:"short"}).slide("out");';
  139. $this->assertEquals($expected, $result);
  140. $result = $this->Moo->effect('slideOut', array('speed' => 'slow'));
  141. $expected = '$("foo").set("slide", {duration:"long"}).slide("out");';
  142. $this->assertEquals($expected, $result);
  143. }
  144. /**
  145. * Test Request Generation
  146. *
  147. * @return void
  148. */
  149. public function testRequest() {
  150. $result = $this->Moo->request(array('controller' => 'posts', 'action' => 'view', 1));
  151. $expected = 'var jsRequest = new Request({url:"\\/posts\\/view\\/1"}).send();';
  152. $this->assertEquals($expected, $result);
  153. $result = $this->Moo->request('/posts/view/1', array('update' => 'content'));
  154. $expected = 'var jsRequest = new Request.HTML({update:"content", url:"\\/posts\\/view\\/1"}).send();';
  155. $this->assertEquals($expected, $result);
  156. $result = $this->Moo->request('/people/edit/1', array(
  157. 'method' => 'post',
  158. 'complete' => 'doSuccess',
  159. 'error' => 'handleError',
  160. 'type' => 'json',
  161. 'data' => array('name' => 'jim', 'height' => '185cm'),
  162. 'wrapCallbacks' => false
  163. ));
  164. $expected = 'var jsRequest = new Request.JSON({method:"post", onComplete:doSuccess, onFailure:handleError, url:"\\/people\\/edit\\/1"}).send({"name":"jim","height":"185cm"});';
  165. $this->assertEquals($expected, $result);
  166. $result = $this->Moo->request('/people/edit/1', array(
  167. 'method' => 'post',
  168. 'complete' => 'doSuccess',
  169. 'update' => '#update-zone',
  170. 'wrapCallbacks' => false
  171. ));
  172. $expected = 'var jsRequest = new Request.HTML({method:"post", onComplete:doSuccess, update:"update-zone", url:"\\/people\\/edit\\/1"}).send();';
  173. $this->assertEquals($expected, $result);
  174. $result = $this->Moo->request('/people/edit/1', array(
  175. 'method' => 'post',
  176. 'complete' => 'doComplete',
  177. 'success' => 'doSuccess',
  178. 'error' => 'doFailure',
  179. 'before' => 'doBefore',
  180. 'update' => 'update-zone',
  181. 'wrapCallbacks' => false
  182. ));
  183. $expected = 'var jsRequest = new Request.HTML({method:"post", onComplete:doComplete, onFailure:doFailure, onRequest:doBefore, onSuccess:doSuccess, update:"update-zone", url:"\\/people\\/edit\\/1"}).send();';
  184. $this->assertEquals($expected, $result);
  185. $result = $this->Moo->request('/people/edit/1', array(
  186. 'method' => 'post',
  187. 'complete' => 'doComplete',
  188. 'success' => 'doSuccess',
  189. 'error' => 'doFailure',
  190. 'before' => 'doBefore',
  191. 'update' => 'update-zone',
  192. 'dataExpression' => true,
  193. 'data' => '$("foo").toQueryString()',
  194. 'wrapCallbacks' => false
  195. ));
  196. $expected = 'var jsRequest = new Request.HTML({method:"post", onComplete:doComplete, onFailure:doFailure, onRequest:doBefore, onSuccess:doSuccess, update:"update-zone", url:"\\/people\\/edit\\/1"}).send($("foo").toQueryString());';
  197. $this->assertEquals($expected, $result);
  198. $result = $this->Moo->request('/people/edit/1', array(
  199. 'method' => 'post',
  200. 'before' => 'doBefore',
  201. 'success' => 'doSuccess',
  202. 'complete' => 'doComplete',
  203. 'update' => '#update-zone',
  204. ));
  205. $expected = 'var jsRequest = new Request.HTML({method:"post", onComplete:function () {doComplete}, onRequest:function () {doBefore}, onSuccess:function (responseText, responseXML) {doSuccess}, update:"update-zone", url:"\\/people\\/edit\\/1"}).send();';
  206. $this->assertEquals($expected, $result);
  207. }
  208. /**
  209. * test sortable list generation
  210. *
  211. * @return void
  212. */
  213. public function testSortable() {
  214. $this->Moo->get('#myList');
  215. $result = $this->Moo->sortable(array(
  216. 'distance' => 5,
  217. 'containment' => 'parent',
  218. 'start' => 'onStart',
  219. 'complete' => 'onStop',
  220. 'sort' => 'onSort',
  221. 'wrapCallbacks' => false
  222. ));
  223. $expected = 'var jsSortable = new Sortables($("myList"), {constrain:"parent", onComplete:onStop, onSort:onSort, onStart:onStart, snap:5});';
  224. $this->assertEquals($expected, $result);
  225. }
  226. /**
  227. * test drag() method
  228. *
  229. * @return void
  230. */
  231. public function testDrag() {
  232. $this->Moo->get('#drag-me');
  233. $result = $this->Moo->drag(array(
  234. 'start' => 'onStart',
  235. 'drag' => 'onDrag',
  236. 'stop' => 'onStop',
  237. 'snapGrid' => array(10, 10),
  238. 'wrapCallbacks' => false
  239. ));
  240. $expected = '$("drag-me").makeDraggable({onComplete:onStop, onDrag:onDrag, onStart:onStart, snap:[10,10]});';
  241. $this->assertEquals($expected, $result);
  242. }
  243. /**
  244. * test drop() method with the required drag option missing
  245. *
  246. * @expectedException PHPUnit_Framework_Error_Warning
  247. * @return void
  248. */
  249. public function testDropWithMissingOption() {
  250. $this->Moo->get('#drop-me');
  251. $this->Moo->drop(array(
  252. 'drop' => 'onDrop',
  253. 'leave' => 'onLeave',
  254. 'hover' => 'onHover',
  255. ));
  256. }
  257. /**
  258. * test drop() method
  259. *
  260. * @return void
  261. */
  262. public function testDrop() {
  263. $this->Moo->get('#drop-me');
  264. $result = $this->Moo->drop(array(
  265. 'drop' => 'onDrop',
  266. 'leave' => 'onLeave',
  267. 'hover' => 'onHover',
  268. 'drag' => '#my-drag',
  269. 'wrapCallbacks' => false
  270. ));
  271. $expected = '$("my-drag").makeDraggable({droppables:$("drop-me"), onDrop:onDrop, onEnter:onHover, onLeave:onLeave});';
  272. $this->assertEquals($expected, $result);
  273. $this->assertEquals($this->Moo->selection, '$("drop-me")');
  274. $result = $this->Moo->drop(array(
  275. 'drop' => 'onDrop',
  276. 'leave' => 'onLeave',
  277. 'hover' => 'onHover',
  278. 'drag' => '#my-drag',
  279. ));
  280. $expected = '$("my-drag").makeDraggable({droppables:$("drop-me"), onDrop:function (element, droppable, event) {onDrop}, onEnter:function (element, droppable) {onHover}, onLeave:function (element, droppable) {onLeave}});';
  281. $this->assertEquals($expected, $result);
  282. }
  283. /**
  284. * test slider generation
  285. *
  286. * @return void
  287. */
  288. public function testSlider() {
  289. $this->Moo->get('#slider');
  290. $result = $this->Moo->slider(array(
  291. 'handle' => '#my-handle',
  292. 'complete' => 'onComplete',
  293. 'change' => 'onChange',
  294. 'direction' => 'horizontal',
  295. 'wrapCallbacks' => false
  296. ));
  297. $expected = 'var jsSlider = new Slider($("slider"), $("my-handle"), {mode:"horizontal", onChange:onChange, onComplete:onComplete});';
  298. $this->assertEquals($expected, $result);
  299. $this->assertEquals($this->Moo->selection, '$("slider")');
  300. $this->Moo->get('#slider');
  301. $result = $this->Moo->slider(array(
  302. 'handle' => '#my-handle',
  303. 'complete' => 'onComplete',
  304. 'change' => 'onChange',
  305. 'direction' => 'horizontal',
  306. 'min' => 10,
  307. 'max' => 40,
  308. 'wrapCallbacks' => false
  309. ));
  310. $expected = 'var jsSlider = new Slider($("slider"), $("my-handle"), {mode:"horizontal", onChange:onChange, onComplete:onComplete, range:[10,40]});';
  311. $this->assertEquals($expected, $result);
  312. $this->Moo->get('#slider');
  313. $result = $this->Moo->slider(array(
  314. 'handle' => '#my-handle',
  315. 'complete' => 'complete;',
  316. 'change' => 'change;',
  317. 'direction' => 'horizontal',
  318. ));
  319. $expected = 'var jsSlider = new Slider($("slider"), $("my-handle"), {mode:"horizontal", onChange:function (step) {change;}, onComplete:function (event) {complete;}});';
  320. $this->assertEquals($expected, $result);
  321. }
  322. /**
  323. * test the serializeForm implementation.
  324. *
  325. * @return void
  326. */
  327. public function testSerializeForm() {
  328. $this->Moo->get('#element');
  329. $result = $this->Moo->serializeForm(array('isForm' => true));
  330. $expected = '$("element").toQueryString();';
  331. $this->assertEquals($expected, $result);
  332. $result = $this->Moo->serializeForm(array('isForm' => true, 'inline' => true));
  333. $expected = '$("element").toQueryString()';
  334. $this->assertEquals($expected, $result);
  335. $result = $this->Moo->serializeForm(array('isForm' => false));
  336. $expected = '$($("element").form).toQueryString();';
  337. $this->assertEquals($expected, $result);
  338. $result = $this->Moo->serializeForm(array('isForm' => false, 'inline' => true));
  339. $expected = '$($("element").form).toQueryString()';
  340. $this->assertEquals($expected, $result);
  341. }
  342. }