[TASK] Streamline functional data handling tests
[Packages/TYPO3.CMS.git] / typo3 / sysext / core / Tests / Functional / DataHandling / FlexformIrre / ActionTest.php
1 <?php
2 namespace TYPO3\CMS\Core\Tests\Functional\DataHandling\FlexformIrre;
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\CMS\Core\Tests\Functional\DataHandling\AbstractDataHandlerActionTestCase;
18
19 class ActionTest extends AbstractDataHandlerActionTestCase
20 {
21 protected $coreExtensionsToLoad = [
22 'workspaces',
23 ];
24
25 /**
26 * @var array
27 */
28 protected $pathsToLinkInTestInstance = [
29 'typo3/sysext/core/Tests/Functional/DataHandling/FlexformIrre/Fixtures/fileadmin' => 'fileadmin/fixture',
30 ];
31
32 /**
33 * @var string
34 */
35 protected $scenarioDataSetDirectory = 'typo3/sysext/core/Tests/Functional/DataHandling/FlexformIrre/DataSet/';
36
37 /**
38 * @test
39 */
40 public function newVersionOfFileRelationInFlexformFieldIsCreatedOnSave()
41 {
42 $this->importScenarioDataSet('LiveDefaultPages');
43 $this->importScenarioDataSet('LiveDefaultElements');
44 $this->backendUser->workspace = 1;
45 $GLOBALS['BE_USER']->workspace = 1;
46 $this->getActionService()->modifyRecords(1, [
47 //'sys_file_reference' => ['uid' => 10, 'hidden' => 0],
48 'tt_content' => ['uid' => 100, 'header' => 'Content #1 (WS)']
49 ]);
50
51 // there should be one relation in the live WS and one in the draft WS pointing to the file field.
52 $queryBuilder = $this->getConnectionPool()
53 ->getQueryBuilderForTable('sys_file_reference');
54 $queryBuilder->getRestrictions()->removeAll();
55 $referenceCount = $queryBuilder
56 ->count('uid')
57 ->from('sys_file_reference')
58 ->where($queryBuilder->expr()->eq('uid_local', $queryBuilder->createNamedParameter(20, \PDO::PARAM_INT)))
59 ->execute()
60 ->fetchColumn(0);
61
62 $this->assertEquals(2, $referenceCount);
63 }
64 }