diff --git a/typo3/sysext/extbase/Classes/Persistence/Generic/Backend.php b/typo3/sysext/extbase/Classes/Persistence/Generic/Backend.php index db0f3107e640aa06f8b40da23ae40ba274fe28d3..46654d8050c2222093ccd3a6cb2e9fc46793a91b 100644 --- a/typo3/sysext/extbase/Classes/Persistence/Generic/Backend.php +++ b/typo3/sysext/extbase/Classes/Persistence/Generic/Backend.php @@ -691,7 +691,7 @@ class Backend implements \TYPO3\CMS\Extbase\Persistence\Generic\BackendInterface $row[$columnMap->getColumnName()] = 0; } } elseif ($propertyValue !== null) { - $row[$columnMap->getColumnName()] = $this->dataMapper->getPlainValue($propertyValue); + $row[$columnMap->getColumnName()] = $this->dataMapper->getPlainValue($propertyValue, $columnMap); } } $this->addCommonFieldsToRow($object, $row); diff --git a/typo3/sysext/extbase/Classes/Persistence/Generic/Mapper/DataMapper.php b/typo3/sysext/extbase/Classes/Persistence/Generic/Mapper/DataMapper.php index b99910eae99907d74264f55f96965b670dd6fa3d..e4e4ac13fd78b2795d5cbfb3b9b9a114b6e3e32b 100755 --- a/typo3/sysext/extbase/Classes/Persistence/Generic/Mapper/DataMapper.php +++ b/typo3/sysext/extbase/Classes/Persistence/Generic/Mapper/DataMapper.php @@ -698,12 +698,15 @@ class DataMapper implements \TYPO3\CMS\Core\SingletonInterface } elseif ($input instanceof \DateTime) { if (!is_null($columnMap) && !is_null($columnMap->getDateTimeStorageFormat())) { $storageFormat = $columnMap->getDateTimeStorageFormat(); + $timeZoneToStore = clone $input; + // set to UTC to store in database + $timeZoneToStore->setTimezone(new \DateTimeZone('UTC')); switch ($storageFormat) { case 'datetime': - $parameter = $input->format('Y-m-d H:i:s'); + $parameter = $timeZoneToStore->format('Y-m-d H:i:s'); break; case 'date': - $parameter = $input->format('Y-m-d'); + $parameter = $timeZoneToStore->format('Y-m-d'); break; default: throw new \InvalidArgumentException('Column map DateTime format "' . $storageFormat . '" is unknown. Allowed values are datetime or date.', 1395353470); diff --git a/typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example/Configuration/TCA/tx_blogexample_domain_model_comment.php b/typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example/Configuration/TCA/tx_blogexample_domain_model_comment.php index d668804bf9237f1b49c21d571517833cefe7bcdc..6ea7a3b03902d32b4921091799397a2f63cc4bbc 100644 --- a/typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example/Configuration/TCA/tx_blogexample_domain_model_comment.php +++ b/typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example/Configuration/TCA/tx_blogexample_domain_model_comment.php @@ -29,6 +29,7 @@ return array( 'label' => 'LLL:EXT:blog_example/Resources/Private/Language/locallang_db.xml:tx_blogexample_domain_model_comment.date', 'config' => array( 'type' => 'input', + 'dbType' => 'datetime', 'size' => 12, 'eval' => 'datetime, required', 'default' => time() diff --git a/typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example/ext_tables.sql b/typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example/ext_tables.sql index 67ef7cf09ae7384c4b145b4a7664636323df5800..0323d36081249afbe03478171af9ef84ae70f2b3 100644 --- a/typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example/ext_tables.sql +++ b/typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example/ext_tables.sql @@ -90,7 +90,7 @@ CREATE TABLE tx_blogexample_domain_model_comment ( post int(11) DEFAULT '0' NOT NULL, - date int(11) DEFAULT '0' NOT NULL, + date datetime, author varchar(255) DEFAULT '' NOT NULL, email varchar(255) DEFAULT '' NOT NULL, content text NOT NULL, diff --git a/typo3/sysext/extbase/Tests/Functional/Persistence/Generic/Mapper/DataMapperTest.php b/typo3/sysext/extbase/Tests/Functional/Persistence/Generic/Mapper/DataMapperTest.php new file mode 100644 index 0000000000000000000000000000000000000000..879cbbdcb98787be8034ef6fdfe552b896b64564 --- /dev/null +++ b/typo3/sysext/extbase/Tests/Functional/Persistence/Generic/Mapper/DataMapperTest.php @@ -0,0 +1,63 @@ +<?php +namespace TYPO3\CMS\Extbase\Tests\Functional\Persistence\Generic\Mapper; + +use ExtbaseTeam\BlogExample\Domain\Model\Comment; +use TYPO3\CMS\Core\Tests\FunctionalTestCase; +use TYPO3\CMS\Core\Utility\GeneralUtility; + + +class DataMapperTest extends FunctionalTestCase +{ + + /** + * @var \TYPO3\CMS\Extbase\Persistence\Generic\PersistenceManager + */ + protected $persistenceManager; + + /** + * @var array + */ + protected $testExtensionsToLoad = array('typo3/sysext/extbase/Tests/Functional/Fixtures/Extensions/blog_example'); + + /** + * @var array + */ + protected $coreExtensionsToLoad = array('extbase', 'fluid'); + + /** + * @var \TYPO3\CMS\Extbase\Object\ObjectManagerInterface The object manager + */ + protected $objectManager; + + + /** + * Sets up this test suite. + */ + protected function setUp() + { + parent::setUp(); + + $this->objectManager = GeneralUtility::makeInstance(\TYPO3\CMS\Extbase\Object\ObjectManager::class); + $this->persistenceManager = $this->objectManager->get(\TYPO3\CMS\Extbase\Persistence\Generic\PersistenceManager::class); + } + + /** + * @test + */ + public function datetimeObjectsCanBePersistedToDatetimeDatabaseFields() + { + $date = new \DateTime('2016-03-06T12:40:00+01:00'); + $comment = new Comment(); + $comment->setDate($date); + + $this->persistenceManager->add($comment); + $this->persistenceManager->persistAll(); + $uid = $this->persistenceManager->getIdentifierByObject($comment); + $this->persistenceManager->clearState(); + + /** @var Comment $existingComment */ + $existingComment = $this->persistenceManager->getObjectByIdentifier($uid, Comment::class); + + $this->assertEquals($date->getTimestamp(), $existingComment->getDate()->getTimestamp()); + } +}