file_provider = new FakeFileProvider(); } /** * @dataProvider providerValidCodeParse * @param string[] $issues_to_fix */ public function testValidCode( string $input_code, string $output_code, string $php_version, array $issues_to_fix, bool $safe_types, bool $allow_backwards_incompatible_changes = true, ): void { $test_name = $this->getTestName(); if (str_contains($test_name, 'SKIPPED-')) { $this->markTestSkipped('Skipped due to a bug.'); } $config = new TestConfig(); $this->project_analyzer = new ProjectAnalyzer( $config, new Providers( $this->file_provider, new FakeParserCacheProvider(), ), ); if (empty($issues_to_fix)) { $config->addPluginPath('examples/plugins/ClassUnqualifier.php'); $config->initializePlugins($this->project_analyzer); } $context = new Context(); $file_path = self::$src_dir_path . 'somefile.php'; $this->addFile( $file_path, $input_code, ); $this->project_analyzer->setPhpVersion($php_version, 'tests'); $keyed_issues_to_fix = []; foreach ($issues_to_fix as $issue) { $keyed_issues_to_fix[$issue] = true; } $this->project_analyzer->setIssuesToFix($keyed_issues_to_fix); $this->project_analyzer->alterCodeAfterCompletion( false, $safe_types, ); $this->project_analyzer->getCodebase()->allow_backwards_incompatible_changes = $allow_backwards_incompatible_changes; $this->project_analyzer->getConfig()->check_for_throws_docblock = true; if (strpos(static::class, 'Unused') || strpos(static::class, 'Unnecessary')) { $this->project_analyzer->getCodebase()->reportUnusedCode(); } $this->analyzeFile($file_path, $context); $this->project_analyzer->consolidateAnalyzedData(); $this->project_analyzer->getCodebase()->analyzer->updateFile($file_path, false); $this->assertSame($output_code, $this->project_analyzer->getCodebase()->getFileContents($file_path)); } /** * @return array,safe_types:bool,allow_backwards_incompatible_changes?:bool}> */ abstract public function providerValidCodeParse(): array; }