2019-06-18 03:17:09 +02:00
|
|
|
<?php
|
|
|
|
namespace Psalm\Report;
|
|
|
|
|
|
|
|
use Psalm\Config;
|
2021-06-08 04:55:21 +02:00
|
|
|
use Psalm\Internal\Json\Json;
|
2019-06-18 03:17:09 +02:00
|
|
|
use Psalm\Report;
|
|
|
|
|
2021-06-08 04:55:21 +02:00
|
|
|
use function max;
|
|
|
|
|
2019-06-18 03:17:09 +02:00
|
|
|
/**
|
|
|
|
* 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,
|
2019-06-18 03:17:09 +02:00
|
|
|
'primaryLocation' => [
|
2020-02-17 00:24:40 +01:00
|
|
|
'message' => $issue_data->message,
|
|
|
|
'filePath' => $issue_data->file_name,
|
2019-06-18 03:17:09 +02:00
|
|
|
'textRange' => [
|
2020-02-17 00:24:40 +01:00
|
|
|
'startLine' => $issue_data->line_from,
|
|
|
|
'endLine' => $issue_data->line_to,
|
2019-06-18 03:17:09 +02:00
|
|
|
// 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),
|
2019-06-18 03:17:09 +02:00
|
|
|
],
|
|
|
|
],
|
|
|
|
'type' => 'CODE_SMELL',
|
2020-05-18 14:40:20 +02:00
|
|
|
'severity' => $issue_data->severity === Config::REPORT_ERROR ? 'CRITICAL' : 'MINOR',
|
2019-06-18 03:17:09 +02:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2020-05-18 14:40:20 +02:00
|
|
|
$options = $this->pretty ? Json::PRETTY : Json::DEFAULT;
|
|
|
|
|
|
|
|
return Json::encode($report, $options) . "\n";
|
2019-06-18 03:17:09 +02:00
|
|
|
}
|
|
|
|
}
|