From 23030a6b17ac2522f482a685bf43427e42c567ec Mon Sep 17 00:00:00 2001 From: Dan D'Avella Date: Tue, 8 Oct 2024 15:34:19 -0400 Subject: [PATCH] Safely handle Sonar results without `textRange` (#869) --- src/core_codemods/sonar/results.py | 6 +++++- tests/test_sonar_results.py | 31 ++++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+), 1 deletion(-) create mode 100644 tests/test_sonar_results.py diff --git a/src/core_codemods/sonar/results.py b/src/core_codemods/sonar/results.py index 8a03b2ff..8788ac41 100644 --- a/src/core_codemods/sonar/results.py +++ b/src/core_codemods/sonar/results.py @@ -40,7 +40,11 @@ def from_result(cls, result: dict) -> Self: if not (rule_id := result.get("rule", None) or result.get("ruleKey", None)): raise ValueError("Could not extract rule id from sarif result.") - locations: list[Location] = [SonarLocation.from_json_location(result)] + locations: list[Location] = ( + [SonarLocation.from_json_location(result)] + if result.get("textRange") + else [] + ) all_flows: list[list[Location]] = [ [ SonarLocation.from_json_location(json_location) diff --git a/tests/test_sonar_results.py b/tests/test_sonar_results.py new file mode 100644 index 00000000..bb052996 --- /dev/null +++ b/tests/test_sonar_results.py @@ -0,0 +1,31 @@ +from core_codemods.sonar.results import SonarResult + + +def test_result_without_textrange(): + result = { + "cleanCodeAttribute": "FORMATTED", + "cleanCodeAttributeCategory": "CONSISTENT", + "component": "PixeeSandbox_DVWA:vulnerabilities/exec/help/help.php", + "creationDate": "2020-10-21T16:03:39+0200", + "debt": "2min", + "effort": "2min", + "flows": [], + "impacts": [{"severity": "LOW", "softwareQuality": "MAINTAINABILITY"}], + "issueStatus": "OPEN", + "key": "AZJnP4pZPJb5bI8DP25Y", + "message": "Replace all tab characters in this file by sequences of " + "white-spaces.", + "organization": "pixee-sandbox", + "project": "PixeeSandbox_DVWA", + "rule": "php:S105", + "severity": "MINOR", + "status": "OPEN", + "tags": ["convention", "psr2"], + "type": "CODE_SMELL", + "updateDate": "2024-10-07T15:50:36+0200", + } + sonar_result = SonarResult.from_result(result) + assert sonar_result.rule_id == "php:S105" + assert sonar_result.finding_id == "AZJnP4pZPJb5bI8DP25Y" + assert sonar_result.locations == [] + assert sonar_result.codeflows == []