diff --git a/typo3/sysext/backend/Classes/Domain/Repository/Localization/LocalizationRepository.php b/typo3/sysext/backend/Classes/Domain/Repository/Localization/LocalizationRepository.php index cc4142aab4a6299d7bfd611f4452dc0be2eb48ca..0d69f8a2521d64226dd44829650f442a0022b0af 100644 --- a/typo3/sysext/backend/Classes/Domain/Repository/Localization/LocalizationRepository.php +++ b/typo3/sysext/backend/Classes/Domain/Repository/Localization/LocalizationRepository.php @@ -66,7 +66,7 @@ class LocalizationRepository $queryBuilder->quoteIdentifier('tt_content_orig.uid') ) ) - ->join( + ->leftJoin( 'tt_content_orig', 'sys_language', 'sys_language', diff --git a/typo3/sysext/backend/Tests/Functional/Controller/Page/Fixtures/tt_content-danish-language.xml b/typo3/sysext/backend/Tests/Functional/Controller/Page/Fixtures/tt_content-danish-language.xml index 9c0879577cb4e065d4d09ee689ba0927b3fd2af1..6369d79ecd5315849fd8cdd313fca776eb0a4f75 100644 --- a/typo3/sysext/backend/Tests/Functional/Controller/Page/Fixtures/tt_content-danish-language.xml +++ b/typo3/sysext/backend/Tests/Functional/Controller/Page/Fixtures/tt_content-danish-language.xml @@ -5,6 +5,7 @@ <pid>1</pid> <sys_language_uid>1</sys_language_uid> <l18n_parent>1</l18n_parent> + <l10n_source>1</l10n_source> <deleted>0</deleted> <t3ver_oid>0</t3ver_oid> <t3ver_wsid>0</t3ver_wsid> @@ -17,6 +18,7 @@ <pid>1</pid> <sys_language_uid>1</sys_language_uid> <l18n_parent>2</l18n_parent> + <l10n_source>2</l10n_source> <deleted>0</deleted> <t3ver_oid>0</t3ver_oid> <t3ver_wsid>0</t3ver_wsid> @@ -29,6 +31,7 @@ <pid>1</pid> <sys_language_uid>1</sys_language_uid> <l18n_parent>3</l18n_parent> + <l10n_source>3</l10n_source> <deleted>0</deleted> <t3ver_oid>0</t3ver_oid> <t3ver_wsid>0</t3ver_wsid> diff --git a/typo3/sysext/backend/Tests/Functional/Controller/Page/LocalizationControllerTest.php b/typo3/sysext/backend/Tests/Functional/Controller/Page/LocalizationControllerTest.php index ef8b7891025ba013f3a0dc95a0352686531b90b1..6a7018d8386b998a9a41ca1b15a189266007a511 100644 --- a/typo3/sysext/backend/Tests/Functional/Controller/Page/LocalizationControllerTest.php +++ b/typo3/sysext/backend/Tests/Functional/Controller/Page/LocalizationControllerTest.php @@ -72,8 +72,7 @@ class LocalizationControllerTest extends \TYPO3\TestingFramework\Core\Functional $this->subject = $this->getMockBuilder(LocalizationController::class) ->setMethods(['getPageColumns']) - ->getMock() - ; + ->getMock(); } /** @@ -188,6 +187,38 @@ class LocalizationControllerTest extends \TYPO3\TestingFramework\Core\Functional $this->assertAssertionDataSet('CreatedElementOrdering'); } + /** + * @test + */ + public function defaultLanguageIsFoundAsOriginLanguage(): void + { + $this->importDataSet(ORIGINAL_ROOT . 'typo3/sysext/backend/Tests/Functional/Controller/Page/Fixtures/tt_content-danish-language.xml'); + + // Create another content element in default language + $data = [ + 'tt_content' => [ + 'NEW123456' => [ + 'sys_language_uid' => 0, + 'header' => 'New content element', + 'pid' => 1, + 'colPos' => 0, + ], + ], + ]; + $dataHandler = new DataHandler(); + $dataHandler->start($data, []); + $dataHandler->process_datamap(); + $dataHandler->process_cmdmap(); + + $request = (new ServerRequest())->withQueryParams([ + 'pageId' => 1, // page uid, the records are stored on + 'languageId' => 1 // current language id + ]); + + $usedLanguages = (string)$this->subject->getUsedLanguagesInPage($request)->getBody(); + $this->assertThat($usedLanguages, $this->stringContains('"uid":0')); + } + /** * @test */ diff --git a/typo3/sysext/backend/Tests/Functional/Domain/Repository/Localization/LocalizationRepositoryTest.php b/typo3/sysext/backend/Tests/Functional/Domain/Repository/Localization/LocalizationRepositoryTest.php index 9dbffed4f649cd95ef26d00aae1515fd48b8f9d0..c11a6044bf30fc875fd8752bde73f922ea7a1ed1 100644 --- a/typo3/sysext/backend/Tests/Functional/Domain/Repository/Localization/LocalizationRepositoryTest.php +++ b/typo3/sysext/backend/Tests/Functional/Domain/Repository/Localization/LocalizationRepositoryTest.php @@ -50,7 +50,7 @@ class LocalizationRepositoryTest extends \TYPO3\TestingFramework\Core\Functional public function fetchOriginLanguageDataProvider(): array { return [ - 'default language returns false' => [ + 'default language returns empty array' => [ 1, 0, [] @@ -58,7 +58,9 @@ class LocalizationRepositoryTest extends \TYPO3\TestingFramework\Core\Functional 'connected mode translated from default language' => [ 1, 1, - [] + [ + 'sys_language_uid' => 0 + ] ], 'connected mode translated from non default language' => [ 1, @@ -70,7 +72,9 @@ class LocalizationRepositoryTest extends \TYPO3\TestingFramework\Core\Functional 'free mode translated from default language' => [ 2, 1, - [] + [ + 'sys_language_uid' => 0 + ] ], 'free mode translated from non default language' => [ 2, @@ -82,7 +86,9 @@ class LocalizationRepositoryTest extends \TYPO3\TestingFramework\Core\Functional 'free mode copied from another page translated from default language' => [ 3, 1, - [] + [ + 'sys_language_uid' => 0 + ] ], 'free mode copied from another page translated from non default language' => [ 3,