From 10dade34d68219c685c22a03edbe64a31ad825eb Mon Sep 17 00:00:00 2001 From: Dariusz Gafka Date: Sat, 7 Dec 2024 14:27:24 +0100 Subject: [PATCH] Invalid whole cache on file change in Ecotone Lite (#418) --- packages/Ecotone/src/Lite/EcotoneLite.php | 33 +++++++++-------------- 1 file changed, 13 insertions(+), 20 deletions(-) diff --git a/packages/Ecotone/src/Lite/EcotoneLite.php b/packages/Ecotone/src/Lite/EcotoneLite.php index dc248f92a..fcb35da2a 100644 --- a/packages/Ecotone/src/Lite/EcotoneLite.php +++ b/packages/Ecotone/src/Lite/EcotoneLite.php @@ -176,16 +176,11 @@ public static function bootstrapFlowTestingWithEventStore( private static function getFileNameBasedOnConfig( string $pathToRootCatalog, - bool $useCachedVersion, FileSystemAnnotationFinder $annotationFinder, ServiceConfiguration $serviceConfiguration, array $configurationVariables, bool $enableTesting ): string { - if ($useCachedVersion) { - return 'messaging'; - } - // this is temporary cache based on if files have changed // get file contents based on class names, configuration and configuration variables $fileSha = ''; @@ -236,16 +231,8 @@ private static function prepareConfiguration(ContainerInterface|array $container } $externalContainer = $containerOrAvailableServices instanceof ContainerInterface ? $containerOrAvailableServices : InMemoryPSRContainer::createFromAssociativeArray($containerOrAvailableServices); - - $serviceCacheConfiguration = new ServiceCacheConfiguration( - $serviceConfiguration->getCacheDirectoryPath(), - self::shouldUseAutomaticCache($useCachedVersion, $pathToRootCatalog), - ); - $configurationVariableService = InMemoryConfigurationVariableService::create($configurationVariables); - $definitionHolder = null; - $messagingSystemCachePath = null; - $serviceConfiguration = MessagingSystemConfiguration::addCorePackage($serviceConfiguration, $enableTesting); + $annotationFinder = AnnotationFinderFactory::createForAttributes( realpath($pathToRootCatalog), $serviceConfiguration->getNamespaces(), @@ -255,13 +242,19 @@ private static function prepareConfiguration(ContainerInterface|array $container $classesToResolve, $enableTesting ); - if ($serviceCacheConfiguration->shouldUseCache()) { - $messagingSystemCachePath = $serviceCacheConfiguration->getPath() . DIRECTORY_SEPARATOR . self::getFileNameBasedOnConfig($pathToRootCatalog, $useCachedVersion, $annotationFinder, $serviceConfiguration, $configurationVariables, $enableTesting); + $cacheHash = self::getFileNameBasedOnConfig($pathToRootCatalog, $annotationFinder, $serviceConfiguration, $configurationVariables, $enableTesting); + $serviceCacheConfiguration = new ServiceCacheConfiguration( + $serviceConfiguration->getCacheDirectoryPath() . DIRECTORY_SEPARATOR . $cacheHash, + self::shouldUseAutomaticCache($useCachedVersion, $pathToRootCatalog), + ); - if (file_exists($messagingSystemCachePath)) { - /** It may fail on deserialization, then return `false` and we can build new one */ - $definitionHolder = unserialize(file_get_contents($messagingSystemCachePath)); - } + $configurationVariableService = InMemoryConfigurationVariableService::create($configurationVariables); + $definitionHolder = null; + $messagingSystemCachePath = $serviceCacheConfiguration->getPath() . DIRECTORY_SEPARATOR . 'messaging'; + + if ($serviceCacheConfiguration->shouldUseCache() && file_exists($messagingSystemCachePath)) { + /** It may fail on deserialization, then return `false` and we can build new one */ + $definitionHolder = unserialize(file_get_contents($messagingSystemCachePath)); } if (! $definitionHolder) {