diff --git a/typo3/sysext/install/Classes/Controller/EnvironmentController.php b/typo3/sysext/install/Classes/Controller/EnvironmentController.php index 887b8655ba6ec95d7d1e07c4a66fb1d87635856d..12f6642d472cb0685cae6444fabde067902fc52c 100644 --- a/typo3/sysext/install/Classes/Controller/EnvironmentController.php +++ b/typo3/sysext/install/Classes/Controller/EnvironmentController.php @@ -171,6 +171,8 @@ class EnvironmentController extends AbstractController $permissionCheck = GeneralUtility::makeInstance(DefaultPermissionsCheck::class); + $view->assign('publicPath', Environment::getPublicPath()); + return new JsonResponse([ 'success' => true, 'errorStatus' => $errorQueue, @@ -297,7 +299,7 @@ class EnvironmentController extends AbstractController ExtensionManagementUtility::extPath('install') . 'Resources/Private/Font/vera.ttf', 'Testing true type' ); - $outputFile = PATH_site . 'typo3temp/assets/images/installTool-' . StringUtility::getUniqueId('createTrueTypeFontTestImage') . '.gif'; + $outputFile = Environment::getPublicPath() . '/typo3temp/assets/images/installTool-' . StringUtility::getUniqueId('createTrueTypeFontTestImage') . '.gif'; imagegif($image, $outputFile); $fileExists = file_exists($outputFile); if ($fileExists) { @@ -306,7 +308,7 @@ class EnvironmentController extends AbstractController return $this->getImageTestResponse([ 'fileExists' => $fileExists, 'outputFile' => $outputFile, - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Font.gif', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Font.gif', ]); } @@ -412,7 +414,7 @@ class EnvironmentController extends AbstractController 'status' => $messages, 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Write-gif.gif', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Write-gif.gif', 'command' => $imageProcessor->IM_commands, ]; } else { @@ -445,7 +447,7 @@ class EnvironmentController extends AbstractController $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Write-png.png', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Write-png.png', 'command' => $imageProcessor->IM_commands, ]; } else { @@ -478,7 +480,7 @@ class EnvironmentController extends AbstractController $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Scale-gif.gif', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Scale-gif.gif', 'command' => $imageProcessor->IM_commands, ]; } else { @@ -511,7 +513,7 @@ class EnvironmentController extends AbstractController $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Scale-png.png', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Scale-png.png', 'command' => $imageProcessor->IM_commands, ]; } else { @@ -544,7 +546,7 @@ class EnvironmentController extends AbstractController $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Scale-jpg.jpg', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Scale-jpg.jpg', 'command' => $imageProcessor->IM_commands, ]; } else { @@ -573,7 +575,7 @@ class EnvironmentController extends AbstractController $inputFile = $imageBasePath . 'TestInput/BackgroundOrange.gif'; $overlayFile = $imageBasePath . 'TestInput/Test.jpg'; $maskFile = $imageBasePath . 'TestInput/MaskBlackWhite.gif'; - $resultFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix + $resultFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId($imageProcessor->alternativeOutputKey . 'combine1') . '.jpg'; $imageProcessor->combineExec($inputFile, $overlayFile, $maskFile, $resultFile); $imResult = $imageProcessor->getImageDimensions($resultFile); @@ -581,7 +583,7 @@ class EnvironmentController extends AbstractController $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Combine-1.jpg', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Combine-1.jpg', 'command' => $imageProcessor->IM_commands, ]; } else { @@ -610,7 +612,7 @@ class EnvironmentController extends AbstractController $inputFile = $imageBasePath . 'TestInput/BackgroundCombine.jpg'; $overlayFile = $imageBasePath . 'TestInput/Test.jpg'; $maskFile = $imageBasePath . 'TestInput/MaskCombine.jpg'; - $resultFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix + $resultFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId($imageProcessor->alternativeOutputKey . 'combine2') . '.jpg'; $imageProcessor->combineExec($inputFile, $overlayFile, $maskFile, $resultFile); $imResult = $imageProcessor->getImageDimensions($resultFile); @@ -618,7 +620,7 @@ class EnvironmentController extends AbstractController $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Combine-2.jpg', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Combine-2.jpg', 'command' => $imageProcessor->IM_commands, ]; } else { @@ -648,13 +650,13 @@ class EnvironmentController extends AbstractController 'color' => 'olive', ]; $imageProcessor->makeBox($image, $conf, $workArea); - $outputFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdSimple') . '.' . $gifOrPng; + $outputFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdSimple') . '.' . $gifOrPng; $imageProcessor->ImageWrite($image, $outputFile); $imResult = $imageProcessor->getImageDimensions($outputFile); $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-simple.' . $gifOrPng, + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-simple.' . $gifOrPng, 'command' => $imageProcessor->IM_commands, ]; return $this->getImageTestResponse($result); @@ -678,13 +680,13 @@ class EnvironmentController extends AbstractController 'color' => 'olive', ]; $imageProcessor->makeBox($image, $conf, $workArea); - $outputFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdBox') . '.' . $gifOrPng; + $outputFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdBox') . '.' . $gifOrPng; $imageProcessor->ImageWrite($image, $outputFile); $imResult = $imageProcessor->getImageDimensions($outputFile); $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-box.' . $gifOrPng, + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-box.' . $gifOrPng, 'command' => $imageProcessor->IM_commands, ]; return $this->getImageTestResponse($result); @@ -715,13 +717,13 @@ class EnvironmentController extends AbstractController ]; $conf['BBOX'] = $imageProcessor->calcBBox($conf); $imageProcessor->makeText($image, $conf, $workArea); - $outputFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdText') . '.' . $gifOrPng; + $outputFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdText') . '.' . $gifOrPng; $imageProcessor->ImageWrite($image, $outputFile); $imResult = $imageProcessor->getImageDimensions($outputFile); $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-text.' . $gifOrPng, + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-text.' . $gifOrPng, 'command' => $imageProcessor->IM_commands, ]; return $this->getImageTestResponse($result); @@ -757,18 +759,18 @@ class EnvironmentController extends AbstractController ]; $conf['BBOX'] = $imageProcessor->calcBBox($conf); $imageProcessor->makeText($image, $conf, $workArea); - $outputFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdText') . '.' . $gifOrPng; + $outputFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdText') . '.' . $gifOrPng; $imageProcessor->ImageWrite($image, $outputFile); $conf['offset'] = '30,120'; $conf['niceText'] = 1; $imageProcessor->makeText($image, $conf, $workArea); - $outputFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdNiceText') . '.' . $gifOrPng; + $outputFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdNiceText') . '.' . $gifOrPng; $imageProcessor->ImageWrite($image, $outputFile); $imResult = $imageProcessor->getImageDimensions($outputFile); $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-niceText.' . $gifOrPng, + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-niceText.' . $gifOrPng, 'command' => $imageProcessor->IM_commands, ]; return $this->getImageTestResponse($result); @@ -804,12 +806,12 @@ class EnvironmentController extends AbstractController ]; $conf['BBOX'] = $imageProcessor->calcBBox($conf); $imageProcessor->makeText($image, $conf, $workArea); - $outputFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdText') . '.' . $gifOrPng; + $outputFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdText') . '.' . $gifOrPng; $imageProcessor->ImageWrite($image, $outputFile); $conf['offset'] = '30,120'; $conf['niceText'] = 1; $imageProcessor->makeText($image, $conf, $workArea); - $outputFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdNiceText') . '.' . $gifOrPng; + $outputFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('gdNiceText') . '.' . $gifOrPng; $imageProcessor->ImageWrite($image, $outputFile); $conf['offset'] = '30,160'; $conf['niceText'] = 1; @@ -822,13 +824,13 @@ class EnvironmentController extends AbstractController // Warning: Re-uses $image from above! $imageProcessor->makeShadow($image, $conf['shadow.'], $workArea, $conf); $imageProcessor->makeText($image, $conf, $workArea); - $outputFile = $this->getImagesPath($imageProcessor) . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('GDwithText-niceText-shadow') . '.' . $gifOrPng; + $outputFile = $this->getImagesPath() . $imageProcessor->filenamePrefix . StringUtility::getUniqueId('GDwithText-niceText-shadow') . '.' . $gifOrPng; $imageProcessor->ImageWrite($image, $outputFile); $imResult = $imageProcessor->getImageDimensions($outputFile); $result = [ 'fileExists' => true, 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-shadow.' . $gifOrPng, + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Gdlib-shadow.' . $gifOrPng, 'command' => $imageProcessor->IM_commands, ]; return $this->getImageTestResponse($result); @@ -903,7 +905,7 @@ class EnvironmentController extends AbstractController $result = [ 'fileExists' => file_exists($imResult[3]), 'outputFile' => $imResult[3], - 'referenceFile' => PATH_site . 'typo3/sysext/install/Resources/Public/Images/TestReference/Read-' . $inputFormat . '.jpg', + 'referenceFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Public/Images/TestReference/Read-' . $inputFormat . '.jpg', 'command' => $imageProcessor->IM_commands, ]; } else { @@ -1066,12 +1068,11 @@ class EnvironmentController extends AbstractController * Return the temp image dir. * If not exist it will be created * - * @param GraphicalFunctions $imageProcessor * @return string */ - protected function getImagesPath(GraphicalFunctions $imageProcessor): string + protected function getImagesPath(): string { - $imagePath = PATH_site . 'typo3temp/assets/images/'; + $imagePath = Environment::getPublicPath() . '/typo3temp/assets/images/'; if (!is_dir($imagePath)) { GeneralUtility::mkdir_deep($imagePath); } diff --git a/typo3/sysext/install/Classes/Controller/UpgradeController.php b/typo3/sysext/install/Classes/Controller/UpgradeController.php index a1e55501b5ea6ed67f6bf062070ad8b209434e94..f76567433a1fa5fa665231688ed4243dccd72868 100644 --- a/typo3/sysext/install/Classes/Controller/UpgradeController.php +++ b/typo3/sysext/install/Classes/Controller/UpgradeController.php @@ -181,7 +181,7 @@ class UpgradeController extends AbstractController 'coreUpdateEnabled' => $coreUpdateService->isCoreUpdateEnabled(), 'coreUpdateComposerMode' => Environment::isComposerMode(), 'coreUpdateIsReleasedVersion' => $coreVersionService->isInstalledVersionAReleasedVersion(), - 'coreUpdateIsSymLinkedCore' => is_link(PATH_site . 'typo3_src'), + 'coreUpdateIsSymLinkedCore' => is_link(Environment::getPublicPath() . '/typo3_src'), 'upgradeWizardsMarkUndoneToken' => $formProtection->generateToken('installTool', 'upgradeWizardsMarkUndone'), 'upgradeWizardsInputToken' => $formProtection->generateToken('installTool', 'upgradeWizardsInput'), @@ -474,7 +474,7 @@ class UpgradeController extends AbstractController */ public function extensionScannerGetDataAction(ServerRequestInterface $request): ResponseInterface { - $extensionsInTypo3conf = (new Finder())->directories()->in(PATH_site . 'typo3conf/ext')->depth(0)->sortByName(); + $extensionsInTypo3conf = (new Finder())->directories()->in(Environment::getPublicPath() . '/typo3conf/ext')->depth(0)->sortByName(); $view = $this->initializeStandaloneView($request, 'Upgrade/ExtensionScanner.html'); $formProtection = FormProtectionFactory::get(InstallToolFormProtection::class); $view->assignMultiple([ @@ -499,7 +499,7 @@ class UpgradeController extends AbstractController { // Get and validate path $extension = $request->getParsedBody()['install']['extension']; - $extensionBasePath = PATH_site . 'typo3conf/ext/' . $extension; + $extensionBasePath = Environment::getPublicPath() . '/typo3conf/ext/' . $extension; if (empty($extension) || !GeneralUtility::isAllowedAbsPath($extensionBasePath)) { throw new \RuntimeException( 'Path to extension ' . $extension . ' not allowed.', @@ -583,7 +583,7 @@ class UpgradeController extends AbstractController { // Get and validate path and file $extension = $request->getParsedBody()['install']['extension']; - $extensionBasePath = PATH_site . 'typo3conf/ext/' . $extension; + $extensionBasePath = Environment::getPublicPath() . '/typo3conf/ext/' . $extension; if (empty($extension) || !GeneralUtility::isAllowedAbsPath($extensionBasePath)) { throw new \RuntimeException( 'Path to extension ' . $extension . ' not allowed.', diff --git a/typo3/sysext/install/Classes/FolderStructure/AbstractNode.php b/typo3/sysext/install/Classes/FolderStructure/AbstractNode.php index 80644031e07dbd0c97a1f37b1dba78f540a81e1c..75059e1f873d0d80517a45d9a5082129883da885 100644 --- a/typo3/sysext/install/Classes/FolderStructure/AbstractNode.php +++ b/typo3/sysext/install/Classes/FolderStructure/AbstractNode.php @@ -199,7 +199,7 @@ abstract class AbstractNode } /** - * Cut off PATH_site from given path + * Cut off public web path from given path * * @param string $path Given path * @return string Relative path, but beginning with / @@ -210,14 +210,14 @@ abstract class AbstractNode if ($path === null) { $path = $this->getAbsolutePath(); } - $pathSiteWithoutTrailingSlash = substr(PATH_site, 0, -1); - if (strpos($path, $pathSiteWithoutTrailingSlash, 0) !== 0) { + $publicPath = Environment::getPublicPath(); + if (strpos($path, $publicPath, 0) !== 0) { throw new Exception\InvalidArgumentException( - 'PATH_site is not first part of given path', + 'Public path is not first part of given path', 1366398198 ); } - $relativePath = substr($path, strlen($pathSiteWithoutTrailingSlash), strlen($path)); + $relativePath = substr($path, strlen($publicPath), strlen($path)); // Add a forward slash again, so we don't end up with an empty string if ($relativePath === '') { $relativePath = '/'; diff --git a/typo3/sysext/install/Classes/FolderStructure/DefaultFactory.php b/typo3/sysext/install/Classes/FolderStructure/DefaultFactory.php index daa9c46a3455f5806f28404ea665e1a3c009a754..59d56d70974862cbc1b03e3c3ba9d98bfa65bec2 100644 --- a/typo3/sysext/install/Classes/FolderStructure/DefaultFactory.php +++ b/typo3/sysext/install/Classes/FolderStructure/DefaultFactory.php @@ -14,6 +14,8 @@ namespace TYPO3\CMS\Install\FolderStructure; * The TYPO3 project - inspiring people to share! */ +use TYPO3\CMS\Core\Core\Environment; + /** * Factory returns default folder structure object hierarchy */ @@ -43,8 +45,8 @@ class DefaultFactory $directoryPermission = $GLOBALS['TYPO3_CONF_VARS']['SYS']['folderCreateMask']; return [ - // Cut off trailing forward / from PATH_site, so root node has no trailing slash like all others - 'name' => substr(PATH_site, 0, -1), + // Note that root node has no trailing slash like all others + 'name' => Environment::getPublicPath(), 'targetPermission' => $directoryPermission, 'children' => [ [ @@ -99,7 +101,7 @@ class DefaultFactory 'name' => '.htaccess', 'type' => FileNode::class, 'targetPermission' => $filePermission, - 'targetContentFile' => PATH_site . 'typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/typo3temp-var-htaccess', + 'targetContentFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/typo3temp-var-htaccess', ], [ 'name' => 'charset', @@ -151,13 +153,13 @@ class DefaultFactory 'name' => '.htaccess', 'type' => FileNode::class, 'targetPermission' => $filePermission, - 'targetContentFile' => PATH_site . 'typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/fileadmin-temp-htaccess', + 'targetContentFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/fileadmin-temp-htaccess', ], [ 'name' => 'index.html', 'type' => FileNode::class, 'targetPermission' => $filePermission, - 'targetContentFile' => PATH_site . 'typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/fileadmin-temp-index.html', + 'targetContentFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/fileadmin-temp-index.html', ], ], ], @@ -186,13 +188,13 @@ class DefaultFactory 'name' => '.htaccess', 'type' => FileNode::class, 'targetPermission' => $filePermission, - 'targetContentFile' => PATH_site . 'typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/fileadmin-user_upload-temp-importexport-htaccess', + 'targetContentFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/fileadmin-user_upload-temp-importexport-htaccess', ], [ 'name' => 'index.html', 'type' => FileNode::class, 'targetPermission' => $filePermission, - 'targetContentFile' => PATH_site . 'typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/fileadmin-temp-index.html', + 'targetContentFile' => Environment::getPublicPath() . '/typo3/sysext/install/Resources/Private/FolderStructureTemplateFiles/fileadmin-temp-index.html', ], ], ], diff --git a/typo3/sysext/install/Classes/Report/SecurityStatusReport.php b/typo3/sysext/install/Classes/Report/SecurityStatusReport.php index e7901e1901e52e4ec294090432ed9e46c99724a4..06a5af062f137bcd6235759986833bb9962aaa73 100644 --- a/typo3/sysext/install/Classes/Report/SecurityStatusReport.php +++ b/typo3/sysext/install/Classes/Report/SecurityStatusReport.php @@ -14,6 +14,7 @@ namespace TYPO3\CMS\Install\Report; * The TYPO3 project - inspiring people to share! */ +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Utility\GeneralUtility; use TYPO3\CMS\Install\Service\EnableFileService; use TYPO3\CMS\Reports\Status; @@ -83,7 +84,7 @@ class SecurityStatusReport implements \TYPO3\CMS\Reports\StatusProviderInterface */ protected function getInstallToolProtectionStatus() { - $enableInstallToolFile = PATH_site . EnableFileService::INSTALL_TOOL_ENABLE_FILE_PATH; + $enableInstallToolFile = Environment::getPublicPath() . '/' . EnableFileService::INSTALL_TOOL_ENABLE_FILE_PATH; $value = $GLOBALS['LANG']->getLL('status_disabled'); $message = ''; $severity = Status::OK; diff --git a/typo3/sysext/install/Classes/Service/CoreUpdateService.php b/typo3/sysext/install/Classes/Service/CoreUpdateService.php index 37e90e5d4a72516cfa7eaec248600eecf2964ab9..3ef68094033f793308bb5462632bb88e11df5dcd 100644 --- a/typo3/sysext/install/Classes/Service/CoreUpdateService.php +++ b/typo3/sysext/install/Classes/Service/CoreUpdateService.php @@ -97,7 +97,7 @@ class CoreUpdateService */ protected function discoverCurrentCoreSymlink() { - return PATH_site . 'typo3_src'; + return Environment::getPublicPath() . '/typo3_src'; } /** @@ -166,7 +166,7 @@ class CoreUpdateService $folderStructureMessageQueue = $folderStructureFacade->getStatus(); $folderStructureErrors = $folderStructureMessageQueue->getAllMessages(FlashMessage::ERROR); $folderStructureWarnings = $folderStructureMessageQueue->getAllMessages(FlashMessage::WARNING); - if (!empty($folderStructureErrors) || !empty($folderStructureWarnings) || !is_link(PATH_site . 'typo3_src')) { + if (!empty($folderStructureErrors) || !empty($folderStructureWarnings) || !is_link(Environment::getPublicPath() . '/typo3_src')) { $success = false; $this->messages->enqueue(new FlashMessage( 'To perform an update, the folder structure of this TYPO3 CMS instance must' @@ -189,12 +189,12 @@ class CoreUpdateService if ($success) { // Explicit write check to document root - $file = PATH_site . StringUtility::getUniqueId('install-core-update-test-'); + $file = Environment::getPublicPath() . '/' . StringUtility::getUniqueId('install-core-update-test-'); $result = @touch($file); if (!$result) { $success = false; $this->messages->enqueue(new FlashMessage( - 'Could not write a file in path "' . PATH_site . '"!', + 'Could not write a file in path "' . Environment::getPublicPath() . '/"!', 'Automatic TYPO3 CMS core update not possible: No write access to document root', FlashMessage::ERROR )); @@ -519,7 +519,7 @@ class CoreUpdateService */ protected function getRelativePath($absolutePath) { - $sourcePath = explode(DIRECTORY_SEPARATOR, rtrim(PATH_site, DIRECTORY_SEPARATOR)); + $sourcePath = explode(DIRECTORY_SEPARATOR, Environment::getPublicPath()); $targetPath = explode(DIRECTORY_SEPARATOR, rtrim($absolutePath, DIRECTORY_SEPARATOR)); while (count($sourcePath) && count($targetPath) && $sourcePath[0] === $targetPath[0]) { array_shift($sourcePath); diff --git a/typo3/sysext/install/Classes/Service/EnableFileService.php b/typo3/sysext/install/Classes/Service/EnableFileService.php index b387f9f707585ccd4c472a5fb4a8e829981005f3..8f0be4a765fc31fc87c7439e541f0b1f996b9e11 100644 --- a/typo3/sysext/install/Classes/Service/EnableFileService.php +++ b/typo3/sysext/install/Classes/Service/EnableFileService.php @@ -13,6 +13,7 @@ namespace TYPO3\CMS\Install\Service; * * The TYPO3 project - inspiring people to share! */ +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Utility\GeneralUtility; /** @@ -35,13 +36,6 @@ class EnableFileService */ const INSTALL_TOOL_ENABLE_FILE_LIFETIME = 3600; - /** - * Path site property, needed for unit testing - * - * @var string - */ - protected static $sitePath = PATH_site; - /** * @return bool */ @@ -92,7 +86,7 @@ class EnableFileService $result = true; $files = self::getFirstInstallFilePaths(); foreach ($files as $file) { - $result = unlink(self::$sitePath . $file) && $result; + $result = unlink(Environment::getPublicPath() . '/' . $file) && $result; } return $result; } @@ -181,7 +175,7 @@ class EnableFileService */ protected static function getInstallToolEnableFilePath() { - return PATH_site . self::INSTALL_TOOL_ENABLE_FILE_PATH; + return Environment::getPublicPath() . '/' . self::INSTALL_TOOL_ENABLE_FILE_PATH; } /** @@ -191,8 +185,8 @@ class EnableFileService */ protected static function getFirstInstallFilePaths() { - $files = array_filter(scandir(self::$sitePath), function ($file) { - return @is_file(self::$sitePath . $file) && preg_match('~^' . self::FIRST_INSTALL_FILE_PATH . '.*~i', $file); + $files = array_filter(scandir(Environment::getPublicPath() . '/'), function ($file) { + return @is_file(Environment::getPublicPath() . '/' . $file) && preg_match('~^' . self::FIRST_INSTALL_FILE_PATH . '.*~i', $file); }); return $files; } diff --git a/typo3/sysext/install/Classes/Service/Typo3tempFileService.php b/typo3/sysext/install/Classes/Service/Typo3tempFileService.php index 23e3838f062246a9230f3fd130c04c67915650c7..458bcf47e4ede348438b6143034f4ac9bb20de13 100644 --- a/typo3/sysext/install/Classes/Service/Typo3tempFileService.php +++ b/typo3/sysext/install/Classes/Service/Typo3tempFileService.php @@ -16,6 +16,7 @@ namespace TYPO3\CMS\Install\Service; use Symfony\Component\Finder\Finder; use Symfony\Component\Finder\SplFileInfo; +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Resource\ProcessedFileRepository; use TYPO3\CMS\Core\Utility\GeneralUtility; @@ -31,7 +32,7 @@ class Typo3tempFileService */ public function getDirectoryStatistics() { - $basePath = PATH_site . 'typo3temp/assets'; + $basePath = Environment::getPublicPath() . '/typo3temp/assets'; if (!is_dir($basePath)) { return []; } @@ -74,7 +75,7 @@ class Typo3tempFileService */ public function clearAssetsFolder(string $folderName) { - $basePath = PATH_site . 'typo3temp/assets/' . $folderName; + $basePath = Environment::getPublicPath() . '/typo3temp/assets/' . $folderName; if (empty($folderName) || !GeneralUtility::isAllowedAbsPath($basePath)) { throw new \RuntimeException( 'Path to folder ' . $folderName . ' not allowed.', diff --git a/typo3/sysext/install/Classes/Updates/BackendLayoutIconUpdateWizard.php b/typo3/sysext/install/Classes/Updates/BackendLayoutIconUpdateWizard.php index 537965ce7e84418df6292355939107b3cdcbcb34..5cf9a0f0b32d8b93f3b9cbb70064c6e537f1ad18 100644 --- a/typo3/sysext/install/Classes/Updates/BackendLayoutIconUpdateWizard.php +++ b/typo3/sysext/install/Classes/Updates/BackendLayoutIconUpdateWizard.php @@ -15,6 +15,7 @@ namespace TYPO3\CMS\Install\Updates; * The TYPO3 project - inspiring people to share! */ use Doctrine\DBAL\DBALException; +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Database\ConnectionPool; use TYPO3\CMS\Core\Database\Query\Expression\ExpressionBuilder; use TYPO3\CMS\Core\Log\Logger; @@ -206,8 +207,8 @@ class BackendLayoutIconUpdateWizard extends AbstractUpdate foreach ($fieldItems as $item) { $fileUid = null; - $sourcePath = PATH_site . $this->sourcePath . $item; - $targetDirectory = PATH_site . $fileadminDirectory . $this->targetPath; + $sourcePath = Environment::getPublicPath() . '/' . $this->sourcePath . $item; + $targetDirectory = Environment::getPublicPath() . '/' . $fileadminDirectory . $this->targetPath; $targetPath = $targetDirectory . PathUtility::basenameDuringBootstrap($item); // maybe the file was already moved, so check if the original file still exists diff --git a/typo3/sysext/install/Classes/Updates/FrontendUserImageUpdateWizard.php b/typo3/sysext/install/Classes/Updates/FrontendUserImageUpdateWizard.php index eb1aef6a3d0d4e1ee8cab30fef6f58cb6416e8b9..2b2ff8167d388b06e5193b967bb455a496f69eaf 100644 --- a/typo3/sysext/install/Classes/Updates/FrontendUserImageUpdateWizard.php +++ b/typo3/sysext/install/Classes/Updates/FrontendUserImageUpdateWizard.php @@ -14,6 +14,7 @@ namespace TYPO3\CMS\Install\Updates; * The TYPO3 project - inspiring people to share! */ use Doctrine\DBAL\DBALException; +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Database\ConnectionPool; use TYPO3\CMS\Core\Database\Query\Expression\ExpressionBuilder; use TYPO3\CMS\Core\Database\Query\Restriction\DeletedRestriction; @@ -242,18 +243,14 @@ class FrontendUserImageUpdateWizard extends AbstractUpdate $fileadminDirectory = rtrim($GLOBALS['TYPO3_CONF_VARS']['BE']['fileadminDir'], '/') . '/'; $i = 0; - if (!PATH_site) { - throw new \Exception('PATH_site was undefined.', 1476107387); - } - $storageUid = (int)$this->storage->getUid(); $connectionPool = GeneralUtility::makeInstance(ConnectionPool::class); foreach ($fieldItems as $item) { $fileUid = null; - $sourcePath = PATH_site . $this->sourcePath . $item; - $targetDirectory = PATH_site . $fileadminDirectory . $this->targetPath; + $sourcePath = Environment::getPublicPath() . '/' . $this->sourcePath . $item; + $targetDirectory = Environment::getPublicPath() . '/' . $fileadminDirectory . $this->targetPath; $targetPath = $targetDirectory . PathUtility::basename($item); // maybe the file was already moved, so check if the original file still exists diff --git a/typo3/sysext/install/Resources/Private/Templates/Environment/FolderStructure.html b/typo3/sysext/install/Resources/Private/Templates/Environment/FolderStructure.html index 193e61a55d129b8464997cebc407e52e821684a9..3e25dcfba6bb95beb11b236ac422916fd5adef90 100644 --- a/typo3/sysext/install/Resources/Private/Templates/Environment/FolderStructure.html +++ b/typo3/sysext/install/Resources/Private/Templates/Environment/FolderStructure.html @@ -1,6 +1,5 @@ -{namespace i=TYPO3\CMS\Install\ViewHelpers} <p> - Root Directory: <strong><i:constant name="PATH_site"/></strong> + Root Directory: <strong>{publicPath}</strong> </p> <div class="t3js-folderStructure-output"></div> diff --git a/typo3/sysext/install/Tests/Unit/FolderStructure/AbstractNodeTest.php b/typo3/sysext/install/Tests/Unit/FolderStructure/AbstractNodeTest.php index af7ce6961255e6c33b5c7f5c182cd09d38e43846..7081ed4081110afd1f9c662aa62ff2c526a68663 100644 --- a/typo3/sysext/install/Tests/Unit/FolderStructure/AbstractNodeTest.php +++ b/typo3/sysext/install/Tests/Unit/FolderStructure/AbstractNodeTest.php @@ -14,6 +14,7 @@ namespace TYPO3\CMS\Install\Tests\Unit\FolderStructure; * The TYPO3 project - inspiring people to share! */ +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Messaging\FlashMessage; use TYPO3\CMS\Install\FolderStructure\AbstractNode; use TYPO3\CMS\Install\FolderStructure\Exception; @@ -136,8 +137,8 @@ class AbstractNodeTest extends FolderStructureTestCase { /** @var $node AbstractNode|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ $node = $this->getAccessibleMock(AbstractNode::class, ['getAbsolutePath'], [], '', false); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('link_'); - $target = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('notExists_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('link_'); + $target = Environment::getVarPath() . '/tests/' . $this->getUniqueId('notExists_'); touch($target); symlink($target, $path); unlink($target); @@ -338,7 +339,7 @@ class AbstractNodeTest extends FolderStructureTestCase '', false ); - $node->expects($this->once())->method('getAbsolutePath')->will($this->returnValue(PATH_site)); + $node->expects($this->once())->method('getAbsolutePath')->will($this->returnValue(Environment::getPublicPath())); $node->_call('getRelativePathBelowSiteRoot', null); } @@ -349,7 +350,7 @@ class AbstractNodeTest extends FolderStructureTestCase { /** @var $node AbstractNode|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ $node = $this->getAccessibleMock(AbstractNode::class, ['dummy'], [], '', false); - $result = $node->_call('getRelativePathBelowSiteRoot', PATH_site); + $result = $node->_call('getRelativePathBelowSiteRoot', Environment::getPublicPath() . '/'); $this->assertSame('/', $result); } @@ -360,7 +361,7 @@ class AbstractNodeTest extends FolderStructureTestCase { /** @var $node AbstractNode|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ $node = $this->getAccessibleMock(AbstractNode::class, ['dummy'], [], '', false); - $result = $node->_call('getRelativePathBelowSiteRoot', PATH_site . 'foo/bar'); + $result = $node->_call('getRelativePathBelowSiteRoot', Environment::getPublicPath() . '/foo/bar'); $this->assertSame('/foo/bar', $result); } } diff --git a/typo3/sysext/install/Tests/Unit/FolderStructure/DirectoryNodeTest.php b/typo3/sysext/install/Tests/Unit/FolderStructure/DirectoryNodeTest.php index b163ac6cfaa740d3fce21e2a1577a0cc86f6d74b..4cd16c21bfb4b99035889fa1b869c05a386c0489 100644 --- a/typo3/sysext/install/Tests/Unit/FolderStructure/DirectoryNodeTest.php +++ b/typo3/sysext/install/Tests/Unit/FolderStructure/DirectoryNodeTest.php @@ -14,6 +14,7 @@ namespace TYPO3\CMS\Install\Tests\Unit\FolderStructure; * The TYPO3 project - inspiring people to share! */ +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Messaging\FlashMessage; use TYPO3\CMS\Install\FolderStructure\DirectoryNode; use TYPO3\CMS\Install\FolderStructure\Exception; @@ -631,7 +632,7 @@ class DirectoryNodeTest extends FolderStructureTestCase { /** @var $node DirectoryNode|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ $node = $this->getAccessibleMock(DirectoryNode::class, ['getAbsolutePath'], [], '', false); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('root_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('root_'); \TYPO3\CMS\Core\Utility\GeneralUtility::mkdir_deep($path); $this->testFilesToDelete[] = $path; $link = $this->getUniqueId('link_'); diff --git a/typo3/sysext/install/Tests/Unit/FolderStructure/FileNodeTest.php b/typo3/sysext/install/Tests/Unit/FolderStructure/FileNodeTest.php index b1a2f70b7498152ec9a30e38aaacfb904ceacbb5..7172e8884e92388ba9b1200704e41bd56909ccbb 100644 --- a/typo3/sysext/install/Tests/Unit/FolderStructure/FileNodeTest.php +++ b/typo3/sysext/install/Tests/Unit/FolderStructure/FileNodeTest.php @@ -14,6 +14,7 @@ namespace TYPO3\CMS\Install\Tests\Unit\FolderStructure; * The TYPO3 project - inspiring people to share! */ +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Messaging\FlashMessage; use TYPO3\CMS\Install\FolderStructure\Exception; use TYPO3\CMS\Install\FolderStructure\Exception\InvalidArgumentException; @@ -199,7 +200,7 @@ class FileNodeTest extends FolderStructureTestCase '', false ); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('dir_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('dir_'); $node->expects($this->any())->method('getAbsolutePath')->will($this->returnValue($path)); $node->expects($this->any())->method('exists')->will($this->returnValue(true)); $node->expects($this->any())->method('isFile')->will($this->returnValue(true)); @@ -776,7 +777,7 @@ class FileNodeTest extends FolderStructureTestCase { /** @var $node FileNode|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ $node = $this->getAccessibleMock(FileNode::class, ['getAbsolutePath'], [], '', false); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('root_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('root_'); \TYPO3\CMS\Core\Utility\GeneralUtility::mkdir_deep($path); $this->testFilesToDelete[] = $path; $link = $this->getUniqueId('link_'); diff --git a/typo3/sysext/install/Tests/Unit/FolderStructure/LinkNodeTest.php b/typo3/sysext/install/Tests/Unit/FolderStructure/LinkNodeTest.php index 6fe092c2954c024dbc2a7f739997977fc429ce20..7f9bf95469c92d881bac34b2982dfc483201ef80 100644 --- a/typo3/sysext/install/Tests/Unit/FolderStructure/LinkNodeTest.php +++ b/typo3/sysext/install/Tests/Unit/FolderStructure/LinkNodeTest.php @@ -15,6 +15,7 @@ namespace TYPO3\CMS\Install\Tests\Unit\FolderStructure; * The TYPO3 project - inspiring people to share! */ +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Messaging\FlashMessage; use TYPO3\CMS\Install\FolderStructure\Exception\InvalidArgumentException; use TYPO3\CMS\Install\FolderStructure\LinkNode; @@ -111,7 +112,7 @@ class LinkNodeTest extends UnitTestCase '', false ); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('dir_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('dir_'); $node->expects($this->any())->method('getAbsolutePath')->will($this->returnValue($path)); $this->assertInternalType('array', $node->getStatus()); } @@ -129,7 +130,7 @@ class LinkNodeTest extends UnitTestCase '', false ); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('dir_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('dir_'); $node->expects($this->any())->method('getAbsolutePath')->will($this->returnValue($path)); $node->expects($this->once())->method('isWindowsOs')->will($this->returnValue(true)); $statusArray = $node->getStatus(); @@ -149,7 +150,7 @@ class LinkNodeTest extends UnitTestCase '', false ); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('dir_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('dir_'); $node->expects($this->any())->method('getAbsolutePath')->will($this->returnValue($path)); $node->expects($this->any())->method('isWindowsOs')->will($this->returnValue(false)); $node->expects($this->once())->method('exists')->will($this->returnValue(false)); @@ -258,8 +259,8 @@ class LinkNodeTest extends UnitTestCase { /** @var $node LinkNode|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ $node = $this->getAccessibleMock(LinkNode::class, ['exists', 'getAbsolutePath'], [], '', false); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('link_'); - $target = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('linkTarget_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('link_'); + $target = Environment::getVarPath() . '/tests/' . $this->getUniqueId('linkTarget_'); touch($target); symlink($target, $path); $this->testFilesToDelete[] = $path; @@ -276,7 +277,7 @@ class LinkNodeTest extends UnitTestCase { /** @var $node LinkNode|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ $node = $this->getAccessibleMock(LinkNode::class, ['exists', 'getAbsolutePath'], [], '', false); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('file_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('file_'); touch($path); $this->testFilesToDelete[] = $path; $node->expects($this->any())->method('exists')->will($this->returnValue(true)); @@ -344,8 +345,8 @@ class LinkNodeTest extends UnitTestCase */ public function isTargetCorrectReturnsTrueIfActualTargetIsIdenticalToSpecifiedTarget() { - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('link_'); - $target = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('linkTarget_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('link_'); + $target = Environment::getVarPath() . '/tests/' . $this->getUniqueId('linkTarget_'); touch($target); symlink($target, $path); $this->testFilesToDelete[] = $path; @@ -371,8 +372,8 @@ class LinkNodeTest extends UnitTestCase */ public function isTargetCorrectReturnsFalseIfActualTargetIsNotIdenticalToSpecifiedTarget() { - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('link_'); - $target = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('linkTarget_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('link_'); + $target = Environment::getVarPath() . '/tests/' . $this->getUniqueId('linkTarget_'); touch($target); symlink($target, $path); $this->testFilesToDelete[] = $path; diff --git a/typo3/sysext/install/Tests/Unit/FolderStructure/RootNodeTest.php b/typo3/sysext/install/Tests/Unit/FolderStructure/RootNodeTest.php index 9ed9a944d46678771d3c258a56c0ae70838f30be..3b518b7552248540b5d5edd2d0f3ffce293616a9 100644 --- a/typo3/sysext/install/Tests/Unit/FolderStructure/RootNodeTest.php +++ b/typo3/sysext/install/Tests/Unit/FolderStructure/RootNodeTest.php @@ -14,6 +14,7 @@ namespace TYPO3\CMS\Install\Tests\Unit\FolderStructure; * The TYPO3 project - inspiring people to share! */ +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Core\Messaging\FlashMessage; use TYPO3\CMS\Install\FolderStructure\DirectoryNode; use TYPO3\CMS\Install\FolderStructure\Exception\InvalidArgumentException; @@ -189,7 +190,7 @@ class RootNodeTest extends UnitTestCase '', false ); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('dir_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('dir_'); touch($path); $this->testFilesToDelete[] = $path; $node->expects($this->any())->method('getAbsolutePath')->will($this->returnValue($path)); @@ -214,7 +215,7 @@ class RootNodeTest extends UnitTestCase '', false ); - $path = PATH_site . 'typo3temp/var/tests/' . $this->getUniqueId('dir_'); + $path = Environment::getVarPath() . '/tests/' . $this->getUniqueId('dir_'); touch($path); $this->testFilesToDelete[] = $path; $node->expects($this->any())->method('getAbsolutePath')->will($this->returnValue($path)); diff --git a/typo3/sysext/install/Tests/Unit/Service/EnableFileServiceTest.php b/typo3/sysext/install/Tests/Unit/Service/EnableFileServiceTest.php index fe78655be2a38ce686aee8113970456f7ef80c83..afcfcf70183fbdf41677096d2158304791723eaa 100644 --- a/typo3/sysext/install/Tests/Unit/Service/EnableFileServiceTest.php +++ b/typo3/sysext/install/Tests/Unit/Service/EnableFileServiceTest.php @@ -15,13 +15,21 @@ namespace TYPO3\CMS\Install\Tests\Unit\Service; */ use org\bovigo\vfs\vfsStream; +use TYPO3\CMS\Core\Core\Environment; use TYPO3\CMS\Install\Service\EnableFileService; +use TYPO3\TestingFramework\Core\AccessibleObjectInterface; +use TYPO3\TestingFramework\Core\Unit\UnitTestCase; /** * Test case */ -class EnableFileServiceTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCase +class EnableFileServiceTest extends UnitTestCase { + /** + * @var bool This test fiddles with Environment + */ + protected $backupEnvironment = true; + /** * Data provider * @@ -67,10 +75,20 @@ class EnableFileServiceTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCa { $vfs = vfsStream::setup('root'); vfsStream::create($structure, $vfs); - /** @var $instance EnableFileService|\TYPO3\TestingFramework\Core\AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ - $instance = $this->getAccessibleMock(EnableFileService::class, ['dummy'], [], '', false); - $instance->_setStatic('sitePath', 'vfs://root/'); - $this->assertEquals([], array_diff($expected, $instance->_call('getFirstInstallFilePaths'))); + /** @var $subject EnableFileService|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ + $subject = $this->getAccessibleMock(EnableFileService::class, ['dummy'], [], '', false); + Environment::initialize( + Environment::getContext(), + Environment::isCli(), + Environment::isComposerMode(), + Environment::getProjectPath(), + 'vfs://root', + Environment::getVarPath(), + Environment::getConfigPath(), + Environment::getCurrentScript(), + 'UNIX' + ); + $this->assertEquals([], array_diff($expected, $subject->_call('getFirstInstallFilePaths'))); } /** @@ -129,10 +147,20 @@ class EnableFileServiceTest extends \TYPO3\TestingFramework\Core\Unit\UnitTestCa { $vfs = vfsStream::setup('root'); vfsStream::create($structure, $vfs); - /** @var $instance EnableFileService|\TYPO3\TestingFramework\Core\AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ - $instance = $this->getAccessibleMock(EnableFileService::class, ['dummy'], [], '', false); - $instance->_setStatic('sitePath', 'vfs://root/'); - $instance->_call('removeFirstInstallFile'); + /** @var $subject EnableFileService|AccessibleObjectInterface|\PHPUnit_Framework_MockObject_MockObject */ + $subject = $this->getAccessibleMock(EnableFileService::class, ['dummy'], [], '', false); + Environment::initialize( + Environment::getContext(), + Environment::isCli(), + Environment::isComposerMode(), + Environment::getProjectPath(), + 'vfs://root', + Environment::getVarPath(), + Environment::getConfigPath(), + Environment::getCurrentScript(), + 'UNIX' + ); + $subject->_call('removeFirstInstallFile'); $this->assertEquals([], array_diff($expected, scandir('vfs://root/'))); }