2021-01-25 20:48:43 +00:00
|
|
|
import csv
|
|
|
|
import io
|
|
|
|
|
|
|
|
from selenium.webdriver.common.keys import Keys
|
2022-02-04 05:21:20 +00:00
|
|
|
from selenium.webdriver.common.by import By
|
|
|
|
from selenium.webdriver.support.select import Select
|
2021-01-25 20:48:43 +00:00
|
|
|
|
|
|
|
from .base import SearchExportTester
|
|
|
|
|
|
|
|
|
2021-10-24 19:19:30 +00:00
|
|
|
class TestContactExport(SearchExportTester):
|
2021-01-25 20:48:43 +00:00
|
|
|
"""Tests if exporting contacts from a search returns a CSV file with all contacts."""
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super().__init__(*args, **kwargs)
|
|
|
|
self.title("Contact Export")
|
|
|
|
self.desc(
|
|
|
|
"Testing if exporting contacts from a search returns a CSV file with all expected contacts."
|
|
|
|
)
|
2021-10-20 12:57:23 +00:00
|
|
|
self.contact_exportoption_id = "select2-result-label-13"
|
2021-01-25 20:48:43 +00:00
|
|
|
|
|
|
|
def download_csv(self):
|
2021-01-25 21:21:14 +00:00
|
|
|
# Data of the request that is specific for this export and not generic like qr_key
|
2021-01-25 20:48:43 +00:00
|
|
|
data = {
|
|
|
|
"_qf_Select_next": "Continue",
|
|
|
|
"exportOption": 1,
|
|
|
|
"mergeOption": 0,
|
|
|
|
"postal_greeting": 1,
|
|
|
|
"addressee": 1,
|
|
|
|
}
|
2021-01-25 21:21:14 +00:00
|
|
|
return self.download_export(data)
|
2021-01-25 20:48:43 +00:00
|
|
|
|
|
|
|
def calculate_exported_contacts_number(self) -> int:
|
|
|
|
"""
|
|
|
|
Downloads csv, opens it in a string buffer using StringIO and passes it to the csv lib
|
|
|
|
Counts number of rows (excl. header) and returns that value
|
|
|
|
"""
|
|
|
|
res = self.download_csv()
|
|
|
|
csv_file = io.StringIO(res.text)
|
|
|
|
|
2021-01-25 21:21:14 +00:00
|
|
|
# DictReader removes header from count
|
2021-01-25 20:48:43 +00:00
|
|
|
exported_csv = csv.DictReader(csv_file)
|
|
|
|
exported_number_exports = sum(1 for row in exported_csv)
|
|
|
|
self.debug(
|
|
|
|
"found %d rows in exported csv excluding header row" %
|
|
|
|
exported_number_exports
|
|
|
|
)
|
|
|
|
|
|
|
|
return exported_number_exports
|
|
|
|
|
|
|
|
def _test(self, search_term: str):
|
|
|
|
"""
|
|
|
|
Test Description:
|
|
|
|
Go to the contact search url
|
|
|
|
Search for the search term
|
|
|
|
Select all contacts and set them to export
|
|
|
|
Get the login cookie and search ID and download the export manually with requests
|
|
|
|
Save the file in tmp
|
|
|
|
Read it to check the number of exported contacts is the same as reported in the UI
|
|
|
|
"""
|
|
|
|
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.debug("searching for contacts with term '%s'" % search_term)
|
2021-01-25 21:21:14 +00:00
|
|
|
self._wait_for_search_to_load()
|
|
|
|
result_no = self._get_contact_search_number()
|
2022-02-04 05:21:20 +00:00
|
|
|
self._select_option_from_magic_dropdown_label("Export contacts")
|
2021-01-25 20:48:43 +00:00
|
|
|
|
|
|
|
exported_number_exports = self.calculate_exported_contacts_number()
|
|
|
|
if exported_number_exports == (result_no):
|
|
|
|
self.passed(
|
|
|
|
"Number of expected contact exports for '%s' matches actual number of exports - Expected: %d, Actual: %d"
|
|
|
|
% (search_term, result_no, exported_number_exports)
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
self.failed(
|
|
|
|
"Number of expected contact exports for '%s' WAS NOT EQUAL to actual number of exports - Expected: %d, Actual: %d"
|
|
|
|
% (search_term, result_no, exported_number_exports)
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_hardcoded_search_terms(self):
|
|
|
|
"""Loops over the test with three hardcoded search terms"""
|
2021-10-20 12:57:23 +00:00
|
|
|
search_terms = ("John", "Jane", "Smith")
|
2021-01-25 20:48:43 +00:00
|
|
|
self._test_all(search_terms)
|