Phpunit、paratest、およびLaravelアプリケーションを使用して、テストスイートの実行を高速化するための並列テストアドオンを使用しています。これはほとんどの場合機能しますが、時々次のエラーが発生します。
League\Flysystem\Exception: Impossible to create the root directory "/codebuild/output/src0123456/src/github.com/org/repo/storage/framework/testing/disks/local". file_get_contents(/codebuild/output/src0123456/src/github.com/org/repo/.env): failed to open stream: No such file or directory
/codebuild/output/src0123456/src/github.com/org/repo/vendor/league/flysystem/src/Adapter/Local.php:112
/codebuild/output/src0123456/src/github.com/org/repo/vendor/league/flysystem/src/Adapter/Local.php:78
/codebuild/output/src0123456/src/github.com/org/repo/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemManager.php:167
/codebuild/output/src0123456/src/github.com/org/repo/vendor/laravel/framework/src/Illuminate/Support/Facades/Facade.php:261
/codebuild/output/src0123456/src/github.com/org/repo/vendor/laravel/framework/src/Illuminate/Support/Facades/Storage.php:70
/codebuild/output/src0123456/src/github.com/org/repo/tests/TestCase.php:42
42行目のエラーは、テスト用のローカルストレージフォルダーを作成しているこの行に関連しています。
Storage::persistentFake();
例外は失敗に関連するエラーではなく、最後にログに記録されたエラーを選択するため、.envファイルに言及するエラーの後半は無関係です。
これはたまにしか発生しないため、一連の操作またはタイミングの問題である必要があります。
テストはPHP 7.3および7.4に対してAWSコードビルド環境内で実行され、失敗します。
誰かアイデアはありますか?
私の経験から、これは通常、ファイルシステムの問題ではありません。ほとんどの場合、正しくクリーンアップできないテストがありました。
ファイルシステムとParatestに応じて、テストは異なる順序で実行され、このエラーが発生します。
これを追跡するためにできることがいくつかあります。
--debug
_モードを有効にし、以前に実行されたすべてのテストを確認します。--order-by=random
_をローカルで使用してテストを異なる順序で実行し、ファイルシステムから読み取るときに表示されます。数回実行します。これをローカルでシミュレートできます。Testcase::setUp()
)の前にファイルシステムレイアウトを作成し、シャットダウン時にそれをクリーンアップすることを確認してください(TestCase::teatDown()
)。