1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-23 06:11:25 +01:00

fix race conditions causing notices if directory does not exist

This commit is contained in:
kkmuffme 2022-07-21 11:32:24 +02:00
parent cac9ec957c
commit bb760a2224
2 changed files with 29 additions and 7 deletions

View File

@ -52,6 +52,7 @@ use function assert;
use function basename;
use function chdir;
use function class_exists;
use function clearstatcache;
use function count;
use function dirname;
use function error_log;
@ -2268,6 +2269,7 @@ class Config
public static function removeCacheDirectory(string $dir): void
{
clearstatcache(true, $dir);
if (is_dir($dir)) {
$objects = scandir($dir, SCANDIR_SORT_NONE);
@ -2276,17 +2278,29 @@ class Config
}
foreach ($objects as $object) {
if ($object !== '.' && $object !== '..') {
if (filetype($dir . '/' . $object) === 'dir') {
self::removeCacheDirectory($dir . '/' . $object);
} else {
unlink($dir . '/' . $object);
}
if ($object === '.' || $object === '..') {
continue;
}
// if it was deleted in the meantime/race condition with other psalm process
if (!file_exists($dir . '/' . $object)) {
continue;
}
if (filetype($dir . '/' . $object) === 'dir') {
self::removeCacheDirectory($dir . '/' . $object);
} else {
unlink($dir . '/' . $object);
}
}
reset($objects);
rmdir($dir);
// may have been removed in the meantime
clearstatcache(true, $dir);
if (is_dir($dir)) {
rmdir($dir);
}
}
}

View File

@ -7,6 +7,7 @@ use PhpParser\Node\Stmt;
use Psalm\Config;
use RuntimeException;
use function clearstatcache;
use function error_log;
use function fclose;
use function file_get_contents;
@ -302,6 +303,13 @@ class ParserCacheProvider
return;
}
// directory was removed
// most likely due to a race condition with other psalm instances that were manually started at the same time
clearstatcache(true, $root_cache_directory);
if (!is_dir($root_cache_directory)) {
return;
}
$file_content_hashes = $this->new_file_content_hashes + $this->getExistingFileContentHashes();
$file_hashes_path = $root_cache_directory . DIRECTORY_SEPARATOR . self::FILE_HASHES;