diff --git a/src/Configuration.php b/src/Configuration.php index 918401c2a..efda0159a 100644 --- a/src/Configuration.php +++ b/src/Configuration.php @@ -622,7 +622,7 @@ private static function retrieveFiles(stdClass $raw, string $key, string $basePa } if (false === isset($raw->{$key})) { - return []; + return $files; } $files = array_merge((array) $raw->{$key}, $files); @@ -726,7 +726,7 @@ private static function retrieveFilesAggregate(iterable ...$fileIterators): arra foreach ($fileIterators as $fileIterator) { foreach ($fileIterator as $file) { - $files[$file->getPathname()] = $file; + $files[(string) $file] = $file; } } diff --git a/tests/ConfigurationFileTest.php b/tests/ConfigurationFileTest.php index bb20c3f4c..54eeb0487 100644 --- a/tests/ConfigurationFileTest.php +++ b/tests/ConfigurationFileTest.php @@ -19,6 +19,7 @@ use KevinGH\Box\Compactor\Php; use KevinGH\Box\Json\JsonValidationException; use const DIRECTORY_SEPARATOR; +use function file_put_contents; use function KevinGH\Box\FileSystem\dump_file; use function KevinGH\Box\FileSystem\make_path_absolute; use function KevinGH\Box\FileSystem\rename; @@ -1445,6 +1446,59 @@ public function test_the_finder_config_cannot_include_invalid_methods(): void } } + public function test_the_composer_json_and_lock_files_are_always_included_even_when_the_user_configure_which_files_to_pick(): void + { + touch('file0'); + touch('file1'); + + mkdir('B'); + touch('B/fileB0'); + touch('B/fileB1'); + + file_put_contents('composer.json', '{}'); + file_put_contents('composer.lock', '{}'); + + $this->setConfig([ + 'files' => [ + 'file0', + 'file1', + ], + 'directories' => ['B'], + ]); + + // Relative to the current working directory for readability + $expected = [ + 'B/fileB0', + 'B/fileB1', + 'composer.json', + 'composer.lock', + 'file0', + 'file1', + ]; + + $actual = $this->normalizeConfigPaths($this->config->getFiles()); + + $this->assertSame($expected, $actual); + $this->assertCount(0, $this->config->getBinaryFiles()); + + $this->setConfig([ + 'directories' => ['B'], + ]); + + // Relative to the current working directory for readability + $expected = [ + 'B/fileB0', + 'B/fileB1', + 'composer.json', + 'composer.lock', + ]; + + $actual = $this->normalizeConfigPaths($this->config->getFiles()); + + $this->assertSame($expected, $actual); + $this->assertCount(0, $this->config->getBinaryFiles()); + } + public function provideJsonValidNonStringArray(): Generator { foreach ($this->provideJsonPrimitives() as $key => $values) {