TYPO3 CMS  TYPO3_8-7
ArrayConverterTest.php
Go to the documentation of this file.
1 <?php
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 
27 class ArrayConverterTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCase
28 {
32  protected $converter;
33 
34  protected function setUp()
35  {
36  $this->converter = new \TYPO3\CMS\Extbase\Property\TypeConverter\ArrayConverter();
37  }
38 
42  public function checkMetadata()
43  {
44  $this->assertEquals(['array', 'string'], $this->converter->getSupportedSourceTypes(), 'Source types do not match');
45  $this->assertEquals('array', $this->converter->getSupportedTargetType(), 'Target type does not match');
46  $this->assertEquals(10, $this->converter->getPriority(), 'Priority does not match');
47  }
48 
53  {
54  $sourceArray = ['Foo' => 'Bar', 'Baz'];
55  $this->assertEquals($sourceArray, $this->converter->convertFrom($sourceArray, 'array'));
56  }
57 
61  public function stringToArrayDataProvider()
62  {
63  return [
64  'Empty string to empty array' => ['', []],
65  ];
66  }
67 
75  public function canConvertFromEmptyString($source, $expectedResult)
76  {
77  $this->assertEquals($expectedResult, $this->converter->convertFrom($source, 'array'));
78  }
79 
83  public function canConvertFromDataProvider()
84  {
85  return [
86  'Can convert empty string' => ['', true],
87  'Can not convert not empty string' => ['foo', false],
88  'Can convert array' => [['foo'], true],
89  ];
90  }
91 
99  public function canConvertFromReturnsCorrectBooleans($source, $expectedResult)
100  {
101  $this->assertSame($expectedResult, $this->converter->canConvertFrom($source, 'array'));
102  }
103 }