Source code for gaiatest.apps.system.regions.search_panel

# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.

import urllib

from marionette_driver import expected, By, Wait

from gaiatest.apps.base import Base
from gaiatest.apps.base import PageRegion


# Bug 1216626 - Regions should inherit from PageRegion, not Base
[docs]class SearchPanel(Base): _search_results_app_frame_locator = (By.CSS_SELECTOR, '.searchWindow.active iframe') _search_results_locator = (By.CSS_SELECTOR, 'gaia-grid .icon') _search_suggestion_ok_button_locator = (By.ID, 'suggestions-notice-confirm') _rocketbar_input_locator = (By.ID, 'rocketbar-input') _search_results_offline_locator = (By.ID, 'offline-message') _search_results_offline_settings_locator = (By.ID, 'settings-connectivity') _link_results_locator = (By.CSS_SELECTOR, '#suggestions li') def _switch_to_search_results_frame(self): self.marionette.switch_to_frame() self.marionette.switch_to_frame(self.marionette.find_element(*self._search_results_app_frame_locator)) @property def offline_search_message(self): return self.marionette.find_element(*self._search_results_offline_locator).text @property def is_offline_message_visible(self): return self.is_element_displayed(*self._search_results_offline_locator)
[docs] def tap_offline_settings_button(self): self.marionette.find_element(*self._search_results_offline_settings_locator).tap() from gaiatest.apps.settings.app import Settings settings = Settings(self.marionette) settings.switch_to_settings_app() return settings
[docs] def go_to_url(self, url): # If a URL exists already, clear the field self.marionette.find_element(*self._rocketbar_input_locator).clear() self.keyboard.send(url) #TODO Remove hack once Bug 1062309 is fixed self.marionette.switch_to_frame() Wait(self.marionette).until(lambda m: not self.keyboard.is_keyboard_displayed) self.marionette.find_element(*self._rocketbar_input_locator).tap() Wait(self.marionette).until(lambda m: self.keyboard.is_keyboard_displayed) self.keyboard.tap_enter() if 'http' in urllib.quote(url, safe=':/?=&~').lower(): Wait(self.marionette).until(lambda m: self.apps.displayed_app.name in urllib.quote(url, safe=':/?=&~')) from gaiatest.apps.search.regions.browser import Browser return Browser(self.marionette)
[docs] def wait_for_search_results_to_load(self, minimum_expected_results=1): Wait(self.marionette).until(lambda m: len(m.find_elements( *self._search_results_locator)) > minimum_expected_results)
[docs] def confirm_suggestion_notice(self): confirm = Wait(self.marionette).until(expected.element_present( *self._search_suggestion_ok_button_locator)) Wait(self.marionette).until(expected.element_displayed(confirm)) confirm.tap() Wait(self.marionette).until(expected.element_not_displayed(confirm))
def _is_result_a_webapp(self, result_element): # An app result is to an installable (via marketplace) webapp return '.webapp' in result_element.get_attribute('data-identifier') @property def app_results(self): # An app result is to an installable (via marketplace) webapp return [self.Result(marionette=self.marionette, element=result) for result in self.marionette.find_elements(*self._search_results_locator) if self._is_result_a_webapp(result)] @property def link_results(self): return [self.Result(marionette=self.marionette, element=result) for result in self.marionette.find_elements(*self._link_results_locator)]
[docs] class Result(PageRegion): @property def name(self): return self.root_element.text
[docs] def tap(self): app_name = self.name self.root_element.tap() # Wait for the displayed app to be that we have tapped Wait(self.marionette).until(lambda m: self.apps.displayed_app.name == app_name) self.apps.switch_to_displayed_app() # Wait for title to load (we cannot be more specific because the aut may change) Wait(self.marionette).until(lambda m: bool(m.title))