
Implements blueprint: horizon-integration-tests-coverage Change-Id: I04fda1a6c97e8d59c758c705c1b6861f8e347240
135 lines
4.9 KiB
Python
135 lines
4.9 KiB
Python
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
import unittest
|
|
|
|
import selenium.common.exceptions as Exceptions
|
|
from selenium.webdriver.common import by
|
|
import selenium.webdriver.support.ui as Support
|
|
from selenium.webdriver.support import wait
|
|
|
|
|
|
class BaseWebObject(unittest.TestCase):
|
|
"""Base class for all web objects."""
|
|
_spinner_locator = (by.By.CSS_SELECTOR, '.modal-body > .spinner')
|
|
|
|
def __init__(self, driver, conf):
|
|
self.driver = driver
|
|
self.conf = conf
|
|
self.explicit_wait = self.conf.selenium.explicit_wait
|
|
|
|
def _is_element_present(self, *locator):
|
|
try:
|
|
self._turn_off_implicit_wait()
|
|
self._get_element(*locator)
|
|
return True
|
|
except Exceptions.NoSuchElementException:
|
|
return False
|
|
finally:
|
|
self._turn_on_implicit_wait()
|
|
|
|
def _is_element_visible(self, *locator):
|
|
try:
|
|
return self._get_element(*locator).is_displayed()
|
|
except (Exceptions.NoSuchElementException,
|
|
Exceptions.ElementNotVisibleException):
|
|
return False
|
|
|
|
def _is_element_displayed(self, element):
|
|
try:
|
|
return element.is_displayed()
|
|
except Exception:
|
|
return False
|
|
|
|
def _is_text_visible(self, element, text, strict=True):
|
|
try:
|
|
if strict:
|
|
return element.text == text
|
|
else:
|
|
return text in element.text
|
|
except Exception:
|
|
return False
|
|
|
|
def _get_element(self, *locator):
|
|
return self.driver.find_element(*locator)
|
|
|
|
def _get_elements(self, *locator):
|
|
return self.driver.find_elements(*locator)
|
|
|
|
def _fill_field_element(self, data, field_element):
|
|
field_element.clear()
|
|
field_element.send_keys(data)
|
|
return field_element
|
|
|
|
def _select_dropdown(self, value, element):
|
|
select = Support.Select(element)
|
|
select.select_by_visible_text(value)
|
|
|
|
def _select_dropdown_by_value(self, value, element):
|
|
select = Support.Select(element)
|
|
select.select_by_value(value)
|
|
|
|
def _turn_off_implicit_wait(self):
|
|
self.driver.implicitly_wait(0)
|
|
|
|
def _turn_on_implicit_wait(self):
|
|
self.driver.implicitly_wait(self.conf.selenium.page_timeout)
|
|
|
|
def _wait_until(self, predicate, timeout=None, poll_frequency=0.5):
|
|
"""Wait until the value returned by predicate is not False or
|
|
the timeout is elapsed.
|
|
'predicate' takes the driver as argument.
|
|
"""
|
|
if not timeout:
|
|
timeout = self.explicit_wait
|
|
wait.WebDriverWait(self.driver, timeout, poll_frequency).until(
|
|
predicate)
|
|
|
|
def _wait_till_text_present_in_element(self, element, text, timeout=None):
|
|
"""Waiting for a text to appear in a certain element very often is
|
|
actually waiting for a _different_ element with a different text to
|
|
appear in place of an old element. So a way to avoid capturing stale
|
|
element reference should be provided for this use case.
|
|
|
|
Better to wrap getting entity status cell in a lambda
|
|
to avoid problems with cell being replaced with totally different
|
|
element by Javascript
|
|
"""
|
|
def predicate(_):
|
|
elt = element() if hasattr(element, '__call__') else element
|
|
return self._is_text_visible(elt, text)
|
|
|
|
self._wait_until(predicate, timeout)
|
|
|
|
def _wait_till_element_visible(self, element, timeout=None):
|
|
self._wait_until(lambda x: self._is_element_displayed(element),
|
|
timeout)
|
|
|
|
def _wait_till_element_disappears(self, element, timeout=None):
|
|
self._wait_until(lambda x: not self._is_element_displayed(element),
|
|
timeout)
|
|
|
|
def wait_till_element_disappears(self, element_getter):
|
|
try:
|
|
self._turn_off_implicit_wait()
|
|
self._wait_till_element_disappears(element_getter())
|
|
except Exceptions.NoSuchElementException:
|
|
# NOTE(mpavlase): This is valid state. When request completes
|
|
# even before Selenium get a chance to get the spinner element,
|
|
# it will raise the NoSuchElementException exception.
|
|
pass
|
|
finally:
|
|
self._turn_on_implicit_wait()
|
|
|
|
def wait_till_spinner_disappears(self):
|
|
getter = lambda: self.driver.find_element(*self._spinner_locator)
|
|
self.wait_till_element_disappears(getter)
|