Acceptance tests using different clients concurrently. Environment deployed from packages.
Build: #1554 failed
Job: Onepanel failed
files tree with specified depth is imported to space after changing max depth option[1oz 1op 1oc-web GUi-RESt]: Test case result
The below summarizes the result of the test " files tree with specified depth is imported to space after changing max depth option[1oz 1op 1oc-web GUi-RESt]" in build 1,554 of Onedata Products - mixed acceptance pkg - Chrome onepanel tests.
- Description
- files tree with specified depth is imported to space after changing max depth option[1oz 1op 1oc-web GUi-RESt]
- Test class
- mixed.scenarios.test_onepanel_basic
- Method
- test_files_tree_with_specified_depth_is_imported_to_space_after_changing_max_depth_option[1oz_1op_1oc-web GUI-REST]
- Duration
- 9 mins
- Status
- Failed (New Failure)
Error Log
RuntimeError: no with "Files" text found in Space in DataPage in Onezone page config = '- dir2:\n - dir21\n - dir22\n - file1.txt: 22222' selenium = {'browsers': <selenium.webdriver.chrome.webdriver.WebDriver (session="e120485a11045cbad1592eefa291ddf6")>, 'onepanel':...2eefa291ddf6")>, 'user1': <selenium.webdriver.chrome.webdriver.WebDriver (session="52de573fefb32e5824af2808786ed26d")>} user = 'user1', op_container = <class 'tests.gui.utils.oneprovider.OPLoggedIn'> tmp_memory = defaultdict(<class 'dict'>, {'onepanel': {'shares': {}, 'spaces': {}, 'groups': {}, 'mailbox': {'token': 'MDAzM2xvY2F0...E2MjE2OTI1MjQKMDAyZnNpZ25hdHVyZSDI8XhD9DVnjRjr7uSn9KU6VsxbWdKJvJHLm5EtlQuyAgo'}, 'oz': {}, 'window': {'modal': None}}}) tmpdir = local('/tmp/pytest-of-bamboo/pytest-0/test_files_tree_with_specified1') space_name = 'space1', oz_page = <class 'tests.gui.utils.onezone.OZLoggedIn'> provider = 'oneprovider-1' hosts = {'oneclient-1': {'container-id': '47fafb0d9bdc6b0abe88507af2cb832a960ab4163d7046d969421ff6cc12979c', 'ip': '172.17.0.2...8475810fa19a2a', 'hostname': 'dev-onezone.default.svc.cluster.local', 'ip': '172.17.0.12', 'name': 'dev-onezone', ...}} def assert_space_content_in_op_gui(config, selenium, user, op_container, tmp_memory, tmpdir, space_name, oz_page, provider, hosts): try: assert_file_browser_in_files_tab_in_op(selenium, user, op_container, > tmp_memory) tests/gui/meta_steps/oneprovider/data.py:208: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ args = ({'browsers': <selenium.webdriver.chrome.webdriver.WebDriver (session="e120485a11045cbad1592eefa291ddf6")>, 'onepanel'...2MjE2OTI1MjQKMDAyZnNpZ25hdHVyZSDI8XhD9DVnjRjr7uSn9KU6VsxbWdKJvJHLm5EtlQuyAgo'}, 'oz': {}, 'window': {'modal': None}}})) kwargs = {} ba = <BoundArguments (selenium={'onepanel': <selenium.webdriver.chrome.webdriver.WebDriver (session="e120485a11045cbad1592e...SDI8XhD9DVnjRjr7uSn9KU6VsxbWdKJvJHLm5EtlQuyAgo'}, 'oz': {}, 'window': {'modal': None}}}), item_browser='file browser')> param = <Parameter "item_browser='file browser'"> ann = <class 'inspect._empty'> @wraps(fun) def wrapper(*args, **kwargs): ba = sig.bind(*args, **kwargs) ba.apply_defaults() for param in parameters.values(): ann = param.annotation if ann is not inspect.Parameter.empty: value = ba.arguments[param.name] try: if not isinstance(value, ann): ba.arguments[param.name] = ann(value) except Exception as ex: msg = f"Cannot cast '{param.name}' <{value}> to {ann}" raise ValueError(msg) from ex > return fun(*ba.args, **ba.kwargs) tests/utils/bdd_utils.py:77: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ selenium = {'browsers': <selenium.webdriver.chrome.webdriver.WebDriver (session="e120485a11045cbad1592eefa291ddf6")>, 'onepanel':...2eefa291ddf6")>, 'user1': <selenium.webdriver.chrome.webdriver.WebDriver (session="52de573fefb32e5824af2808786ed26d")>} browser_id = 'user1' op_container = <class 'tests.gui.utils.oneprovider.OPLoggedIn'> tmp_memory = defaultdict(<class 'dict'>, {'onepanel': {'shares': {}, 'spaces': {}, 'groups': {}, 'mailbox': {'token': 'MDAzM2xvY2F0...E2MjE2OTI1MjQKMDAyZnNpZ25hdHVyZSDI8XhD9DVnjRjr7uSn9KU6VsxbWdKJvJHLm5EtlQuyAgo'}, 'oz': {}, 'window': {'modal': None}}}) item_browser = 'file browser' @wt(parsers.parse('user of {browser_id} sees {item_browser} ' 'in files tab in Oneprovider page')) def assert_file_browser_in_files_tab_in_op(selenium, browser_id, op_container, tmp_memory, item_browser='file browser'): > switch_to_iframe(selenium, browser_id) tests/gui/steps/oneprovider/data_tab.py:237: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ selenium = {'browsers': <selenium.webdriver.chrome.webdriver.WebDriver (session="e120485a11045cbad1592eefa291ddf6")>, 'onepanel':...2eefa291ddf6")>, 'user1': <selenium.webdriver.chrome.webdriver.WebDriver (session="52de573fefb32e5824af2808786ed26d")>} browser_id = 'user1', selector = None > ??? <decorator-gen-37>:2: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ fun = <function switch_to_iframe at 0x7f401fe45e18> args = ({'browsers': <selenium.webdriver.chrome.webdriver.WebDriver (session="e120485a11045cbad1592eefa291ddf6")>, 'onepanel'... 'user1': <selenium.webdriver.chrome.webdriver.WebDriver (session="52de573fefb32e5824af2808786ed26d")>}, 'user1', None) kwargs = {}, now = 1621606255.9219685, limit = 1621606345.9219685 i = 1621606346.820987 @decorator def wrapper(fun, *args, **kwargs): now = time() limit, i = (now + timeout, now) if timeout else (attempts, 0) while i < limit: try: result = fun(*args, **kwargs) except exceptions: sleep(interval) i = time() if timeout else i+1 continue else: return result > return fun(*args, **kwargs) tests/utils/utils.py:90: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ selenium = {'browsers': <selenium.webdriver.chrome.webdriver.WebDriver (session="e120485a11045cbad1592eefa291ddf6")>, 'onepanel':...2eefa291ddf6")>, 'user1': <selenium.webdriver.chrome.webdriver.WebDriver (session="52de573fefb32e5824af2808786ed26d")>} browser_id = 'user1', selector = None @repeat_failed(interval=1, timeout=90, exceptions=NoSuchElementException) def switch_to_iframe(selenium, browser_id, selector=None): driver = selenium[browser_id] driver.switch_to.default_content() > iframe = driver.find_element_by_tag_name('iframe') tests/gui/steps/common/miscellaneous.py:108: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <selenium.webdriver.chrome.webdriver.WebDriver (session="52de573fefb32e5824af2808786ed26d")> name = 'iframe' def find_element_by_tag_name(self, name): """ Finds an element by tag name. :Args: - name - name of html tag (eg: h1, a, span) :Returns: - WebElement - the element if it was found :Raises: - NoSuchElementException - if the element wasn't found :Usage: element = driver.find_element_by_tag_name('h1') """ > return self.find_element(by=By.TAG_NAME, value=name) /usr/local/lib/python3.6/dist-packages/selenium/webdriver/remote/webdriver.py:529: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <selenium.webdriver.chrome.webdriver.WebDriver (session="52de573fefb32e5824af2808786ed26d")> by = 'css selector', value = 'iframe' def find_element(self, by=By.ID, value=None): """ Find an element given a By strategy and locator. Prefer the find_element_by_* methods when possible. :Usage: element = driver.find_element(By.ID, 'foo') :rtype: WebElement """ if self.w3c: if by == By.ID: by = By.CSS_SELECTOR value = '[id="%s"]' % value elif by == By.TAG_NAME: by = By.CSS_SELECTOR elif by == By.CLASS_NAME: by = By.CSS_SELECTOR value = ".%s" % value elif by == By.NAME: by = By.CSS_SELECTOR value = '[name="%s"]' % value return self.execute(Command.FIND_ELEMENT, { 'using': by, > 'value': value})['value'] /usr/local/lib/python3.6/dist-packages/selenium/webdriver/remote/webdriver.py:966: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <selenium.webdriver.chrome.webdriver.WebDriver (session="52de573fefb32e5824af2808786ed26d")> driver_command = 'findElement' params = {'using': 'css selector', 'value': 'iframe'} def execute(self, driver_command, params=None): """ Sends a command to be executed by a command.CommandExecutor. :Args: - driver_command: The name of the command to execute as a string. - params: A dictionary of named parameters to send with the command. :Returns: The command's JSON response loaded into a dictionary object. """ if self.session_id is not None: if not params: params = {'sessionId': self.session_id} elif 'sessionId' not in params: params['sessionId'] = self.session_id params = self._wrap_value(params) response = self.command_executor.execute(driver_command, params) if response: > self.error_handler.check_response(response) /usr/local/lib/python3.6/dist-packages/selenium/webdriver/remote/webdriver.py:320: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <selenium.webdriver.remote.errorhandler.ErrorHandler object at 0x7f401c241908> response = {'status': 404, 'value': '{"value":{"error":"no such element","message":"no such element: Unable to locate element: {\...ector\\":\\"iframe\\"}\\n (Session info: chrome=78.0.3904.70)","stacktrace":"#0 0x564086f127e9 \\u003Cunknown>\\n"}}'} def check_response(self, response): """ Checks that a JSON response from the WebDriver does not have an error. :Args: - response - The JSON response from the WebDriver server as a dictionary object. :Raises: If the response contains an error message. """ status = response.get('status', None) if status is None or status == ErrorCode.SUCCESS: return value = None message = response.get("message", "") screen = response.get("screen", "") stacktrace = None if isinstance(status, int): value_json = response.get('value', None) if value_json and isinstance(value_json, basestring): import json try: value = json.loads(value_json) if len(value.keys()) == 1: value = value['value'] status = value.get('error', None) if status is None: status = value["status"] message = value["value"] if not isinstance(message, basestring): value = message message = message.get('message') else: message = value.get('message', None) except ValueError: pass exception_class = ErrorInResponseException if status in ErrorCode.NO_SUCH_ELEMENT: exception_class = NoSuchElementException elif status in ErrorCode.NO_SUCH_FRAME: exception_class = NoSuchFrameException elif status in ErrorCode.NO_SUCH_WINDOW: exception_class = NoSuchWindowException elif status in ErrorCode.STALE_ELEMENT_REFERENCE: exception_class = StaleElementReferenceException elif status in ErrorCode.ELEMENT_NOT_VISIBLE: exception_class = ElementNotVisibleException elif status in ErrorCode.INVALID_ELEMENT_STATE: exception_class = InvalidElementStateException elif status in ErrorCode.INVALID_SELECTOR \ or status in ErrorCode.INVALID_XPATH_SELECTOR \ or status in ErrorCode.INVALID_XPATH_SELECTOR_RETURN_TYPER: exception_class = InvalidSelectorException elif status in ErrorCode.ELEMENT_IS_NOT_SELECTABLE: exception_class = ElementNotSelectableException elif status in ErrorCode.ELEMENT_NOT_INTERACTABLE: exception_class = ElementNotInteractableException elif status in ErrorCode.INVALID_COOKIE_DOMAIN: exception_class = InvalidCookieDomainException elif status in ErrorCode.UNABLE_TO_SET_COOKIE: exception_class = UnableToSetCookieException elif status in ErrorCode.TIMEOUT: exception_class = TimeoutException elif status in ErrorCode.SCRIPT_TIMEOUT: exception_class = TimeoutException elif status in ErrorCode.UNKNOWN_ERROR: exception_class = WebDriverException elif status in ErrorCode.UNEXPECTED_ALERT_OPEN: exception_class = UnexpectedAlertPresentException elif status in ErrorCode.NO_ALERT_OPEN: exception_class = NoAlertPresentException elif status in ErrorCode.IME_NOT_AVAILABLE: exception_class = ImeNotAvailableException elif status in ErrorCode.IME_ENGINE_ACTIVATION_FAILED: exception_class = ImeActivationFailedException elif status in ErrorCode.MOVE_TARGET_OUT_OF_BOUNDS: exception_class = MoveTargetOutOfBoundsException elif status in ErrorCode.JAVASCRIPT_ERROR: exception_class = JavascriptException elif status in ErrorCode.SESSION_NOT_CREATED: exception_class = SessionNotCreatedException elif status in ErrorCode.INVALID_ARGUMENT: exception_class = InvalidArgumentException elif status in ErrorCode.NO_SUCH_COOKIE: exception_class = NoSuchCookieException elif status in ErrorCode.UNABLE_TO_CAPTURE_SCREEN: exception_class = ScreenshotException elif status in ErrorCode.ELEMENT_CLICK_INTERCEPTED: exception_class = ElementClickInterceptedException elif status in ErrorCode.INSECURE_CERTIFICATE: exception_class = InsecureCertificateException elif status in ErrorCode.INVALID_COORDINATES: exception_class = InvalidCoordinatesException elif status in ErrorCode.INVALID_SESSION_ID: exception_class = InvalidSessionIdException elif status in ErrorCode.UNKNOWN_METHOD: exception_class = UnknownMethodException else: exception_class = WebDriverException if value == '' or value is None: value = response['value'] if isinstance(value, basestring): if exception_class == ErrorInResponseException: raise exception_class(response, value) raise exception_class(value) if message == "" and 'message' in value: message = value['message'] screen = None if 'screen' in value: screen = value['screen'] stacktrace = None if 'stackTrace' in value and value['stackTrace']: stacktrace = [] try: for frame in value['stackTrace']: line = self._value_or_default(frame, 'lineNumber', '') file = self._value_or_default(frame, 'fileName', '<anonymous>') if line: file = "%s:%s" % (file, line) meth = self._value_or_default(frame, 'methodName', '<anonymous>') if 'className' in frame: meth = "%s.%s" % (frame['className'], meth) msg = " at %s (%s)" msg = msg % (meth, file) stacktrace.append(msg) except TypeError: pass if exception_class == ErrorInResponseException: raise exception_class(response, message) elif exception_class == UnexpectedAlertPresentException: alert_text = None if 'data' in value: alert_text = value['data'].get('text') elif 'alert' in value: alert_text = value['alert'].get('text') raise exception_class(message, screen, stacktrace, alert_text) > raise exception_class(message, screen, stacktrace) E selenium.common.exceptions.NoSuchElementException: Message: no such element: Unable to locate element: {"method":"css selector","selector":"iframe"} E (Session info: chrome=78.0.3904.70) /usr/local/lib/python3.6/dist-packages/selenium/webdriver/remote/errorhandler.py:242: NoSuchElementException During handling of the above exception, another exception occurred: request = <FixtureRequest for <Function 'test_files_tree_with_specified_depth_is_imported_to_space_after_changing_max_depth_option[1oz_1op_1oc-web GUI-REST]'>> @pytest.mark.usefixtures(*function_args) def scenario_wrapper(request): > _execute_scenario(feature, scenario, request, encoding) /usr/local/lib/python3.6/dist-packages/pytest_bdd/scenario.py:227: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ /usr/local/lib/python3.6/dist-packages/pytest_bdd/scenario.py:189: in _execute_scenario _execute_step_function(request, scenario, step, step_func) /usr/local/lib/python3.6/dist-packages/pytest_bdd/scenario.py:130: in _execute_step_function step_func(**kwargs) tests/utils/bdd_utils.py:77: in wrapper return fun(*ba.args, **ba.kwargs) <decorator-gen-1039>:2: in assert_space_content_in_op ??? tests/utils/utils.py:90: in wrapper return fun(*args, **kwargs) tests/mixed/steps/onepanel_basic.py:537: in assert_space_content_in_op host, hosts) tests/gui/meta_steps/oneprovider/data.py:211: in assert_space_content_in_op_gui tmp_memory, space_name) tests/utils/bdd_utils.py:77: in wrapper return fun(*ba.args, **ba.kwargs) tests/gui/meta_steps/oneprovider/data.py:396: in go_to_filebrowser oz_page) tests/utils/bdd_utils.py:77: in wrapper return fun(*ba.args, **ba.kwargs) <decorator-gen-775>:2: in click_on_option_of_space_on_left_sidebar_menu ??? tests/utils/utils.py:90: in wrapper return fun(*args, **kwargs) tests/gui/steps/onezone/spaces.py:272: in click_on_option_of_space_on_left_sidebar_menu transform(option)).click() tests/gui/utils/core/web_elements.py:58: in __get__ elem = super(WebItem, self).__get__(instance, owner) tests/gui/utils/core/web_elements.py:52: in __get__ lambda: self._format_msg(err_msg, instance, _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ web_elem_root = <selenium.webdriver.remote.webelement.WebElement (session="52de573fefb32e5824af2808786ed26d", element="eafcacf7-0b36-4549-9056-7a018aa1ce42")> css_sel = '.one-list-level-2 .item-header', text = 'Files' err_msg = 'no with "Files" text found in Space in DataPage in Onezone page' def find_web_elem_with_text(web_elem_root, css_sel, text, err_msg): items = web_elem_root.find_elements_by_css_selector(css_sel) _scroll_to_css_sel(web_elem_root, css_sel) for item in items: if item.text.lower() == text.lower(): return item else: with suppress(TypeError): err_msg = err_msg() > raise RuntimeError(err_msg) E RuntimeError: no with "Files" text found in Space in DataPage in Onezone page tests/gui/utils/generic.py:111: RuntimeError