[TASK] Shorten the extend class in all unit tests
[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 script belongs to the Extbase framework. *
6 * *
7 * It is free software; you can redistribute it and/or modify it under *
8 * the terms of the GNU Lesser General Public License as published by the *
9 * Free Software Foundation, either version 3 of the License, or (at your *
10 * option) any later version. *
11 * *
12 * This script is distributed in the hope that it will be useful, but *
13 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHAN- *
14 * TABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser *
15 * General Public License for more details. *
16 * *
17 * You should have received a copy of the GNU Lesser General Public *
18 * License along with the script. *
19 * If not, see http://www.gnu.org/licenses/lgpl.html *
20 * *
21 * The TYPO3 project - inspiring people to share! *
22 * */
23
24 use TYPO3\TestingFramework\Core\Unit\UnitTestCase;
25
26 /**
27 * Test case
28 */
29 class ArrayConverterTest extends UnitTestCase
30 {
31 /**
32 * @var \TYPO3\CMS\Extbase\Property\TypeConverter\ArrayConverter
33 */
34 protected $converter;
35
36 protected function setUp()
37 {
38 $this->converter = new \TYPO3\CMS\Extbase\Property\TypeConverter\ArrayConverter();
39 }
40
41 /**
42 * @test
43 */
44 public function checkMetadata()
45 {
46 $this->assertEquals(['array', 'string'], $this->converter->getSupportedSourceTypes(), 'Source types do not match');
47 $this->assertEquals('array', $this->converter->getSupportedTargetType(), 'Target type does not match');
48 $this->assertEquals(10, $this->converter->getPriority(), 'Priority does not match');
49 }
50
51 /**
52 * @test
53 */
54 public function convertFromDoesNotModifyTheSourceArray()
55 {
56 $sourceArray = ['Foo' => 'Bar', 'Baz'];
57 $this->assertEquals($sourceArray, $this->converter->convertFrom($sourceArray, 'array'));
58 }
59
60 /**
61 * @return array
62 */
63 public function stringToArrayDataProvider()
64 {
65 return [
66 'Empty string to empty array' => ['', []],
67 ];
68 }
69
70 /**
71 * @test
72 * @dataProvider stringToArrayDataProvider
73 *
74 * @param string $source
75 * @param array $expectedResult
76 */
77 public function canConvertFromEmptyString($source, $expectedResult)
78 {
79 $this->assertEquals($expectedResult, $this->converter->convertFrom($source, 'array'));
80 }
81
82 /**
83 * @return array
84 */
85 public function canConvertFromDataProvider()
86 {
87 return [
88 'Can convert empty string' => ['', true],
89 'Can not convert not empty string' => ['foo', false],
90 'Can convert array' => [['foo'], true],
91 ];
92 }
93
94 /**
95 * @test
96 * @dataProvider canConvertFromDataProvider
97 *
98 * @param mixed $source
99 * @param bool $expectedResult
100 */
101 public function canConvertFromReturnsCorrectBooleans($source, $expectedResult)
102 {
103 $this->assertSame($expectedResult, $this->converter->canConvertFrom($source, 'array'));
104 }
105 }