1
0
mirror of https://github.com/danog/psalm.git synced 2024-12-17 11:56:59 +01:00
psalm/src/Psalm/Report/SonarqubeReport.php

47 lines
1.5 KiB
PHP
Raw Normal View History

<?php
namespace Psalm\Report;
use Psalm\Config;
2021-06-08 04:55:21 +02:00
use Psalm\Internal\Json\Json;
use Psalm\Report;
2021-06-08 04:55:21 +02:00
use function max;
/**
* JSON report format suitable for import into SonarQube or SonarCloud as
* generic (external) issue data via `sonar.externalIssuesReportPaths`.
*
* https://docs.sonarqube.org/latest/analysis/generic-issue/
*/
class SonarqubeReport extends Report
{
public function create(): string
{
$report = ['issues' => []];
foreach ($this->issues_data as $issue_data) {
$report['issues'][] = [
'engineId' => 'Psalm',
2020-02-17 00:24:40 +01:00
'ruleId' => $issue_data->type,
'primaryLocation' => [
2020-02-17 00:24:40 +01:00
'message' => $issue_data->message,
'filePath' => $issue_data->file_name,
'textRange' => [
2020-02-17 00:24:40 +01:00
'startLine' => $issue_data->line_from,
'endLine' => $issue_data->line_to,
// Columns in external issue reports are indexed from 0
2020-02-17 00:24:40 +01:00
'startColumn' => max(0, $issue_data->column_from - 1),
'endColumn' => max(0, $issue_data->column_to - 1),
],
],
'type' => 'CODE_SMELL',
'severity' => $issue_data->severity === Config::REPORT_ERROR ? 'CRITICAL' : 'MINOR',
];
}
$options = $this->pretty ? Json::PRETTY : Json::DEFAULT;
return Json::encode($report, $options) . "\n";
}
}