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