Cleaned code for future tests

This commit is contained in:
Roxie Gibson 2021-01-04 19:42:17 +00:00
parent 38abecefef
commit ee1cd692da
Signed by untrusted user: roxxers
GPG Key ID: 5D0140EDEE123F4D

167
main.py
View File

@ -1,3 +1,4 @@
import os
import re import re
import csv import csv
import urllib.parse as urlparse import urllib.parse as urlparse
@ -10,29 +11,30 @@ from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support.ui import WebDriverWait
BASE_URL = "https://crm-dev.caat.org.uk/"
USERNAME = "roxie" class BaseTester:
PASSWORD = "" BASE_URL = "https://crm-dev.caat.org.uk/"
USERNAME = "roxie"
PASSWORD = ""
fireFoxOptions = webdriver.FirefoxOptions() def __init__(self):
fireFoxOptions.headless = True fireFoxOptions = webdriver.FirefoxOptions()
browser = webdriver.Firefox(options=fireFoxOptions) fireFoxOptions.headless = True
self.browser = webdriver.Firefox(options=fireFoxOptions)
self.wait = WebDriverWait(self.browser, 20)
def login(self):
def login():
""" Login to civicrm so we can continue with the proper cookies """ """ Login to civicrm so we can continue with the proper cookies """
browser.get(BASE_URL) self.browser.get(self.BASE_URL)
username = browser.find_element_by_id("edit-name") username = self.browser.find_element_by_id("edit-name")
password = browser.find_element_by_id("edit-pass") password = self.browser.find_element_by_id("edit-pass")
submit = browser.find_element_by_id("edit-submit") submit = self.browser.find_element_by_id("edit-submit")
username.send_keys(USERNAME) username.send_keys(self.USERNAME)
password.send_keys(PASSWORD) password.send_keys(self.PASSWORD)
submit.click() submit.click()
wait = WebDriverWait(browser, 20)
# Wait for the js elements load so we know the cookies are good. # Wait for the js elements load so we know the cookies are good.
wait.until( self.wait.until(
EC.visibility_of_element_located( EC.visibility_of_element_located(
( (
By.CSS_SELECTOR, By.CSS_SELECTOR,
@ -41,51 +43,46 @@ def login():
) )
) )
def logout(self):
self.browser.get(self.BASE_URL + "/user/logout")
# Wait for the next page to load to finish logging out
self.wait.until(
EC.visibility_of_element_located((By.ID, "tabs-wrapper"))
)
def test_contactexport(search_term: str): def find_element_by_id(self, *args, **kwargs):
search_url = "https://crm-dev.caat.org.uk/civicrm/contact/search" return self.browser.find_element_by_id(*args, **kwargs)
browser.get(search_url)
search_box = browser.find_element_by_id("sort_name")
search_box.send_keys(search_term)
search_box.send_keys(Keys.ENTER)
wait = WebDriverWait(browser, 60)
wait.until(
EC.visibility_of_element_located(
(
By.ID,
"alpha-filter" #wait for table to load
)
)
)
results_text = browser.find_element_by_css_selector(
".form-layout-compressed > tbody:nth-child(1) > tr:nth-child(2) > td:nth-child(2) > label:nth-child(2)"
).text
matches = re.findall(
r"(\d+)", results_text
) # Should just be one match in normal cases
result_no = int(matches[0])
browser.find_element_by_id("CIVICRM_QFID_ts_all_4").click() def find_element_by_css_selector(self, *args, **kwargs):
browser.find_element_by_id("select2-chosen-4").click() return self.browser.find_element_by_css_selector(*args, **kwargs)
browser.find_element_by_id("select2-result-label-15").click()
wait.until(
EC.visibility_of_element_located((By.CSS_SELECTOR, ".crm-block"))
)
browser.save_screenshot("screenshot.png")
export_page_url = browser.current_url
parsed = urlparse.urlparse(export_page_url)
qf_key = parse_qs(parsed.query)['qfKey']
def wait_until_visible(self, locator):
return self.wait.until(EC.visibility_of_element_located(locator))
class ContactExport(BaseTester):
def __init__(self):
super().__init__()
self.search_url = "https://crm-dev.caat.org.uk/civicrm/contact/search"
self.contact_selectall_id = "CIVICRM_QFID_ts_all_4"
self.contact_dropdown_id = "select2-chosen-4"
self.contact_exportoption_id = "select2-result-label-15"
def download_csv(self):
session_cookie = {} session_cookie = {}
for cookie in browser.get_cookies(): for cookie in self.browser.get_cookies():
if re.findall(r"^SSESS.*", cookie.get("name")): if re.findall(r"^SSESS.*", cookie.get("name")):
session_cookie = cookie session_cookie = cookie
if not session_cookie: if not session_cookie:
print("NO SESSION COOKIE FOUND. Are you logged in?") print("NO SESSION COOKIE FOUND. Are you logged in?")
return raise RuntimeError("No session cookie found.")
session = requests.Session() session = requests.Session()
session.cookies.update({session_cookie["name"]: session_cookie["value"]}) session.cookies.update(
{session_cookie["name"]: session_cookie["value"]}
)
qf_key = self.get_export_id()
data = { data = {
"qfKey": qf_key, "qfKey": qf_key,
"entryURL": "https://crm-dev.caat.org.uk/civicrm/contact/search", "entryURL": "https://crm-dev.caat.org.uk/civicrm/contact/search",
@ -100,13 +97,51 @@ def test_contactexport(search_term: str):
"https://crm-dev.caat.org.uk/civicrm/contact/search", "https://crm-dev.caat.org.uk/civicrm/contact/search",
data=data data=data
) )
with open("tmp.csv", "w") as csv_file: return req
def calculate_exported_contacts_number(self):
req = self.download_csv()
file_name = "/tmp/exportedRecords.csv"
with open(file_name, "w") as csv_file:
csv_file.write(req.text) csv_file.write(req.text)
with open("tmp.csv", "r") as csv_file: with open(file_name, "r") as csv_file:
# Dict reader should remove headers # Dict reader should remove headers
exported_csv = csv.DictReader(csv_file) exported_csv = csv.DictReader(csv_file)
exported_number_exports = sum(1 for row in exported_csv) exported_number_exports = sum(1 for row in exported_csv)
os.remove(file_name)
return exported_number_exports
def get_export_id(self) -> str:
export_page_url = self.browser.current_url
parsed = urlparse.urlparse(export_page_url)
return parse_qs(parsed.query)['qfKey']
def test(self, search_term: str):
try:
self.login()
self.browser.get(self.search_url)
search_box = self.find_element_by_id("sort_name")
search_box.send_keys(search_term)
search_box.send_keys(Keys.ENTER)
self.wait_until_visible(
(By.ID, "alpha-filter")
) #wait for table to load
results_text = self.find_element_by_css_selector(
".form-layout-compressed > tbody:nth-child(1) > tr:nth-child(2) > td:nth-child(2) > label:nth-child(2)"
).text
matches = re.findall(
r"(\d+)", results_text
) # Should just be one match in normal cases
result_no = int(matches[0])
self.find_element_by_id(self.contact_selectall_id).click()
self.find_element_by_id(self.contact_dropdown_id).click()
self.find_element_by_id(self.contact_exportoption_id).click()
self.wait_until_visible((By.CSS_SELECTOR, ".crm-block"))
req = self.download_csv()
exported_number_exports = self.calculate_exported_contacts_number()
if exported_number_exports == (result_no): if exported_number_exports == (result_no):
print( print(
"TEST PASSED: Number of expected contact exports for '{}' matches actual number of exports - Expected: {}, Actual: {}" "TEST PASSED: Number of expected contact exports for '{}' matches actual number of exports - Expected: {}, Actual: {}"
@ -117,26 +152,10 @@ def test_contactexport(search_term: str):
"TEST FAILED: Number of expected contact exports for '{}' WAS NOT EQUAL to actual number of exports - Expected: {}, Actual: {}" "TEST FAILED: Number of expected contact exports for '{}' WAS NOT EQUAL to actual number of exports - Expected: {}, Actual: {}"
.format(search_term, result_no, exported_number_exports) .format(search_term, result_no, exported_number_exports)
) )
finally:
# search > contact > add something in the name thing > select all button > change magic dropdown to export > continue and it will do the download self.logout()
self.browser.close()
def logout(): if __name__ == "__main__":
wait = WebDriverWait(browser, 20) ContactExport().test("John")
browser.get(BASE_URL + "/user/logout")
# Wait for the next page to load to finish logging out
wait.until(EC.visibility_of_element_located((By.ID, "tabs-wrapper")))
try:
login()
test_contactexport("john")
test_contactexport("j")
test_contactexport("e")
#wait_for_download()
logout()
finally:
try:
browser.close()
except:
pass