[FEATURE] stdWrap replacement: add optionSplit-support
[Packages/TYPO3.CMS.git] / typo3 / sysext / frontend / Tests / Unit / ContentObject / ContentObjectRendererTest.php
1 <?php
2 namespace TYPO3\CMS\Frontend\Tests\Unit\ContentObject;
3
4 /***************************************************************
5 * Copyright notice
6 *
7 * (c) 2009-2013 Oliver Hader <oliver@typo3.org>
8 * All rights reserved
9 *
10 * This script is part of the TYPO3 project. The TYPO3 project is
11 * free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 2 of the License, or
14 * (at your option) any later version.
15 *
16 * The GNU General Public License can be found at
17 * http://www.gnu.org/copyleft/gpl.html.
18 *
19 * This script is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
23 *
24 * This copyright notice MUST APPEAR in all copies of the script!
25 ***************************************************************/
26 /**
27 * Testcase for TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer
28 *
29 * @author Oliver Hader <oliver@typo3.org>
30 * @author Oliver Klee <typo3-coding@oliverklee.de>
31 */
32 class ContentObjectRendererTest extends \TYPO3\CMS\Core\Tests\UnitTestCase {
33
34 /**
35 * @var \PHPUnit_Framework_MockObject_MockObject|\TYPO3\CMS\Core\Tests\AccessibleObjectInterface|\TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer
36 */
37 protected $cObj = NULL;
38
39 /**
40 * @var \PHPUnit_Framework_MockObject_MockObject|\TYPO3\CMS\Frontend\Controller\TypoScriptFrontendController|\TYPO3\CMS\Core\Tests\AccessibleObjectInterface
41 */
42 protected $tsfe = NULL;
43
44 /**
45 * @var \PHPUnit_Framework_MockObject_MockObject|\TYPO3\CMS\Core\TypoScript\TemplateService
46 */
47 protected $template = NULL;
48
49 /**
50 * Set up
51 */
52 public function setUp() {
53 $this->template = $this->getMock('TYPO3\\CMS\\Core\\TypoScript\\TemplateService', array('getFileName', 'linkData'));
54 $this->tsfe = $this->getAccessibleMock('TYPO3\\CMS\\Frontend\\Controller\\TypoScriptFrontendController', array('dummy'), array(), '', FALSE);
55 $this->tsfe->tmpl = $this->template;
56 $this->tsfe->config = array();
57 $this->tsfe->page = array();
58 $sysPageMock = $this->getMock('TYPO3\\CMS\\Frontend\\Page\\PageRepository', array('getRawRecord'));
59 $this->tsfe->sys_page = $sysPageMock;
60 $GLOBALS['TSFE'] = $this->tsfe;
61 $GLOBALS['TSFE']->csConvObj = new \TYPO3\CMS\Core\Charset\CharsetConverter();
62 $GLOBALS['TSFE']->renderCharset = 'utf-8';
63 $GLOBALS['TYPO3_CONF_VARS']['SYS']['TYPO3\\CMS\\Core\\Charset\\CharsetConverter_utils'] = 'mbstring';
64 $this->cObj = $this->getAccessibleMock('\\TYPO3\\CMS\\Frontend\\ContentObject\\ContentObjectRenderer', array('dummy'));
65 $this->cObj->start(array(), 'tt_content');
66 }
67
68 ////////////////////////
69 // Utitility functions
70 ////////////////////////
71 /**
72 * Converts the subject and the expected result into the target charset.
73 *
74 * @param string $charset the target charset
75 * @param string $subject the subject, will be modified
76 * @param string $expected the expected result, will be modified
77 */
78 protected function handleCharset($charset, &$subject, &$expected) {
79 $GLOBALS['TSFE']->renderCharset = $charset;
80 $subject = $GLOBALS['TSFE']->csConvObj->conv($subject, 'iso-8859-1', $charset);
81 $expected = $GLOBALS['TSFE']->csConvObj->conv($expected, 'iso-8859-1', $charset);
82 }
83
84 /////////////////////////////////////////////
85 // Tests concerning the getImgResource hook
86 /////////////////////////////////////////////
87 /**
88 * @test
89 */
90 public function getImgResourceHookGetsCalled() {
91 $this->template->expects($this->atLeastOnce())->method('getFileName')->with('typo3/clear.gif')->will($this->returnValue('typo3/clear.gif'));
92 $className = uniqid('tx_coretest');
93 $getImgResourceHookMock = $this->getMock('TYPO3\\CMS\\Frontend\\ContentObject\\ContentObjectGetImageResourceHookInterface', array('getImgResourcePostProcess'), array(), $className);
94 $getImgResourceHookMock->expects($this->once())->method('getImgResourcePostProcess')->will($this->returnCallback(array($this, 'isGetImgResourceHookCalledCallback')));
95 $getImgResourceHookObjects = array($getImgResourceHookMock);
96 $this->cObj->_setRef('getImgResourceHookObjects', $getImgResourceHookObjects);
97 $this->cObj->IMAGE(array('file' => 'typo3/clear.gif'));
98 }
99
100 /**
101 * Handles the arguments that have been sent to the getImgResource hook.
102 *
103 * @return array
104 * @see getImgResourceHookGetsCalled
105 */
106 public function isGetImgResourceHookCalledCallback() {
107 list($file, $fileArray, $imageResource, $parent) = func_get_args();
108 $this->assertEquals('typo3/clear.gif', $file);
109 $this->assertEquals('typo3/clear.gif', $imageResource['origFile']);
110 $this->assertTrue(is_array($fileArray));
111 $this->assertTrue($parent instanceof \TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer);
112 return $imageResource;
113 }
114
115
116 /*************************
117 * Tests concerning getContentObject
118 ************************/
119 public function getContentObjectValidContentObjectsDataProvider() {
120 return array(
121 array('TEXT', 'Text'),
122 array('CASE', 'Case'),
123 array('CLEARGIF', 'ClearGif'),
124 array('COBJ_ARRAY', 'ContentObjectArray'),
125 array('COA', 'ContentObjectArray'),
126 array('COA_INT', 'ContentObjectArrayInternal'),
127 array('USER', 'User'),
128 array('USER_INT', 'UserInternal'),
129 array('FILE', 'File'),
130 array('FILES', 'Files'),
131 array('IMAGE', 'Image'),
132 array('IMG_RESOURCE', 'ImageResource'),
133 array('IMGTEXT', 'ImageText'),
134 array('CONTENT', 'Content'),
135 array('RECORDS', 'Records'),
136 array('HMENU', 'HierarchicalMenu'),
137 array('CTABLE', 'ContentTable'),
138 array('OTABLE', 'OffsetTable'),
139 array('COLUMNS', 'Columns'),
140 array('HRULER', 'HorizontalRuler'),
141 array('CASEFUNC', 'Case'),
142 array('LOAD_REGISTER', 'LoadRegister'),
143 array('RESTORE_REGISTER', 'RestoreRegister'),
144 array('FORM', 'Form'),
145 array('SEARCHRESULT', 'SearchResult'),
146 array('TEMPLATE', 'Template'),
147 array('FLUIDTEMPLATE', 'FluidTemplate'),
148 array('MULTIMEDIA', 'Multimedia'),
149 array('MEDIA', 'Media'),
150 array('SWFOBJECT', 'ShockwaveFlashObject'),
151 array('FLOWPLAYER', 'FlowPlayer'),
152 array('QTOBJECT', 'QuicktimeObject'),
153 array('SVG', 'ScalableVectorGraphics'),
154 array('EDITPANEL', 'EditPanel'),
155 );
156 }
157
158 /**
159 * @test
160 * @dataProvider getContentObjectValidContentObjectsDataProvider
161 * @param string $name TypoScript name of content object
162 * @param string $className Expected class name
163 */
164 public function getContentObjectUsesExistingInstanceOfRequestedObjectType($name, $className) {
165 $fullClassName = 'TYPO3\\CMS\\Frontend\\ContentObject\\' . $className . 'ContentObject';
166 $contentObjectInstance = $this->getMock($fullClassName, array(), array(), '', FALSE);
167 $this->cObj->_set('contentObjects', array($className => $contentObjectInstance));
168 $this->assertSame($contentObjectInstance, $this->cObj->getContentObject($name));
169 }
170
171 /**
172 * @test
173 * @dataProvider getContentObjectValidContentObjectsDataProvider
174 * @param string $name TypoScript name of content object
175 * @param string $className Expected class name
176 */
177 public function getContentObjectCallsMakeInstanceForNewContentObjectInstance($name, $className) {
178 $fullClassName = 'TYPO3\\CMS\\Frontend\\ContentObject\\' . $className . 'ContentObject';
179 $contentObjectInstance = $this->getMock($fullClassName, array(), array(), '', FALSE);
180 \TYPO3\CMS\Core\Utility\GeneralUtility::addInstance($fullClassName, $contentObjectInstance);
181 $this->assertSame($contentObjectInstance, $this->cObj->getContentObject($name));
182 }
183
184 //////////////////////////
185 // Tests concerning FORM
186 //////////////////////////
187 /**
188 * @test
189 */
190 public function formWithSecureFormMailEnabledDoesNotContainRecipientField() {
191 $GLOBALS['TYPO3_CONF_VARS']['FE']['secureFormmail'] = TRUE;
192 $this->assertNotContains('name="recipient', $this->cObj->FORM(array('recipient' => 'foo@bar.com', 'recipient.' => array()), array()));
193 }
194
195 /**
196 * @test
197 */
198 public function formWithSecureFormMailDisabledDoesNotContainRecipientField() {
199 $GLOBALS['TYPO3_CONF_VARS']['FE']['secureFormmail'] = FALSE;
200 $this->assertContains('name="recipient', $this->cObj->FORM(array('recipient' => 'foo@bar.com', 'recipient.' => array()), array()));
201 }
202
203 /////////////////////////////////////////
204 // Tests concerning getQueryArguments()
205 /////////////////////////////////////////
206 /**
207 * @test
208 */
209 public function getQueryArgumentsExcludesParameters() {
210 $_SERVER['QUERY_STRING'] = 'key1=value1' . '&key2=value2' . '&key3[key31]=value31' . '&key3[key32][key321]=value321' . '&key3[key32][key322]=value322';
211 $getQueryArgumentsConfiguration = array();
212 $getQueryArgumentsConfiguration['exclude'] = array();
213 $getQueryArgumentsConfiguration['exclude'][] = 'key1';
214 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key31]';
215 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key32][key321]';
216 $getQueryArgumentsConfiguration['exclude'] = implode(',', $getQueryArgumentsConfiguration['exclude']);
217 $expectedResult = $this->rawUrlEncodeSquareBracketsInUrl('&key2=value2&key3[key32][key322]=value322');
218 $actualResult = $this->cObj->getQueryArguments($getQueryArgumentsConfiguration);
219 $this->assertEquals($expectedResult, $actualResult);
220 }
221
222 /**
223 * @test
224 */
225 public function getQueryArgumentsExcludesGetParameters() {
226 $_GET = array(
227 'key1' => 'value1',
228 'key2' => 'value2',
229 'key3' => array(
230 'key31' => 'value31',
231 'key32' => array(
232 'key321' => 'value321',
233 'key322' => 'value322'
234 )
235 )
236 );
237 $getQueryArgumentsConfiguration = array();
238 $getQueryArgumentsConfiguration['method'] = 'GET';
239 $getQueryArgumentsConfiguration['exclude'] = array();
240 $getQueryArgumentsConfiguration['exclude'][] = 'key1';
241 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key31]';
242 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key32][key321]';
243 $getQueryArgumentsConfiguration['exclude'] = implode(',', $getQueryArgumentsConfiguration['exclude']);
244 $expectedResult = $this->rawUrlEncodeSquareBracketsInUrl('&key2=value2&key3[key32][key322]=value322');
245 $actualResult = $this->cObj->getQueryArguments($getQueryArgumentsConfiguration);
246 $this->assertEquals($expectedResult, $actualResult);
247 }
248
249 /**
250 * @test
251 */
252 public function getQueryArgumentsOverrulesSingleParameter() {
253 $_SERVER['QUERY_STRING'] = 'key1=value1';
254 $getQueryArgumentsConfiguration = array();
255 $overruleArguments = array(
256 // Should be overriden
257 'key1' => 'value1Overruled',
258 // Shouldn't be set: Parameter doesn't exist in source array and is not forced
259 'key2' => 'value2Overruled'
260 );
261 $expectedResult = '&key1=value1Overruled';
262 $actualResult = $this->cObj->getQueryArguments($getQueryArgumentsConfiguration, $overruleArguments);
263 $this->assertEquals($expectedResult, $actualResult);
264 }
265
266 /**
267 * @test
268 */
269 public function getQueryArgumentsOverrulesMultiDimensionalParameters() {
270 $_POST = array(
271 'key1' => 'value1',
272 'key2' => 'value2',
273 'key3' => array(
274 'key31' => 'value31',
275 'key32' => array(
276 'key321' => 'value321',
277 'key322' => 'value322'
278 )
279 )
280 );
281 $getQueryArgumentsConfiguration = array();
282 $getQueryArgumentsConfiguration['method'] = 'POST';
283 $getQueryArgumentsConfiguration['exclude'] = array();
284 $getQueryArgumentsConfiguration['exclude'][] = 'key1';
285 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key31]';
286 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key32][key321]';
287 $getQueryArgumentsConfiguration['exclude'] = implode(',', $getQueryArgumentsConfiguration['exclude']);
288 $overruleArguments = array(
289 // Should be overriden
290 'key2' => 'value2Overruled',
291 'key3' => array(
292 'key32' => array(
293 // Shouldn't be set: Parameter is excluded and not forced
294 'key321' => 'value321Overruled',
295 // Should be overriden: Parameter is not excluded
296 'key322' => 'value322Overruled',
297 // Shouldn't be set: Parameter doesn't exist in source array and is not forced
298 'key323' => 'value323Overruled'
299 )
300 )
301 );
302 $expectedResult = $this->rawUrlEncodeSquareBracketsInUrl('&key2=value2Overruled&key3[key32][key322]=value322Overruled');
303 $actualResult = $this->cObj->getQueryArguments($getQueryArgumentsConfiguration, $overruleArguments);
304 $this->assertEquals($expectedResult, $actualResult);
305 }
306
307 /**
308 * @test
309 */
310 public function getQueryArgumentsOverrulesMultiDimensionalForcedParameters() {
311 $_SERVER['QUERY_STRING'] = 'key1=value1' . '&key2=value2' . '&key3[key31]=value31' . '&key3[key32][key321]=value321' . '&key3[key32][key322]=value322';
312 $_POST = array(
313 'key1' => 'value1',
314 'key2' => 'value2',
315 'key3' => array(
316 'key31' => 'value31',
317 'key32' => array(
318 'key321' => 'value321',
319 'key322' => 'value322'
320 )
321 )
322 );
323 $getQueryArgumentsConfiguration = array();
324 $getQueryArgumentsConfiguration['exclude'] = array();
325 $getQueryArgumentsConfiguration['exclude'][] = 'key1';
326 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key31]';
327 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key32][key321]';
328 $getQueryArgumentsConfiguration['exclude'][] = 'key3[key32][key322]';
329 $getQueryArgumentsConfiguration['exclude'] = implode(',', $getQueryArgumentsConfiguration['exclude']);
330 $overruleArguments = array(
331 // Should be overriden
332 'key2' => 'value2Overruled',
333 'key3' => array(
334 'key32' => array(
335 // Should be set: Parameter is excluded but forced
336 'key321' => 'value321Overruled',
337 // Should be set: Parameter doesn't exist in source array but is forced
338 'key323' => 'value323Overruled'
339 )
340 )
341 );
342 $expectedResult = $this->rawUrlEncodeSquareBracketsInUrl('&key2=value2Overruled&key3[key32][key321]=value321Overruled&key3[key32][key323]=value323Overruled');
343 $actualResult = $this->cObj->getQueryArguments($getQueryArgumentsConfiguration, $overruleArguments, TRUE);
344 $this->assertEquals($expectedResult, $actualResult);
345 $getQueryArgumentsConfiguration['method'] = 'POST';
346 $actualResult = $this->cObj->getQueryArguments($getQueryArgumentsConfiguration, $overruleArguments, TRUE);
347 $this->assertEquals($expectedResult, $actualResult);
348 }
349
350 /**
351 * Encodes square brackets in URL.
352 *
353 * @param string $string
354 * @return string
355 */
356 private function rawUrlEncodeSquareBracketsInUrl($string) {
357 return str_replace(array('[', ']'), array('%5B', '%5D'), $string);
358 }
359
360 //////////////////////////////
361 // Tests concerning crop
362 //////////////////////////////
363 /**
364 * @test
365 */
366 public function cropIsMultibyteSafe() {
367 $this->assertEquals('бла', $this->cObj->crop('бла', '3|...'));
368 }
369
370 //////////////////////////////
371 // Tests concerning cropHTML
372 //////////////////////////////
373 /**
374 * This is the data provider for the tests of crop and cropHTML below. It provides all combinations
375 * of charset, text type, and configuration options to be tested.
376 *
377 * @return array two-dimensional array with the second level like this:
378 * @see cropHtmlWithDataProvider
379 */
380 public function cropHtmlDataProvider() {
381 $plainText = 'Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j implemented the original version of the crop function.';
382 $textWithMarkup = '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j</a>' . ' implemented</strong> the original version of the crop function.';
383 $textWithEntities = 'Kasper Sk&aring;rh&oslash;j implemented the; original ' . 'version of the crop function.';
384 $charsets = array('iso-8859-1', 'utf-8', 'ascii', 'big5');
385 $data = array();
386 foreach ($charsets as $charset) {
387 $data = array_merge($data, array(
388 $charset . ' plain text; 11|...' => array(
389 '11|...',
390 $plainText,
391 'Kasper Sk' . chr(229) . 'r...',
392 $charset
393 ),
394 $charset . ' plain text; -58|...' => array(
395 '-58|...',
396 $plainText,
397 '...h' . chr(248) . 'j implemented the original version of the crop function.',
398 $charset
399 ),
400 $charset . ' plain text; 4|...|1' => array(
401 '4|...|1',
402 $plainText,
403 'Kasp...',
404 $charset
405 ),
406 $charset . ' plain text; 20|...|1' => array(
407 '20|...|1',
408 $plainText,
409 'Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j...',
410 $charset
411 ),
412 $charset . ' plain text; -5|...|1' => array(
413 '-5|...|1',
414 $plainText,
415 '...tion.',
416 $charset
417 ),
418 $charset . ' plain text; -49|...|1' => array(
419 '-49|...|1',
420 $plainText,
421 '...the original version of the crop function.',
422 $charset
423 ),
424 $charset . ' text with markup; 11|...' => array(
425 '11|...',
426 $textWithMarkup,
427 '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'r...</a></strong>',
428 $charset
429 ),
430 $charset . ' text with markup; 13|...' => array(
431 '13|...',
432 $textWithMarkup,
433 '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'rh' . chr(248) . '...</a></strong>',
434 $charset
435 ),
436 $charset . ' text with markup; 14|...' => array(
437 '14|...',
438 $textWithMarkup,
439 '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j</a>...</strong>',
440 $charset
441 ),
442 $charset . ' text with markup; 15|...' => array(
443 '15|...',
444 $textWithMarkup,
445 '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j</a> ...</strong>',
446 $charset
447 ),
448 $charset . ' text with markup; 29|...' => array(
449 '29|...',
450 $textWithMarkup,
451 '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j</a> implemented</strong> th...',
452 $charset
453 ),
454 $charset . ' text with markup; -58|...' => array(
455 '-58|...',
456 $textWithMarkup,
457 '<strong><a href="mailto:kasper@typo3.org">...h' . chr(248) . 'j</a> implemented</strong> the original version of the crop function.',
458 $charset
459 ),
460 $charset . ' text with markup 4|...|1' => array(
461 '4|...|1',
462 $textWithMarkup,
463 '<strong><a href="mailto:kasper@typo3.org">Kasp...</a></strong>',
464 $charset
465 ),
466 $charset . ' text with markup; 11|...|1' => array(
467 '11|...|1',
468 $textWithMarkup,
469 '<strong><a href="mailto:kasper@typo3.org">Kasper...</a></strong>',
470 $charset
471 ),
472 $charset . ' text with markup; 13|...|1' => array(
473 '13|...|1',
474 $textWithMarkup,
475 '<strong><a href="mailto:kasper@typo3.org">Kasper...</a></strong>',
476 $charset
477 ),
478 $charset . ' text with markup; 14|...|1' => array(
479 '14|...|1',
480 $textWithMarkup,
481 '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j</a>...</strong>',
482 $charset
483 ),
484 $charset . ' text with markup; 15|...|1' => array(
485 '15|...|1',
486 $textWithMarkup,
487 '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j</a>...</strong>',
488 $charset
489 ),
490 $charset . ' text with markup; 29|...|1' => array(
491 '29|...|1',
492 $textWithMarkup,
493 '<strong><a href="mailto:kasper@typo3.org">Kasper Sk' . chr(229) . 'rh' . chr(248) . 'j</a> implemented</strong>...',
494 $charset
495 ),
496 $charset . ' text with markup; -66|...|1' => array(
497 '-66|...|1',
498 $textWithMarkup,
499 '<strong><a href="mailto:kasper@typo3.org">...Sk' . chr(229) . 'rh' . chr(248) . 'j</a> implemented</strong> the original version of the crop function.',
500 $charset
501 ),
502 $charset . ' text with entities 9|...' => array(
503 '9|...',
504 $textWithEntities,
505 'Kasper Sk...',
506 $charset
507 ),
508 $charset . ' text with entities 10|...' => array(
509 '10|...',
510 $textWithEntities,
511 'Kasper Sk&aring;...',
512 $charset
513 ),
514 $charset . ' text with entities 11|...' => array(
515 '11|...',
516 $textWithEntities,
517 'Kasper Sk&aring;r...',
518 $charset
519 ),
520 $charset . ' text with entities 13|...' => array(
521 '13|...',
522 $textWithEntities,
523 'Kasper Sk&aring;rh&oslash;...',
524 $charset
525 ),
526 $charset . ' text with entities 14|...' => array(
527 '14|...',
528 $textWithEntities,
529 'Kasper Sk&aring;rh&oslash;j...',
530 $charset
531 ),
532 $charset . ' text with entities 15|...' => array(
533 '15|...',
534 $textWithEntities,
535 'Kasper Sk&aring;rh&oslash;j ...',
536 $charset
537 ),
538 $charset . ' text with entities 16|...' => array(
539 '16|...',
540 $textWithEntities,
541 'Kasper Sk&aring;rh&oslash;j i...',
542 $charset
543 ),
544 $charset . ' text with entities -57|...' => array(
545 '-57|...',
546 $textWithEntities,
547 '...j implemented the; original version of the crop function.',
548 $charset
549 ),
550 $charset . ' text with entities -58|...' => array(
551 '-58|...',
552 $textWithEntities,
553 '...&oslash;j implemented the; original version of the crop function.',
554 $charset
555 ),
556 $charset . ' text with entities -59|...' => array(
557 '-59|...',
558 $textWithEntities,
559 '...h&oslash;j implemented the; original version of the crop function.',
560 $charset
561 ),
562 $charset . ' text with entities 4|...|1' => array(
563 '4|...|1',
564 $textWithEntities,
565 'Kasp...',
566 $charset
567 ),
568 $charset . ' text with entities 9|...|1' => array(
569 '9|...|1',
570 $textWithEntities,
571 'Kasper...',
572 $charset
573 ),
574 $charset . ' text with entities 10|...|1' => array(
575 '10|...|1',
576 $textWithEntities,
577 'Kasper...',
578 $charset
579 ),
580 $charset . ' text with entities 11|...|1' => array(
581 '11|...|1',
582 $textWithEntities,
583 'Kasper...',
584 $charset
585 ),
586 $charset . ' text with entities 13|...|1' => array(
587 '13|...|1',
588 $textWithEntities,
589 'Kasper...',
590 $charset
591 ),
592 $charset . ' text with entities 14|...|1' => array(
593 '14|...|1',
594 $textWithEntities,
595 'Kasper Sk&aring;rh&oslash;j...',
596 $charset
597 ),
598 $charset . ' text with entities 15|...|1' => array(
599 '15|...|1',
600 $textWithEntities,
601 'Kasper Sk&aring;rh&oslash;j...',
602 $charset
603 ),
604 $charset . ' text with entities 16|...|1' => array(
605 '16|...|1',
606 $textWithEntities,
607 'Kasper Sk&aring;rh&oslash;j...',
608 $charset
609 ),
610 $charset . ' text with entities -57|...|1' => array(
611 '-57|...|1',
612 $textWithEntities,
613 '...implemented the; original version of the crop function.',
614 $charset
615 ),
616 $charset . ' text with entities -58|...|1' => array(
617 '-58|...|1',
618 $textWithEntities,
619 '...implemented the; original version of the crop function.',
620 $charset
621 ),
622 $charset . ' text with entities -59|...|1' => array(
623 '-59|...|1',
624 $textWithEntities,
625 '...implemented the; original version of the crop function.',
626 $charset
627 ),
628 $charset . ' text with dash in html-element 28|...|1' => array(
629 '28|...|1',
630 'Some text with a link to <link email.address@example.org - mail "Open email window">my email.address@example.org</link> and text after it',
631 'Some text with a link to <link email.address@example.org - mail "Open email window">my...</link>',
632 $charset
633 )
634 ));
635 }
636 return $data;
637 }
638
639 /**
640 * Checks if stdWrap.cropHTML works with plain text cropping from left
641 *
642 * @test
643 * @dataProvider cropHtmlDataProvider
644 * @param string $settings
645 * @param string $subject the string to crop
646 * @param string $expected the expected cropped result
647 * @param string $charset the charset that will be set as renderCharset
648 */
649 public function cropHtmlWithDataProvider($settings, $subject, $expected, $charset) {
650 $this->handleCharset($charset, $subject, $expected);
651 $this->assertEquals($expected, $this->cObj->cropHTML($subject, $settings), 'cropHTML failed with settings: "' . $settings . '" and charset "' . $charset . '"');
652 }
653
654 /**
655 * Checks if stdWrap.cropHTML works with a complex content with many tags. Currently cropHTML
656 * counts multiple invisible characters not as one (as the browser will output the content).
657 *
658 * @test
659 */
660 public function cropHtmlWorksWithComplexContent() {
661 $GLOBALS['TSFE']->renderCharset = 'iso-8859-1';
662 $subject = '
663 <h1>Blog Example</h1>
664 <hr>
665 <div class="csc-header csc-header-n1">
666 <h2 class="csc-firstHeader">Welcome to Blog #1</h2>
667 </div>
668 <p class="bodytext">
669 A blog about TYPO3 extension development. In order to start blogging, read the <a href="#">Help section</a>. If you have any further questions, feel free to contact the administrator John Doe (<a href="mailto:john.doe@example.com">john.doe@example.com)</a>.
670 </p>
671 <div class="tx-blogexample-list-container">
672 <p class="bodytext">
673 Below are the most recent posts:
674 </p>
675 <ul>
676 <li>
677 <h3>
678 <a href="index.php?id=99&amp;tx_blogexample_pi1[post][uid]=211&amp;tx_blogexample_pi1[blog]=&amp;tx_blogexample_pi1[action]=show&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=003b0131ed">The Post #1</a>
679 </h3>
680 <p class="bodytext">
681 Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut...
682 </p>
683 <p class="metadata">
684 Published on 26.08.2009 by Jochen Rau
685 </p>
686 <p>
687 Tags: [MVC]&nbsp;[Domain Driven Design]&nbsp;<br>
688 <a href="index.php?id=99&amp;tx_blogexample_pi1[post][uid]=211&amp;tx_blogexample_pi1[action]=show&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=f982643bc3">read more &gt;&gt;</a><br>
689 <a href="index.php?id=99&amp;tx_blogexample_pi1[post][uid]=211&amp;tx_blogexample_pi1[blog][uid]=70&amp;tx_blogexample_pi1[action]=edit&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=5b481bc8f0">Edit</a>&nbsp;<a href="index.php?id=99&amp;tx_blogexample_pi1[post][uid]=211&amp;tx_blogexample_pi1[blog][uid]=70&amp;tx_blogexample_pi1[action]=delete&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=4e52879656">Delete</a>
690 </p>
691 </li>
692 </ul>
693 <p>
694 <a href="index.php?id=99&amp;tx_blogexample_pi1[blog][uid]=70&amp;tx_blogexample_pi1[action]=new&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=2718a4b1a0">Create a new Post</a>
695 </p>
696 </div>
697 <hr>
698 <p>
699 ? TYPO3 Association
700 </p>
701 ';
702 $result = $this->cObj->cropHTML($subject, '300');
703 $expected = '
704 <h1>Blog Example</h1>
705 <hr>
706 <div class="csc-header csc-header-n1">
707 <h2 class="csc-firstHeader">Welcome to Blog #1</h2>
708 </div>
709 <p class="bodytext">
710 A blog about TYPO3 extension development. In order to start blogging, read the <a href="#">Help section</a>. If you have any further questions, feel free to contact the administrator John Doe (<a href="mailto:john.doe@example.com">john.doe@example.com)</a>.
711 </p>
712 <div class="tx-blogexample-list-container">
713 <p class="bodytext">
714 Below are the most recent posts:
715 </p>
716 <ul>
717 <li>
718 <h3>
719 <a href="index.php?id=99&amp;tx_blogexample_pi1[post][uid]=211&amp;tx_blogexample_pi1[blog]=&amp;tx_blogexample_pi1[action]=show&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=003b0131ed">The Pos</a></h3></li></ul></div>';
720 $this->assertEquals($expected, $result);
721 $result = $this->cObj->cropHTML($subject, '-100');
722 $expected = '<div class="tx-blogexample-list-container"><ul><li><p>Design]&nbsp;<br>
723 <a href="index.php?id=99&amp;tx_blogexample_pi1[post][uid]=211&amp;tx_blogexample_pi1[action]=show&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=f982643bc3">read more &gt;&gt;</a><br>
724 <a href="index.php?id=99&amp;tx_blogexample_pi1[post][uid]=211&amp;tx_blogexample_pi1[blog][uid]=70&amp;tx_blogexample_pi1[action]=edit&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=5b481bc8f0">Edit</a>&nbsp;<a href="index.php?id=99&amp;tx_blogexample_pi1[post][uid]=211&amp;tx_blogexample_pi1[blog][uid]=70&amp;tx_blogexample_pi1[action]=delete&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=4e52879656">Delete</a>
725 </p>
726 </li>
727 </ul>
728 <p>
729 <a href="index.php?id=99&amp;tx_blogexample_pi1[blog][uid]=70&amp;tx_blogexample_pi1[action]=new&amp;tx_blogexample_pi1[controller]=Post&amp;cHash=2718a4b1a0">Create a new Post</a>
730 </p>
731 </div>
732 <hr>
733 <p>
734 ? TYPO3 Association
735 </p>
736 ';
737 $this->assertEquals($expected, $result);
738 }
739
740 /**
741 * @return array
742 */
743 public function stdWrap_roundDataProvider() {
744 return array(
745 'rounding off without any configuration' => array(
746 1.123456789,
747 array(),
748 1
749 ),
750 'rounding up without any configuration' => array(
751 1.523456789,
752 array(),
753 2
754 ),
755 'regular rounding (off) to two decimals' => array(
756 0.123456789,
757 array(
758 'decimals' => 2
759 ),
760 0.12
761 ),
762 'regular rounding (up) to two decimals' => array(
763 0.1256789,
764 array(
765 'decimals' => 2
766 ),
767 0.13
768 ),
769 'rounding up to integer with type ceil' => array(
770 0.123456789,
771 array(
772 'roundType' => 'ceil'
773 ),
774 1
775 ),
776 'rounding down to integer with type floor' => array(
777 2.3481,
778 array(
779 'roundType' => 'floor'
780 ),
781 2
782 )
783 );
784 }
785
786 /**
787 * Checks if stdWrap.cropHTML handles linebreaks correctly (by ignoring them)
788 *
789 * @test
790 */
791 public function cropHtmlWorksWithLinebreaks() {
792 $subject = "Lorem ipsum dolor sit amet,\nconsetetur sadipscing elitr,\nsed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam";
793 $expected = "Lorem ipsum dolor sit amet,\nconsetetur sadipscing elitr,\nsed diam nonumy eirmod tempor invidunt ut labore et dolore magna";
794 $result = $this->cObj->cropHTML($subject, '121');
795 $this->assertEquals($expected, $result);
796 }
797
798 /**
799 * Test for the stdWrap function "round"
800 *
801 * @param float $float
802 * @param array $conf
803 * @param float $expected
804 * @return void
805 * @dataProvider stdWrap_roundDataProvider
806 * @test
807 */
808 public function stdWrap_round($float, $conf, $expected) {
809 $conf = array(
810 'round.' => $conf
811 );
812 $result = $this->cObj->stdWrap_round($float, $conf);
813 $this->assertEquals($expected, $result);
814 }
815
816 /**
817 * @return array
818 */
819 public function stdWrap_strPadDataProvider() {
820 return array(
821 'pad string with default settings and length 10' => array(
822 'Alien',
823 array(
824 'length' => '10',
825 ),
826 'Alien ',
827 ),
828 'pad string with padWith -= and type left and length 10' => array(
829 'Alien',
830 array(
831 'length' => '10',
832 'padWith' => '-=',
833 'type' => 'left',
834 ),
835 '-=-=-Alien',
836 ),
837 'pad string with padWith _ and type both and length 10' => array(
838 'Alien',
839 array(
840 'length' => '10',
841 'padWith' => '_',
842 'type' => 'both',
843 ),
844 '__Alien___',
845 ),
846 'pad string with padWith ___ and type both and length 6' => array(
847 'Alien',
848 array(
849 'length' => '6',
850 'padWith' => '___',
851 'type' => 'both',
852 ),
853 'Alien_',
854 ),
855 'pad string with padWith _ and type both and length 12, using stdWrap for length' => array(
856 'Alien',
857 array(
858 'length' => '1',
859 'length.' => array(
860 'wrap' => '|2',
861 ),
862 'padWith' => '_',
863 'type' => 'both',
864 ),
865 '___Alien____',
866 ),
867 'pad string with padWith _ and type both and length 12, using stdWrap for padWidth' => array(
868 'Alien',
869 array(
870 'length' => '12',
871 'padWith' => '_',
872 'padWith.' => array(
873 'wrap' => '-|=',
874 ),
875 'type' => 'both',
876 ),
877 '-_=Alien-_=-',
878 ),
879 'pad string with padWith _ and type both and length 12, using stdWrap for type' => array(
880 'Alien',
881 array(
882 'length' => '12',
883 'padWith' => '_',
884 'type' => 'both',
885 // make type become "left"
886 'type.' => array(
887 'substring' => '2,1',
888 'wrap' => 'lef|',
889 ),
890 ),
891 '_______Alien',
892 ),
893 );
894 }
895
896 /**
897 * Test for the stdWrap function "strPad"
898 *
899 * @param string $content
900 * @param array $conf
901 * @param string $expected
902 *
903 * @dataProvider stdWrap_strPadDataProvider
904 * @test
905 */
906 public function stdWrap_strPad($content, $conf, $expected) {
907 $conf = array(
908 'strPad.' => $conf
909 );
910 $result = $this->cObj->stdWrap_strPad($content, $conf);
911 $this->assertEquals($expected, $result);
912 }
913
914 /**
915 * Data provider for the hash test
916 *
917 * @return array multi-dimensional array with the second level like this:
918 * @see hash
919 */
920 public function hashDataProvider() {
921 $data = array(
922 'testing md5' => array(
923 'joh316',
924 array(
925 'hash' => 'md5'
926 ),
927 'bacb98acf97e0b6112b1d1b650b84971'
928 ),
929 'testing sha1' => array(
930 'joh316',
931 array(
932 'hash' => 'sha1'
933 ),
934 '063b3d108bed9f88fa618c6046de0dccadcf3158'
935 ),
936 'testing non-existing hashing algorithm' => array(
937 'joh316',
938 array(
939 'hash' => 'non-existing'
940 ),
941 ''
942 ),
943 'testing stdWrap capability' => array(
944 'joh316',
945 array(
946 'hash.' => array(
947 'cObject' => 'TEXT',
948 'cObject.' => array(
949 'value' => 'md5'
950 )
951 )
952 ),
953 'bacb98acf97e0b6112b1d1b650b84971'
954 )
955 );
956 return $data;
957 }
958
959 /**
960 * Test for the stdWrap function "hash"
961 *
962 * @param string $text
963 * @param array $conf
964 * @param string $expected
965 * @return void
966 * @dataProvider hashDataProvider
967 * @test
968 */
969 public function stdWrap_hash($text, array $conf, $expected) {
970 $result = $this->cObj->stdWrap_hash($text, $conf);
971 $this->assertEquals($expected, $result);
972 }
973
974 /**
975 * Data provider for the numberFormat test
976 *
977 * @return array multi-dimensional array with the second level like this:
978 * @see numberFormat
979 */
980 public function numberFormatDataProvider() {
981 $data = array(
982 'testing decimals' => array(
983 0.8,
984 array(
985 'decimals' => 2
986 ),
987 '0.80'
988 ),
989 'testing dec_point' => array(
990 0.8,
991 array(
992 'decimals' => 1,
993 'dec_point' => ','
994 ),
995 '0,8'
996 ),
997 'testing thousands_sep' => array(
998 999.99,
999 array(
1000 'decimals' => 0,
1001 'thousands_sep.' => array(
1002 'char' => 46
1003 )
1004 ),
1005 '1.000'
1006 ),
1007 'testing mixture' => array(
1008 1281731.45,
1009 array(
1010 'decimals' => 1,
1011 'dec_point.' => array(
1012 'char' => 44
1013 ),
1014 'thousands_sep.' => array(
1015 'char' => 46
1016 )
1017 ),
1018 '1.281.731,5'
1019 )
1020 );
1021 return $data;
1022 }
1023
1024 /**
1025 * Check if stdWrap.numberFormat and all of its properties work properly
1026 *
1027 * @dataProvider numberFormatDataProvider
1028 * @test
1029 */
1030 public function numberFormat($float, $formatConf, $expected) {
1031 $result = $this->cObj->numberFormat($float, $formatConf);
1032 $this->assertEquals($expected, $result);
1033 }
1034
1035 /**
1036 * Data provider for the replacement test
1037 *
1038 * @return array multi-dimensional array with the second level like this:
1039 * @see replacement
1040 */
1041 public function replacementDataProvider() {
1042 $data = array(
1043 'multiple replacements, including regex' => array(
1044 'There_is_a_cat,_a_dog_and_a_tiger_in_da_hood!_Yeah!',
1045 array(
1046 'replacement.' => array(
1047 '120.' => array(
1048 'search' => 'in da hood',
1049 'replace' => 'around the block'
1050 ),
1051 '20.' => array(
1052 'search' => '_',
1053 'replace.' => array('char' => '32')
1054 ),
1055 '130.' => array(
1056 'search' => '#a (Cat|Dog|Tiger)#i',
1057 'replace' => 'an animal',
1058 'useRegExp' => '1'
1059 )
1060 )
1061 ),
1062 'There is an animal, an animal and an animal around the block! Yeah!'
1063 ),
1064 'replacement with optionSplit, normal pattern' => array(
1065 'There_is_a_cat,_a_dog_and_a_tiger_in_da_hood!_Yeah!',
1066 array(
1067 'replacement.' => array(
1068 '10.' => array(
1069 'search' => '_',
1070 'replace' => '1 || 2 || 3',
1071 'useOptionSplitReplace' => '1'
1072 ),
1073 )
1074 ),
1075 'There1is2a3cat,3a3dog3and3a3tiger3in3da3hood!3Yeah!'
1076 ),
1077 'replacement with optionSplit, using regex' => array(
1078 'There is a cat, a dog and a tiger in da hood! Yeah!',
1079 array(
1080 'replacement.' => array(
1081 '10.' => array(
1082 'search' => '#(a) (Cat|Dog|Tiger)#i',
1083 'replace' => '${1} tiny ${2} || ${1} midsized ${2} || ${1} big ${2}',
1084 'useOptionSplitReplace' => '1',
1085 'useRegExp' => '1'
1086 )
1087 )
1088 ),
1089 'There is a tiny cat, a midsized dog and a big tiger in da hood! Yeah!'
1090 ),
1091 );
1092 return $data;
1093 }
1094
1095 /**
1096 * Check if stdWrap.replacement and all of its properties work properly
1097 *
1098 * @dataProvider replacementDataProvider
1099 * @test
1100 */
1101 public function replacement($input, $conf, $expected) {
1102 $result = $this->cObj->stdWrap_replacement($input, $conf);
1103 $this->assertEquals($expected, $result);
1104 }
1105
1106 /**
1107 * Data provider for the getQuery test
1108 *
1109 * @return array multi-dimensional array with the second level like this:
1110 * @see getQuery
1111 */
1112 public function getQueryDataProvider() {
1113 $data = array(
1114 'testing empty conf' => array(
1115 'tt_content',
1116 array(),
1117 array(
1118 'SELECT' => '*'
1119 )
1120 ),
1121 'testing #17284: adding uid/pid for workspaces' => array(
1122 'tt_content',
1123 array(
1124 'selectFields' => 'header,bodytext'
1125 ),
1126 array(
1127 'SELECT' => 'header,bodytext, tt_content.uid as uid, tt_content.pid as pid, tt_content.t3ver_state as t3ver_state'
1128 )
1129 ),
1130 'testing #17284: no need to add' => array(
1131 'tt_content',
1132 array(
1133 'selectFields' => 'tt_content.*'
1134 ),
1135 array(
1136 'SELECT' => 'tt_content.*'
1137 )
1138 ),
1139 'testing #17284: no need to add #2' => array(
1140 'tt_content',
1141 array(
1142 'selectFields' => '*'
1143 ),
1144 array(
1145 'SELECT' => '*'
1146 )
1147 ),
1148 'testing #29783: joined tables, prefix tablename' => array(
1149 'tt_content',
1150 array(
1151 'selectFields' => 'tt_content.header,be_users.username',
1152 'join' => 'be_users ON tt_content.cruser_id = be_users.uid'
1153 ),
1154 array(
1155 'SELECT' => 'tt_content.header,be_users.username, tt_content.uid as uid, tt_content.pid as pid, tt_content.t3ver_state as t3ver_state'
1156 )
1157 ),
1158 'testing #34152: single count(*), add nothing' => array(
1159 'tt_content',
1160 array(
1161 'selectFields' => 'count(*)'
1162 ),
1163 array(
1164 'SELECT' => 'count(*)'
1165 )
1166 ),
1167 'testing #34152: single max(crdate), add nothing' => array(
1168 'tt_content',
1169 array(
1170 'selectFields' => 'max(crdate)'
1171 ),
1172 array(
1173 'SELECT' => 'max(crdate)'
1174 )
1175 ),
1176 'testing #34152: single min(crdate), add nothing' => array(
1177 'tt_content',
1178 array(
1179 'selectFields' => 'min(crdate)'
1180 ),
1181 array(
1182 'SELECT' => 'min(crdate)'
1183 )
1184 ),
1185 'testing #34152: single sum(is_siteroot), add nothing' => array(
1186 'tt_content',
1187 array(
1188 'selectFields' => 'sum(is_siteroot)'
1189 ),
1190 array(
1191 'SELECT' => 'sum(is_siteroot)'
1192 )
1193 ),
1194 'testing #34152: single avg(crdate), add nothing' => array(
1195 'tt_content',
1196 array(
1197 'selectFields' => 'avg(crdate)'
1198 ),
1199 array(
1200 'SELECT' => 'avg(crdate)'
1201 )
1202 )
1203 );
1204 return $data;
1205 }
1206
1207 /**
1208 * Check if sanitizeSelectPart works as expected
1209 *
1210 * @dataProvider getQueryDataProvider
1211 * @test
1212 */
1213 public function getQuery($table, $conf, $expected) {
1214 $result = $this->cObj->getQuery($table, $conf, TRUE);
1215 foreach ($expected as $field => $value) {
1216 $this->assertEquals($value, $result[$field]);
1217 }
1218 }
1219
1220 /**
1221 * Data provider for the stdWrap_strftime test
1222 *
1223 * @return array multi-dimensional array with the second level like this:
1224 * @see stdWrap_strftime
1225 */
1226 public function stdWrap_strftimeReturnsFormattedStringDataProvider() {
1227 $data = array(
1228 'given timestamp' => array(
1229 1346500800, // This is 2012-09-01 12:00 in UTC/GMT
1230 array(
1231 'strftime' => '%d-%m-%Y',
1232 ),
1233 ),
1234 'empty string' => array(
1235 '',
1236 array(
1237 'strftime' => '%d-%m-%Y',
1238 ),
1239 ),
1240 'testing null' => array(
1241 NULL,
1242 array(
1243 'strftime' => '%d-%m-%Y',
1244 ),
1245 ),
1246 );
1247 return $data;
1248 }
1249
1250 /**
1251 * @test
1252 * @dataProvider stdWrap_strftimeReturnsFormattedStringDataProvider
1253 */
1254 public function stdWrap_strftimeReturnsFormattedString($content, $conf) {
1255 // Set exec_time to a hard timestamp
1256 $GLOBALS['EXEC_TIME'] = 1346500800;
1257 // Save current timezone and set to UTC to make the system under test behave
1258 // the same in all server timezone settings
1259 $timezoneBackup = date_default_timezone_get();
1260 date_default_timezone_set('UTC');
1261
1262 $result = $this->cObj->stdWrap_strftime($content, $conf);
1263
1264 // Reset timezone
1265 date_default_timezone_set($timezoneBackup);
1266
1267 $this->assertEquals('01-09-2012', $result);
1268 }
1269
1270 /**
1271 * @param string|NULL $content
1272 * @param array $configuration
1273 * @param string $expected
1274 * @dataProvider stdWrap_ifNullDeterminesNullValuesDataProvider
1275 * @test
1276 */
1277 public function stdWrap_ifNullDeterminesNullValues($content, array $configuration, $expected) {
1278 $result = $this->cObj->stdWrap_ifNull($content, $configuration);
1279 $this->assertEquals($expected, $result);
1280 }
1281
1282 /**
1283 * Data provider for stdWrap_ifNullDeterminesNullValues test
1284 *
1285 * @return array
1286 */
1287 public function stdWrap_ifNullDeterminesNullValuesDataProvider() {
1288 return array(
1289 'null value' => array(
1290 NULL,
1291 array(
1292 'ifNull' => '1',
1293 ),
1294 '1',
1295 ),
1296 'zero value' => array(
1297 '0',
1298 array(
1299 'ifNull' => '1',
1300 ),
1301 '0',
1302 ),
1303 );
1304 }
1305
1306 /**
1307 * @param $content
1308 * @param array $configuration
1309 * @param $expected
1310 * @dataProvider stdWrap_noTrimWrapAcceptsSplitCharDataProvider
1311 * @test
1312 */
1313 public function stdWrap_noTrimWrapAcceptsSplitChar($content, array $configuration, $expected) {
1314 $result = $this->cObj->stdWrap_noTrimWrap($content, $configuration);
1315 $this->assertEquals($expected, $result);
1316 }
1317
1318 /**
1319 * Data provider for stdWrap_noTrimWrapAcceptsSplitChar test
1320 *
1321 * @return array
1322 */
1323 public function stdWrap_noTrimWrapAcceptsSplitCharDataProvider() {
1324 return array(
1325 'No char given' => array(
1326 'middle',
1327 array(
1328 'noTrimWrap' => '| left | right |',
1329 ),
1330 ' left middle right '
1331 ),
1332 'Zero char given' => array(
1333 'middle',
1334 array(
1335 'noTrimWrap' => '0 left 0 right 0',
1336 'noTrimWrap.' => array('splitChar' => '0'),
1337
1338 ),
1339 ' left middle right '
1340 ),
1341 'Default char given' => array(
1342 'middle',
1343 array(
1344 'noTrimWrap' => '| left | right |',
1345 'noTrimWrap.' => array('splitChar' => '|'),
1346 ),
1347 ' left middle right '
1348 ),
1349 'Split char is a' => array(
1350 'middle',
1351 array(
1352 'noTrimWrap' => 'a left a right a',
1353 'noTrimWrap.' => array('splitChar' => 'a'),
1354 ),
1355 ' left middle right '
1356 ),
1357 'Split char is multi-char (ab)' => array(
1358 'middle',
1359 array(
1360 'noTrimWrap' => 'ab left ab right ab',
1361 'noTrimWrap.' => array('splitChar' => 'ab'),
1362 ),
1363 ' left middle right '
1364 ),
1365 'Split char accepts stdWrap' => array(
1366 'middle',
1367 array(
1368 'noTrimWrap' => 'abc left abc right abc',
1369 'noTrimWrap.' => array(
1370 'splitChar' => 'b',
1371 'splitChar.' => array('wrap' => 'a|c'),
1372 ),
1373 ),
1374 ' left middle right '
1375 ),
1376 );
1377 }
1378
1379 /**
1380 * @param array $expectedTags
1381 * @param array $configuration
1382 * @test
1383 * @dataProvider stdWrap_addPageCacheTagsAddsPageTagsDataProvider
1384 */
1385 public function stdWrap_addPageCacheTagsAddsPageTags(array $expectedTags, array $configuration) {
1386 $this->cObj->stdWrap_addPageCacheTags('', $configuration);
1387 $this->assertEquals($expectedTags, $this->tsfe->_get('pageCacheTags'));
1388 }
1389
1390 /**
1391 * @return array
1392 */
1393 public function stdWrap_addPageCacheTagsAddsPageTagsDataProvider() {
1394 return array(
1395 'No Tag' => array(
1396 array(),
1397 array('addPageCacheTags' => ''),
1398 ),
1399 'Two expectedTags' => array(
1400 array('tag1', 'tag2'),
1401 array('addPageCacheTags' => 'tag1,tag2'),
1402 ),
1403 'Two expectedTags plus one with stdWrap' => array(
1404 array('tag1', 'tag2', 'tag3'),
1405 array(
1406 'addPageCacheTags' => 'tag1,tag2',
1407 'addPageCacheTags.' => array('wrap' => '|,tag3')
1408 ),
1409 ),
1410 );
1411 }
1412
1413
1414 /////////////////////////////
1415 // Tests concerning getData()
1416 /////////////////////////////
1417
1418 /**
1419 * @return array
1420 */
1421 public function getDataWithTypeGpDataProvider() {
1422 return array(
1423 'Value in get-data' => array('onlyInGet', 'GetValue'),
1424 'Value in post-data' => array('onlyInPost', 'PostValue'),
1425 'Value in post-data overriding get-data' => array('inGetAndPost', 'ValueInPost'),
1426 );
1427 }
1428
1429 /**
1430 * Checks if getData() works with type "gp"
1431 *
1432 * @test
1433 * @dataProvider getDataWithTypeGpDataProvider
1434 */
1435 public function getDataWithTypeGp($key, $expectedValue) {
1436 $_GET = array(
1437 'onlyInGet' => 'GetValue',
1438 'inGetAndPost' => 'ValueInGet',
1439 );
1440 $_POST = array(
1441 'onlyInPost' => 'PostValue',
1442 'inGetAndPost' => 'ValueInPost',
1443 );
1444 $this->assertEquals($expectedValue, $this->cObj->getData('gp:' . $key));
1445 }
1446
1447 /**
1448 * Checks if getData() works with type "tsfe"
1449 *
1450 * @test
1451 */
1452 public function getDataWithTypeTsfe() {
1453 $this->assertEquals($GLOBALS['TSFE']->renderCharset, $this->cObj->getData('tsfe:renderCharset'));
1454 }
1455
1456 /**
1457 * Checks if getData() works with type "getenv"
1458 *
1459 * @test
1460 */
1461 public function getDataWithTypeGetenv() {
1462 $envName = uniqid('frontendtest');
1463 $value = uniqid('someValue');
1464 putenv($envName . '=' . $value);
1465 $this->assertEquals($value, $this->cObj->getData('getenv:' . $envName));
1466 }
1467
1468 /**
1469 * Checks if getData() works with type "getindpenv"
1470 *
1471 * @test
1472 */
1473 public function getDataWithTypeGetindpenv() {
1474 $this->assertEquals(PATH_thisScript, $this->cObj->getData('getindpenv:SCRIPT_FILENAME'));
1475 }
1476
1477 /**
1478 * Checks if getData() works with type "getindpenv"
1479 *
1480 * @test
1481 */
1482 public function getDataWithTypeField() {
1483 $key = 'someKey';
1484 $value = 'someValue';
1485 $field = array($key => $value);
1486
1487 $this->assertEquals($value, $this->cObj->getData('field:' . $key, $field));
1488 }
1489
1490 /**
1491 * Checks if getData() works with type "file"
1492 *
1493 * @test
1494 */
1495 public function getDataWithTypeFile() {
1496 $uid = rand();
1497 $properties = array(
1498 uniqid() => uniqid(),
1499 uniqid() => uniqid(),
1500 'uid' => $uid
1501 );
1502 $file = new \TYPO3\CMS\Core\Resource\File($properties);
1503 $this->cObj->setCurrentFile($file);
1504
1505 $this->assertEquals($uid, $this->cObj->getData('file:current:uid'));
1506 }
1507
1508 /**
1509 * Checks if getData() works with type "parameters"
1510 *
1511 * @test
1512 */
1513 public function getDataWithTypeParameters() {
1514 $key = uniqid('someKey');
1515 $value = uniqid('someValue');
1516 $this->cObj->parameters[$key] = $value;
1517
1518 $this->assertEquals($value, $this->cObj->getData('parameters:' . $key));
1519 }
1520
1521 /**
1522 * Checks if getData() works with type "register"
1523 *
1524 * @test
1525 */
1526 public function getDataWithTypeRegister() {
1527 $key = uniqid('someKey');
1528 $value = uniqid('someValue');
1529 $GLOBALS['TSFE']->register[$key] = $value;
1530
1531 $this->assertEquals($value, $this->cObj->getData('register:' . $key));
1532 }
1533
1534 /**
1535 * Checks if getData() works with type "level"
1536 *
1537 * @test
1538 */
1539 public function getDataWithTypeLevel() {
1540 $rootline = array(
1541 0 => array('uid' => 1, 'title' => 'title1'),
1542 1 => array('uid' => 2, 'title' => 'title2'),
1543 2 => array('uid' => 3, 'title' => 'title3'),
1544 );
1545
1546 $GLOBALS['TSFE']->tmpl->rootLine = $rootline;
1547 $this->assertEquals(2, $this->cObj->getData('level'));
1548 }
1549
1550 /**
1551 * Checks if getData() works with type "global"
1552 *
1553 * @test
1554 */
1555 public function getDataWithTypeGlobal() {
1556 $this->assertEquals($GLOBALS['TSFE']->renderCharset, $this->cObj->getData('global:TSFE|renderCharset'));
1557 }
1558
1559 /**
1560 * Checks if getData() works with type "leveltitle"
1561 *
1562 * @test
1563 */
1564 public function getDataWithTypeLeveltitle() {
1565 $rootline = array(
1566 0 => array('uid' => 1, 'title' => 'title1'),
1567 1 => array('uid' => 2, 'title' => 'title2'),
1568 2 => array('uid' => 3, 'title' => ''),
1569 );
1570
1571 $GLOBALS['TSFE']->tmpl->rootLine = $rootline;
1572 $this->assertEquals('', $this->cObj->getData('leveltitle:-1'));
1573 // since "title3" is not set, it will slide to "title2"
1574 $this->assertEquals('title2', $this->cObj->getData('leveltitle:-1,slide'));
1575 }
1576
1577 /**
1578 * Checks if getData() works with type "levelmedia"
1579 *
1580 * @test
1581 */
1582 public function getDataWithTypeLevelmedia() {
1583 $rootline = array(
1584 0 => array('uid' => 1, 'title' => 'title1', 'media' => 'media1'),
1585 1 => array('uid' => 2, 'title' => 'title2', 'media' => 'media2'),
1586 2 => array('uid' => 3, 'title' => 'title3', 'media' => ''),
1587 );
1588
1589 $GLOBALS['TSFE']->tmpl->rootLine = $rootline;
1590 $this->assertEquals('', $this->cObj->getData('levelmedia:-1'));
1591 // since "title3" is not set, it will slide to "title2"
1592 $this->assertEquals('media2', $this->cObj->getData('levelmedia:-1,slide'));
1593 }
1594
1595 /**
1596 * Checks if getData() works with type "leveluid"
1597 *
1598 * @test
1599 */
1600 public function getDataWithTypeLeveluid() {
1601 $rootline = array(
1602 0 => array('uid' => 1, 'title' => 'title1'),
1603 1 => array('uid' => 2, 'title' => 'title2'),
1604 2 => array('uid' => 3, 'title' => 'title3'),
1605 );
1606
1607 $GLOBALS['TSFE']->tmpl->rootLine = $rootline;
1608 $this->assertEquals(3, $this->cObj->getData('leveluid:-1'));
1609 // every element will have a uid - so adding slide doesn't really make sense, just for completeness
1610 $this->assertEquals(3, $this->cObj->getData('leveluid:-1,slide'));
1611 }
1612
1613 /**
1614 * Checks if getData() works with type "levelfield"
1615 *
1616 * @test
1617 */
1618 public function getDataWithTypeLevelfield() {
1619 $rootline = array(
1620 0 => array('uid' => 1, 'title' => 'title1', 'testfield' => 'field1'),
1621 1 => array('uid' => 2, 'title' => 'title2', 'testfield' => 'field2'),
1622 2 => array('uid' => 3, 'title' => 'title3', 'testfield' => ''),
1623 );
1624
1625 $GLOBALS['TSFE']->tmpl->rootLine = $rootline;
1626 $this->assertEquals('', $this->cObj->getData('levelfield:-1,testfield'));
1627 $this->assertEquals('field2', $this->cObj->getData('levelfield:-1,testfield,slide'));
1628 }
1629
1630 /**
1631 * Checks if getData() works with type "fullrootline"
1632 *
1633 * @test
1634 */
1635 public function getDataWithTypeFullrootline() {
1636 $rootline1 = array(
1637 0 => array('uid' => 1, 'title' => 'title1', 'testfield' => 'field1'),
1638 );
1639 $rootline2 = array(
1640 0 => array('uid' => 1, 'title' => 'title1', 'testfield' => 'field1'),
1641 1 => array('uid' => 2, 'title' => 'title2', 'testfield' => 'field2'),
1642 2 => array('uid' => 3, 'title' => 'title3', 'testfield' => 'field3'),
1643 );
1644
1645 $GLOBALS['TSFE']->tmpl->rootLine = $rootline1;
1646 $GLOBALS['TSFE']->rootLine = $rootline2;
1647 $this->assertEquals('field2', $this->cObj->getData('fullrootline:-1,testfield'));
1648 }
1649
1650 /**
1651 * Checks if getData() works with type "date"
1652 *
1653 * @test
1654 */
1655 public function getDataWithTypeDate() {
1656 $format = 'Y-M-D';
1657 $defaultFormat = 'd/m Y';
1658
1659 $this->assertEquals(date($format, $GLOBALS['EXEC_TIME']), $this->cObj->getData('date:' . $format));
1660 $this->assertEquals(date($defaultFormat, $GLOBALS['EXEC_TIME']), $this->cObj->getData('date'));
1661 }
1662
1663 /**
1664 * Checks if getData() works with type "page"
1665 *
1666 * @test
1667 */
1668 public function getDataWithTypePage() {
1669 $uid = rand();
1670 $GLOBALS['TSFE']->page['uid'] = $uid;
1671 $this->assertEquals($uid, $this->cObj->getData('page:uid'));
1672 }
1673
1674 /**
1675 * Checks if getData() works with type "current"
1676 *
1677 * @test
1678 */
1679 public function getDataWithTypeCurrent() {
1680 $key = uniqid('someKey');
1681 $value = uniqid('someValue');
1682 $this->cObj->data[$key] = $value;
1683 $this->cObj->currentValKey = $key;
1684 $this->assertEquals($value, $this->cObj->getData('current'));
1685 }
1686
1687 /**
1688 * Checks if getData() works with type "db"
1689 *
1690 * @test
1691 */
1692 public function getDataWithTypeDb() {
1693 $dummyRecord = array('uid' => 5, 'title' => 'someTitle');
1694
1695 $GLOBALS['TSFE']->sys_page->expects($this->atLeastOnce())->method('getRawRecord')->with('tt_content', '106')->will($this->returnValue($dummyRecord));
1696 $this->assertEquals($dummyRecord['title'], $this->cObj->getData('db:tt_content:106:title'));
1697 }
1698
1699 /**
1700 * Checks if getData() works with type "lll"
1701 *
1702 * @test
1703 */
1704 public function getDataWithTypeLll() {
1705 $key = uniqid('someKey');
1706 $value = uniqid('someValue');
1707 $language = uniqid('someLanguage');
1708 $GLOBALS['TSFE']->LL_labels_cache[$language]['LLL:' . $key] = $value;
1709 $GLOBALS['TSFE']->lang = $language;
1710
1711 $this->assertEquals($value, $this->cObj->getData('lll:' . $key));
1712 }
1713
1714 /**
1715 * Checks if getData() works with type "path"
1716 *
1717 * @test
1718 */
1719 public function getDataWithTypePath() {
1720 $filenameIn = uniqid('someValue');
1721 $filenameOut = uniqid('someValue');
1722 $this->template->expects($this->atLeastOnce())->method('getFileName')->with($filenameIn)->will($this->returnValue($filenameOut));
1723 $this->assertEquals($filenameOut, $this->cObj->getData('path:' . $filenameIn));
1724 }
1725
1726 /**
1727 * Checks if getData() works with type "parentRecordNumber"
1728 *
1729 * @test
1730 */
1731 public function getDataWithTypeParentRecordNumber() {
1732 $recordNumber = rand();
1733 $this->cObj->parentRecordNumber = $recordNumber;
1734 $this->assertEquals($recordNumber, $this->cObj->getData('cobj:parentRecordNumber'));
1735 }
1736
1737 /**
1738 * Checks if getData() works with type "debug:rootLine"
1739 *
1740 * @test
1741 */
1742 public function getDataWithTypeDebugRootline() {
1743 $rootline = array(
1744 0 => array('uid' => 1, 'title' => 'title1'),
1745 1 => array('uid' => 2, 'title' => 'title2'),
1746 2 => array('uid' => 3, 'title' => ''),
1747 );
1748 $expectedResult = '0uid1titletitle11uid2titletitle22uid3title';
1749 $GLOBALS['TSFE']->tmpl->rootLine = $rootline;
1750
1751 $result = $this->cObj->getData('debug:rootLine');
1752 $cleanedResult = strip_tags($result);
1753 $cleanedResult = str_replace("\r", '', $cleanedResult);
1754 $cleanedResult = str_replace("\n", '', $cleanedResult);
1755 $cleanedResult = str_replace("\t", '', $cleanedResult);
1756 $cleanedResult = str_replace(' ', '', $cleanedResult);
1757
1758 $this->assertEquals($expectedResult, $cleanedResult);
1759 }
1760
1761 /**
1762 * Checks if getData() works with type "debug:fullRootLine"
1763 *
1764 * @test
1765 */
1766 public function getDataWithTypeDebugFullRootline() {
1767 $rootline = array(
1768 0 => array('uid' => 1, 'title' => 'title1'),
1769 1 => array('uid' => 2, 'title' => 'title2'),
1770 2 => array('uid' => 3, 'title' => ''),
1771 );
1772 $expectedResult = '0uid1titletitle11uid2titletitle22uid3title';
1773 $GLOBALS['TSFE']->rootLine = $rootline;
1774
1775 $result = $this->cObj->getData('debug:fullRootLine');
1776 $cleanedResult = strip_tags($result);
1777 $cleanedResult = str_replace("\r", '', $cleanedResult);
1778 $cleanedResult = str_replace("\n", '', $cleanedResult);
1779 $cleanedResult = str_replace("\t", '', $cleanedResult);
1780 $cleanedResult = str_replace(' ', '', $cleanedResult);
1781
1782 $this->assertEquals($expectedResult, $cleanedResult);
1783 }
1784
1785 /**
1786 * Checks if getData() works with type "debug:data"
1787 *
1788 * @test
1789 */
1790 public function getDataWithTypeDebugData() {
1791 $key = uniqid('someKey');
1792 $value = uniqid('someValue');
1793 $this->cObj->data = array($key => $value);
1794
1795 $expectedResult = $key . $value;
1796
1797 $result = $this->cObj->getData('debug:data');
1798 $cleanedResult = strip_tags($result);
1799 $cleanedResult = str_replace("\r", '', $cleanedResult);
1800 $cleanedResult = str_replace("\n", '', $cleanedResult);
1801 $cleanedResult = str_replace("\t", '', $cleanedResult);
1802 $cleanedResult = str_replace(' ', '', $cleanedResult);
1803
1804 $this->assertEquals($expectedResult, $cleanedResult);
1805 }
1806
1807 /**
1808 * Checks if getData() works with type "debug:register"
1809 *
1810 * @test
1811 */
1812 public function getDataWithTypeDebugRegister() {
1813 $key = uniqid('someKey');
1814 $value = uniqid('someValue');
1815 $GLOBALS['TSFE']->register = array($key => $value);
1816
1817 $expectedResult = $key . $value;
1818
1819 $result = $this->cObj->getData('debug:register');
1820 $cleanedResult = strip_tags($result);
1821 $cleanedResult = str_replace("\r", '', $cleanedResult);
1822 $cleanedResult = str_replace("\n", '', $cleanedResult);
1823 $cleanedResult = str_replace("\t", '', $cleanedResult);
1824 $cleanedResult = str_replace(' ', '', $cleanedResult);
1825
1826 $this->assertEquals($expectedResult, $cleanedResult);
1827 }
1828
1829 /**
1830 * Checks if getData() works with type "data:page"
1831 *
1832 * @test
1833 */
1834 public function getDataWithTypeDebugPage() {
1835 $uid = rand();
1836 $GLOBALS['TSFE']->page = array('uid' => $uid);
1837
1838 $expectedResult = 'uid' . $uid;
1839
1840 $result = $this->cObj->getData('debug:page');
1841 $cleanedResult = strip_tags($result);
1842 $cleanedResult = str_replace("\r", '', $cleanedResult);
1843 $cleanedResult = str_replace("\n", '', $cleanedResult);
1844 $cleanedResult = str_replace("\t", '', $cleanedResult);
1845 $cleanedResult = str_replace(' ', '', $cleanedResult);
1846
1847 $this->assertEquals($expectedResult, $cleanedResult);
1848 }
1849 }
1850
1851 ?>