GUI acceptance tests using environment deployed from packages.
Build: #2913 failed
Job: Oneprovider hardlinks failed
user creates metadata for nonowned hardlink and owner user sees them on original file[1oz 1op deployed]: Test case result
The below summarizes the result of the test " user creates metadata for nonowned hardlink and owner user sees them on original file[1oz 1op deployed]" in build 2,913 of Onedata Products - gui acceptance pkg - Oneprovider hardlinks.
- Description
- user creates metadata for nonowned hardlink and owner user sees them on original file[1oz 1op deployed]
- Test class
- gui.scenarios.test_oneprovider_hardlinks
- Method
- test_user_creates_metadata_for_nonowned_hardlink_and_owner_user_sees_them_on_original_file[1oz_1op_deployed]
- Duration
- 2 mins
- Status
- Failed (New Failure)
Error Log
selenium.common.exceptions.InvalidSessionIdException: Message: invalid session id Stacktrace: #0 0x560caeeac13a <unknown> #1 0x560caeb9243d <unknown> #2 0x560caebd38e3 <unknown> #3 0x560caec06a04 <unknown> #4 0x560caec00eb2 <unknown> #5 0x560caec00105 <unknown> #6 0x560caeb5cc38 <unknown> #7 0x560caee76b3b <unknown> #8 0x560caee7aac1 <unknown> #9 0x560caee63335 <unknown> #10 0x560caee7b642 <unknown> #11 0x560caee4849f <unknown> #12 0x560caeb5b6b6 <unknown> #13 0x7fda460941ca <unknown> #14 0x7fda4609428b __libc_start_main #15 0x560caeb26e6a _start fixturefunc = <function assert_tab_in_modal at 0x7f33049fbec0> request = <FixtureRequest for <Function test_user_creates_metadata_for_nonowned_hardlink_and_owner_user_sees_them_on_original_file[1oz_1op_deployed]>> kwargs = {'browser_id': 'space_owner_browser', 'modal_name': 'File details', 'modals': <class 'tests.gui.utils.common.modals.Mo...ace_owner_browser': <selenium.webdriver.chrome.webdriver.WebDriver (session="4cc833962f43bd622c9bda6f3de004a9")>}, ...} def call_fixture_func( fixturefunc: "_FixtureFunc[FixtureValue]", request: FixtureRequest, kwargs ) -> FixtureValue: if is_generator(fixturefunc): fixturefunc = cast( Callable[..., Generator[FixtureValue, None, None]], fixturefunc ) generator = fixturefunc(**kwargs) try: fixture_result = next(generator) except StopIteration: raise ValueError(f"{request.fixturename} did not yield a value") from None finalizer = functools.partial(_teardown_yield_fixture, fixturefunc, generator) request.addfinalizer(finalizer) else: fixturefunc = cast(Callable[..., FixtureValue], fixturefunc) > fixture_result = fixturefunc(**kwargs) /usr/local/lib/python3.12/dist-packages/_pytest/fixtures.py:913: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ tests/utils/bdd_utils.py:78: in wrapper return fun(*ba.args, **ba.kwargs) /usr/local/lib/python3.12/dist-packages/decorator.py:232: in fun return caller(func, *(extras + args), **kw) tests/utils/utils.py:93: in wrapper return fun(*args, **kwargs) tests/gui/steps/modals/details_modal.py:94: in assert_tab_in_modal active_tab = getattr(modals(selenium[browser_id]), tests/gui/utils/core/web_elements.py:59: in __get__ elem = super(WebItem, self).__get__(instance, owner) tests/gui/utils/core/web_elements.py:29: in __get__ return find_web_elem(instance.web_elem, self.css_sel, tests/gui/utils/generic.py:134: in find_web_elem _scroll_to_css_sel(web_elem_root, css_sel) tests/gui/utils/generic.py:179: in _scroll_to_css_sel driver.execute_script(f"var el = (typeof $ === 'function' ? " /usr/local/lib/python3.12/dist-packages/selenium/webdriver/remote/webdriver.py:414: in execute_script return self.execute(command, {"script": script, "args": converted_args})["value"] /usr/local/lib/python3.12/dist-packages/selenium/webdriver/remote/webdriver.py:354: in execute self.error_handler.check_response(response) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <selenium.webdriver.remote.errorhandler.ErrorHandler object at 0x7f33044f03b0> response = {'status': 404, 'value': '{"value":{"error":"invalid session id","message":"invalid session id","stacktrace":"#0 0x560...nknown>\\n#13 0x7fda460941ca \\u003Cunknown>\\n#14 0x7fda4609428b __libc_start_main\\n#15 0x560caeb26e6a _start\\n"}}'} def check_response(self, response: Dict[str, Any]) -> None: """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 not status or status == ErrorCode.SUCCESS: return value = None message = response.get("message", "") screen: str = response.get("screen", "") stacktrace = None if isinstance(status, int): value_json = response.get("value", None) if value_json and isinstance(value_json, str): import json try: value = json.loads(value_json) if len(value) == 1: value = value["value"] status = value.get("error", None) if not status: status = value.get("status", ErrorCode.UNKNOWN_ERROR) message = value.get("value") or value.get("message") if not isinstance(message, str): value = message message = message.get("message") else: message = value.get("message", None) except ValueError: pass exception_class: Type[WebDriverException] e = ErrorCode() error_codes = [item for item in dir(e) if not item.startswith("__")] for error_code in error_codes: error_info = getattr(ErrorCode, error_code) if isinstance(error_info, list) and status in error_info: exception_class = getattr(ExceptionMapping, error_code, WebDriverException) break else: exception_class = WebDriverException if not value: value = response["value"] if isinstance(value, str): raise exception_class(value) if message == "" and "message" in value: message = value["message"] screen = None # type: ignore[assignment] if "screen" in value: screen = value["screen"] stacktrace = None st_value = value.get("stackTrace") or value.get("stacktrace") if st_value: if isinstance(st_value, str): stacktrace = st_value.split("\n") else: stacktrace = [] try: for frame in st_value: line = frame.get("lineNumber", "") file = frame.get("fileName", "<anonymous>") if line: file = f"{file}:{line}" meth = frame.get("methodName", "<anonymous>") if "className" in frame: meth = f"{frame['className']}.{meth}" msg = " at %s (%s)" msg = msg % (meth, file) stacktrace.append(msg) except TypeError: pass if 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) # type: ignore[call-arg] # mypy is not smart enough here > raise exception_class(message, screen, stacktrace) E selenium.common.exceptions.InvalidSessionIdException: Message: invalid session id E Stacktrace: E #0 0x560caeeac13a <unknown> E #1 0x560caeb9243d <unknown> E #2 0x560caebd38e3 <unknown> E #3 0x560caec06a04 <unknown> E #4 0x560caec00eb2 <unknown> E #5 0x560caec00105 <unknown> E #6 0x560caeb5cc38 <unknown> E #7 0x560caee76b3b <unknown> E #8 0x560caee7aac1 <unknown> E #9 0x560caee63335 <unknown> E #10 0x560caee7b642 <unknown> E #11 0x560caee4849f <unknown> E #12 0x560caeb5b6b6 <unknown> E #13 0x7fda460941ca <unknown> E #14 0x7fda4609428b __libc_start_main E #15 0x560caeb26e6a _start /usr/local/lib/python3.12/dist-packages/selenium/webdriver/remote/errorhandler.py:229: InvalidSessionIdException