forked from DefectDojo/django-DefectDojo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathibm_appscan_test.py
59 lines (49 loc) · 2.39 KB
/
ibm_appscan_test.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
from selenium.webdriver.support.ui import Select
import unittest
import sys
import os
from base_test_class import BaseTestCase
from product_test import ProductTest
from selenium.webdriver.common.by import By
dir_path = os.path.dirname(os.path.realpath(__file__))
class IBMAppScanTest(BaseTestCase):
def test_import_ibm_app_scan_result(self):
# Login to the site.
# Username and password will be gotten from environ
driver = self.driver
# Navigate to the Endpoint page
self.goto_product_overview(driver)
# wait for product_wrapper div as datatables javascript modifies the DOM on page load.
driver.find_element(By.ID, 'products_wrapper')
driver.find_element(By.LINK_TEXT, "QA Test").click()
# "Click" the Finding Drop down
driver.find_element(By.PARTIAL_LINK_TEXT, "Findings").click()
# "Click" the New Endpoint
driver.find_element(By.LINK_TEXT, "Import Scan Results").click()
# Select scan type
Select(driver.find_element(By.ID, "id_scan_type")).select_by_visible_text("IBM AppScan DAST")
# Select `Default` as the Environment
Select(driver.find_element(By.ID, "id_environment")).select_by_visible_text('Development')
# Upload Scan result file
scanner_file = os.path.join(dir_path, "ibm_appscan_xml_file.xml")
driver.find_element(By.NAME, "file").send_keys(scanner_file)
# click on upload button
driver.find_elements(By.CSS_SELECTOR, "button.btn.btn-primary")[1].click()
# Query the site to determine if the finding has been added
# Assert the query to determine status or failure
self.assertTrue(self.is_success_message_present(text='IBM AppScan DAST processed a total of 27 findings'))
def suite():
suite = unittest.TestSuite()
# Add each test the the suite to be run
# success and failure is output by the test
suite.addTest(BaseTestCase('test_login'))
suite.addTest(BaseTestCase('disable_block_execution'))
suite.addTest(ProductTest('test_create_product'))
suite.addTest(IBMAppScanTest('test_import_ibm_app_scan_result'))
suite.addTest(ProductTest('test_delete_product'))
return suite
if __name__ == "__main__":
runner = unittest.TextTestRunner(descriptions=True, failfast=True, verbosity=2)
ret = not runner.run(suite()).wasSuccessful()
BaseTestCase.tearDownDriver()
sys.exit(ret)