From b351adc2dc764737f88e2a65f842ec99ae1df380 Mon Sep 17 00:00:00 2001 From: Cody Maffucci <46459665+Maffooch@users.noreply.github.com> Date: Mon, 20 May 2024 22:49:11 -0500 Subject: [PATCH 1/2] Import History: Adding a few tests --- .../scans/generic/test_import_report1.json | 38 +++++++++++++++++++ .../scans/generic/test_import_report2.json | 38 +++++++++++++++++++ unittests/test_import_reimport.py | 15 ++++++++ 3 files changed, 91 insertions(+) create mode 100644 unittests/scans/generic/test_import_report1.json create mode 100644 unittests/scans/generic/test_import_report2.json diff --git a/unittests/scans/generic/test_import_report1.json b/unittests/scans/generic/test_import_report1.json new file mode 100644 index 00000000000..d3904face82 --- /dev/null +++ b/unittests/scans/generic/test_import_report1.json @@ -0,0 +1,38 @@ +{ + "name": "Unicorn", + "type": "Unicorn", + "findings": [ + { + "title": "Henry Smith", + "description": "small", + "severity": "Critical", + "active": false, + "verified": false, + "is_mitigated": true + }, + { + "title": "Emma Jones", + "description": "small", + "severity": "Critical", + "active": false, + "verified": false, + "is_mitigated": true + }, + { + "title": "Emma Jones", + "description": "small", + "severity": "Critical", + "active": true, + "verified": true, + "is_mitigated": false + }, + { + "title": "Emma Jones", + "description": "small", + "severity": "Critical", + "active": false, + "verified": false, + "is_mitigated": true + } + ] +} \ No newline at end of file diff --git a/unittests/scans/generic/test_import_report2.json b/unittests/scans/generic/test_import_report2.json new file mode 100644 index 00000000000..7cb918277ff --- /dev/null +++ b/unittests/scans/generic/test_import_report2.json @@ -0,0 +1,38 @@ +{ + "name": "Unicorn", + "type": "Unicorn", + "findings": [ + { + "title": "Henry Smith", + "description": "small", + "severity": "Critical", + "active": false, + "verified": false, + "is_mitigated": true + }, + { + "title": "Henry Smith", + "description": "small", + "severity": "Critical", + "active": false, + "verified": false, + "is_mitigated": true + }, + { + "title": "Henry Smith", + "description": "small", + "severity": "Critical", + "active": false, + "verified": false, + "is_mitigated": true + }, + { + "title": "Henry Smith", + "description": "small", + "severity": "Critical", + "active": true, + "verified": true, + "is_mitigated": false + } + ] +} \ No newline at end of file diff --git a/unittests/test_import_reimport.py b/unittests/test_import_reimport.py index 342e771c65b..f16bcb0dc57 100644 --- a/unittests/test_import_reimport.py +++ b/unittests/test_import_reimport.py @@ -85,7 +85,10 @@ def __init__(self, *args, **kwargs): self.clair_empty = self.scans_path + 'clair/clair_empty.json' self.scan_type_clair = 'Clair Scan' + self.scan_type_generic = "Generic Findings Import" self.generic_filename_with_file = self.scans_path + "generic/test_with_image.json" + self.generic_import_1 = self.scans_path + "generic/test_import_report1.json" + self.generic_import_2 = self.scans_path + "generic/test_import_report2.json" self.aws_prowler_file_name = self.scans_path + 'aws_prowler/many_vuln.json' self.aws_prowler_file_name_plus_one = self.scans_path + 'aws_prowler/many_vuln_plus_one.json' @@ -1445,6 +1448,18 @@ def test_import_reimport_vulnerability_ids(self): self.assertEqual('GHSA-v6rh-hp5x-86rv', findings[3].vulnerability_ids[0]) self.assertEqual('CVE-2021-44420', findings[3].vulnerability_ids[1]) + def test_import_history_reactivated_and_untouched_findings_do_not_mix(self): + with assertTestImportModelsCreated(self, imports=1, affected_findings=4, created=4): + import0 = self.import_scan_with_params(self.generic_import_1, scan_type=self.scan_type_generic) + test_id = import0['test'] + # reimport the second report + with assertTestImportModelsCreated(self, reimports=1, affected_findings=4, closed=3, reactivated=1): + self.reimport_scan_with_params(test_id, self.generic_import_2, scan_type=self.scan_type_generic) + # reimport the first report again + with assertTestImportModelsCreated(self, reimports=1, affected_findings=2, closed=1, reactivated=1): + self.reimport_scan_with_params(test_id, self.generic_import_1, scan_type=self.scan_type_generic) + # Passing this test means an exception does not occur + class ImportReimportTestAPI(DojoAPITestCase, ImportReimportMixin): fixtures = ['dojo_testdata.json'] From e1bfd9a4769fb2cc78bb15efdd15295a8f602232 Mon Sep 17 00:00:00 2001 From: Cody Maffucci <46459665+Maffooch@users.noreply.github.com> Date: Tue, 21 May 2024 13:08:18 -0500 Subject: [PATCH 2/2] Update tests --- unittests/test_import_reimport.py | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/unittests/test_import_reimport.py b/unittests/test_import_reimport.py index f16bcb0dc57..c2e3aadf568 100644 --- a/unittests/test_import_reimport.py +++ b/unittests/test_import_reimport.py @@ -1449,15 +1449,12 @@ def test_import_reimport_vulnerability_ids(self): self.assertEqual('CVE-2021-44420', findings[3].vulnerability_ids[1]) def test_import_history_reactivated_and_untouched_findings_do_not_mix(self): - with assertTestImportModelsCreated(self, imports=1, affected_findings=4, created=4): - import0 = self.import_scan_with_params(self.generic_import_1, scan_type=self.scan_type_generic) - test_id = import0['test'] + import0 = self.import_scan_with_params(self.generic_import_1, scan_type=self.scan_type_generic) + test_id = import0['test'] # reimport the second report - with assertTestImportModelsCreated(self, reimports=1, affected_findings=4, closed=3, reactivated=1): - self.reimport_scan_with_params(test_id, self.generic_import_2, scan_type=self.scan_type_generic) + self.reimport_scan_with_params(test_id, self.generic_import_2, scan_type=self.scan_type_generic) # reimport the first report again - with assertTestImportModelsCreated(self, reimports=1, affected_findings=2, closed=1, reactivated=1): - self.reimport_scan_with_params(test_id, self.generic_import_1, scan_type=self.scan_type_generic) + self.reimport_scan_with_params(test_id, self.generic_import_1, scan_type=self.scan_type_generic) # Passing this test means an exception does not occur