Beispiel #1
0
 def test_parse_file_with_multiple_vuln_has_multiple_finding(self):
     test = Test()
     test.engagement = Engagement()
     test.engagement.product = Product()
     testfile = open(
         get_unit_tests_path() +
         "/scans/microfocus_webinspect/Webinspect_many_vuln.xml")
     parser = MicrofocusWebinspectParser()
     findings = parser.get_findings(testfile, test)
     for finding in findings:
         for endpoint in finding.unsaved_endpoints:
             endpoint.clean()
     self.assertEqual(8, len(findings))
     item = findings[1]
     self.assertEqual(525, item.cwe)
     self.assertIsNotNone(item.references)
     self.assertEqual("1cfe38ee-89f7-4110-ad7c-8fca476b2f04",
                      item.unique_id_from_tool)
     self.assertEqual(1, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("php.vulnweb.com", endpoint.host)
     self.assertEqual(80, endpoint.port)
     self.assertIsNone(
         endpoint.path
     )  # path begins with '/' but Endpoint store "root-less" path
Beispiel #2
0
 def test_convert_severity(self):
     with self.subTest("convert info", val="0"):
         self.assertEqual("Info",
                          MicrofocusWebinspectParser.convert_severity("0"))
     with self.subTest("convert medium", val="2"):
         self.assertEqual("Medium",
                          MicrofocusWebinspectParser.convert_severity("2"))
Beispiel #3
0
 def test_parse_file_with_no_vuln_has_no_findings(self):
     test = Test()
     test.engagement = Engagement()
     test.engagement.product = Product()
     testfile = open(get_unit_tests_path() +
                     "/scans/microfocus_webinspect/Webinspect_no_vuln.xml")
     parser = MicrofocusWebinspectParser()
     findings = parser.get_findings(testfile, test)
     self.assertEqual(0, len(findings))
Beispiel #4
0
 def test_parse_file_with_one_vuln_has_one_findings(self):
     test = Test()
     test.engagement = Engagement()
     test.engagement.product = Product()
     testfile = open(
         "dojo/unittests/scans/microfocus_webinspect/Webinspect_one_vuln.xml"
     )
     parser = MicrofocusWebinspectParser()
     findings = parser.get_findings(testfile, test)
     self.assertEqual(1, len(findings))
     item = findings[0]
     self.assertEqual(200, item.cwe)
     self.assertLess(0, len(item.unsaved_endpoints))
Beispiel #5
0
 def test_parse_file_version_18_20(self):
     testfile = open(
         "unittests/scans/microfocus_webinspect/Webinspect_V18_20.xml")
     parser = MicrofocusWebinspectParser()
     findings = parser.get_findings(testfile, Test())
     for finding in findings:
         for endpoint in finding.unsaved_endpoints:
             endpoint.clean()
     self.assertEqual(4, len(findings))
     item = findings[0]
     self.assertEqual('Cache Management: Headers', item.title)
     self.assertEqual('Info', item.severity)
     self.assertEqual(200, item.cwe)
     self.assertEqual(2, item.nb_occurences)
     self.assertEqual(2, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com", endpoint.host)
     self.assertEqual(443, endpoint.port)
     self.assertIsNone(
         endpoint.path
     )  # path begins with '/' but Endpoint store "root-less" path
     endpoint = item.unsaved_endpoints[1]
     self.assertEqual("www.microfocus.com", endpoint.host)
     self.assertEqual(443, endpoint.port)
     self.assertEqual(
         "en-us/home", endpoint.path
     )  # path begins with '/' but Endpoint store "root-less" path
     item = findings[1]
     self.assertEqual(525, item.cwe)
     self.assertEqual(1, item.nb_occurences)
     self.assertEqual(1, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com", endpoint.host)
     self.assertEqual(443, endpoint.port)
     item = findings[2]
     self.assertEqual(200, item.cwe)
     self.assertEqual(1, item.nb_occurences)
     self.assertEqual(1, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com", endpoint.host)
     self.assertEqual(443, endpoint.port)
     item = findings[3]
     self.assertEqual(613, item.cwe)
     self.assertEqual(1, item.nb_occurences)
     self.assertEqual(1, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com", endpoint.host)
     self.assertEqual(443, endpoint.port)
Beispiel #6
0
 def test_parse_file_with_multiple_vuln_has_multiple_finding(self):
     test = Test()
     test.engagement = Engagement()
     test.engagement.product = Product()
     testfile = open(
         "dojo/unittests/scans/microfocus_webinspect/Webinspect_many_vuln.xml"
     )
     parser = MicrofocusWebinspectParser()
     findings = parser.get_findings(testfile, test)
     self.assertEqual(8, len(findings))
     item = findings[1]
     self.assertEqual(525, item.cwe)
     self.assertIsNotNone(item.references)
     self.assertEqual("1cfe38ee-89f7-4110-ad7c-8fca476b2f04",
                      item.unique_id_from_tool)
     self.assertLess(0, len(item.unsaved_endpoints))
Beispiel #7
0
 def test_parse_file_with_one_vuln_has_one_findings(self):
     test = Test()
     test.engagement = Engagement()
     test.engagement.product = Product()
     testfile = open(get_unit_tests_path() +
                     "/scans/microfocus_webinspect/Webinspect_one_vuln.xml")
     parser = MicrofocusWebinspectParser()
     findings = parser.get_findings(testfile, test)
     for finding in findings:
         for endpoint in finding.unsaved_endpoints:
             endpoint.clean()
     self.assertEqual(1, len(findings))
     item = findings[0]
     self.assertEqual(200, item.cwe)
     self.assertEqual(1, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com", endpoint.host)
     self.assertEqual(443, endpoint.port)
     self.assertIsNone(
         endpoint.path
     )  # path begins with '/' but Endpoint store "root-less" path
 def test_parse_file_version_18_20(self):
     testfile = open(
         "dojo/unittests/scans/microfocus_webinspect/Webinspect_V18_20.xml")
     parser = MicrofocusWebinspectParser()
     findings = parser.get_findings(testfile, Test())
     self.assertEqual(4, len(findings))
     item = findings[0]
     self.assertEqual('Cache Management: Headers', item.title)
     self.assertEqual('Info', item.severity)
     self.assertEqual(200, item.cwe)
     self.assertEqual(2, item.nb_occurences)
     self.assertEqual(2, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com:443", endpoint.host)
     self.assertEqual("/", endpoint.path)
     endpoint = item.unsaved_endpoints[1]
     self.assertEqual("www.microfocus.com:443", endpoint.host)
     self.assertEqual("/en-us/home", endpoint.path)
     item = findings[1]
     self.assertEqual(525, item.cwe)
     self.assertEqual(1, item.nb_occurences)
     self.assertEqual(1, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com:443", endpoint.host)
     item = findings[2]
     self.assertEqual(200, item.cwe)
     self.assertEqual(1, item.nb_occurences)
     self.assertEqual(1, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com:443", endpoint.host)
     item = findings[3]
     self.assertEqual(613, item.cwe)
     self.assertEqual(1, item.nb_occurences)
     self.assertEqual(1, len(item.unsaved_endpoints))
     endpoint = item.unsaved_endpoints[0]
     self.assertEqual("www.microfocus.com:443", endpoint.host)