[TASK] Streamline phpdoc annotations in EXT:extbase
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Unit / Property / TypeConverter / ArrayConverterTest.php
1 <?php
2 namespace TYPO3\CMS\Extbase\Tests\Unit\Property\TypeConverter;
3
4 /*
5 * This file is part of the TYPO3 CMS project.
6 *
7 * It is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU General Public License, either version 2
9 * of the License, or any later version.
10 *
11 * For the full copyright and license information, please read the
12 * LICENSE.txt file that was distributed with this source code.
13 *
14 * The TYPO3 project - inspiring people to share!
15 */
16
17 use TYPO3\TestingFramework\Core\Unit\UnitTestCase;
18
19 /**
20 * Test case
21 */
22 class ArrayConverterTest extends UnitTestCase
23 {
24 /**
25 * @var \TYPO3\CMS\Extbase\Property\TypeConverter\ArrayConverter
26 */
27 protected $converter;
28
29 protected function setUp()
30 {
31 $this->converter = new \TYPO3\CMS\Extbase\Property\TypeConverter\ArrayConverter();
32 }
33
34 /**
35 * @test
36 */
37 public function checkMetadata()
38 {
39 $this->assertEquals(['array', 'string'], $this->converter->getSupportedSourceTypes(), 'Source types do not match');
40 $this->assertEquals('array', $this->converter->getSupportedTargetType(), 'Target type does not match');
41 $this->assertEquals(10, $this->converter->getPriority(), 'Priority does not match');
42 }
43
44 /**
45 * @test
46 */
47 public function convertFromDoesNotModifyTheSourceArray()
48 {
49 $sourceArray = ['Foo' => 'Bar', 'Baz'];
50 $this->assertEquals($sourceArray, $this->converter->convertFrom($sourceArray, 'array'));
51 }
52
53 /**
54 * @return array
55 */
56 public function stringToArrayDataProvider()
57 {
58 return [
59 'Empty string to empty array' => ['', []],
60 ];
61 }
62
63 /**
64 * @test
65 * @dataProvider stringToArrayDataProvider
66 *
67 * @param string $source
68 * @param array $expectedResult
69 */
70 public function canConvertFromEmptyString($source, $expectedResult)
71 {
72 $this->assertEquals($expectedResult, $this->converter->convertFrom($source, 'array'));
73 }
74
75 /**
76 * @return array
77 */
78 public function canConvertFromDataProvider()
79 {
80 return [
81 'Can convert empty string' => ['', true],
82 'Can not convert not empty string' => ['foo', false],
83 'Can convert array' => [['foo'], true],
84 ];
85 }
86
87 /**
88 * @test
89 * @dataProvider canConvertFromDataProvider
90 *
91 * @param mixed $source
92 * @param bool $expectedResult
93 */
94 public function canConvertFromReturnsCorrectBooleans($source, $expectedResult)
95 {
96 $this->assertSame($expectedResult, $this->converter->canConvertFrom($source, 'array'));
97 }
98 }