file_provider = new FakeFileProvider(); $config = new TestConfig(); $config->throw_exception = false; $providers = new Providers( $this->file_provider, new ParserInstanceCacheProvider(), null, null, new FakeFileReferenceCacheProvider(), new ProjectCacheProvider(), ); $this->project_analyzer = new ProjectAnalyzer( $config, $providers, ); $this->project_analyzer->setPhpVersion('7.3', 'tests'); } /** * @dataProvider providerTestErrorFix * @param array> $files * @param array $error_counts * @param array $ignored_issues */ public function testErrorFix( array $files, array $error_counts, array $ignored_issues = [], ): void { $this->project_analyzer->getCodebase()->diff_methods = true; $codebase = $this->project_analyzer->getCodebase(); $config = $codebase->config; foreach ($ignored_issues as $error_type => $error_level) { $config->setCustomErrorLevel($error_type, $error_level); } $analyzed_files = []; for ($i = 0; $i < count($files); ++$i) { $batch = $files[$i]; foreach ($batch as $file_path => $contents) { $this->file_provider->registerFile($file_path, $contents); if (!isset($analyzed_files[$file_path])) { $codebase->addFilesToAnalyze([$file_path => $file_path]); $analyzed_files[$file_path] = true; } } if ($i === 0) { $codebase->scanFiles(); } else { $codebase->reloadFiles($this->project_analyzer, array_keys($batch)); } $codebase->analyzer->analyzeFiles($this->project_analyzer, 1, false); $expected_count = 0; $data = IssueBuffer::clear(); foreach ($data as $file_issues) { $expected_count += count($file_issues); } $this->assertSame($error_counts[$i], $expected_count); } } /** * @return array>,error_counts:array,ignored_issues?:array}> */ public function providerTestErrorFix(): array { return [ 'fixMissingColonSyntaxError' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => ' ' ' [0, 1, 0], ], 'addReturnTypesToSingleMethod' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => 'foo(); } }', ], [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => 'foo(); } }', ], [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => 'foo(); } }', ], ], 'error_counts' => [2, 1, 0], 'ignored_issues' => [ 'MissingReturnType' => Config::REPORT_INFO, ], ], 'traitMethodRenameFirstCorrect' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => 'bar(); } }', (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'T.php' => ' 'bar(); } }', (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'T.php' => ' 'bar(); } }', (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'T.php' => ' [0, 2, 0], ], 'traitMethodRenameFirstError' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => 'bar(); } }', (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'T.php' => ' 'bar(); } }', (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'T.php' => ' 'bar(); } }', (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'T.php' => ' [2, 0, 0], ], 'addSuppressions' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => 'bar(); } } }', ], [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => 'bar(); } } }', ], [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => 'bar(); } } }', ], ], 'error_counts' => [2, 1, 0], ], 'fixDefault' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => ' ' [1, 0], ], 'changeContent' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => ' 'hasMethod($method); }', ], [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'C.php' => ' 'hasMethod($method); }', ], ], 'error_counts' => [0, 0, 0, 0], ], 'missingConstructorForTwoVars' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => ' ' [2, 1], ], 'missingConstructorForInheritedProperties' => [ 'files' => [ [ (string) getcwd() . DIRECTORY_SEPARATOR . 'src' . DIRECTORY_SEPARATOR . 'A.php' => ' ' ' [2, 1, 0], ], ]; } }