Run Test: slices-bi-singlenode-login 2026-05-11 18:13:24.025639 CEST - Run: /usr/local/bin/uv pip install --upgrade slices-cli --extra-index-url=https://doc.slices-ri.eu/pypi/ 2026-05-11 18:13:27.197209 CEST - Run: slices --version 2026-05-11 18:13:27.411648 CEST - version: Slices CLI v2025.1.5 Slices CLI core v1.1.2 Slices CLI bi v2.0.2 Slices clientlib core v5.5.1 Slices clientlib bi v5.1.2 2026-05-11 18:13:27.411923 CEST - Run: slices pubkey list --format text 2026-05-11 18:13:28.027120 CEST - Pubkey already registered 2026-05-11 18:13:28.027422 CEST - Run: slices bi infrastructure list --format csv --all --refresh 2026-05-11 18:13:28.592488 CEST - Refreshed infrastructure list. Total: 22 entries. 2026-05-11 18:13:28.592600 CEST - Check List Flavors 2026-05-11 18:13:28.592780 CEST - Run: slices bi --infra es-bilbao-bi-vm1 flavor list -f json 2026-05-11 18:14:30.313907 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/step_ListFlavors_command_1.txt': /opt/slices-monitor-worker/slices-cli-venv/bin/slices bi --infra es-bilbao-bi-vm1 flavor list -f json 2026-05-11 18:14:30.314120 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/flavor-list_STDERR.txt': ╭───────────────────── Traceback (most recent call last) ──────────────────────╮ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_transports/default.py:101 in map_httpcore_exceptions │ │ │ │ 98 │ if len(HTTPCORE_EXC_MAP) == 0: │ │ 99 │ │ HTTPCORE_EXC_MAP = _load_httpcore_exceptions() │ │ 100 │ try: │ │ ❱ 101 │ │ yield │ │ 102 │ except Exception as exc: │ │ 103 │ │ mapped_exc = None │ │ 104 │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_transports/default.py:250 in handle_request │ │ │ │ 247 │ │ │ extensions=request.extensions, │ │ 248 │ │ ) │ │ 249 │ │ with map_httpcore_exceptions(): │ │ ❱ 250 │ │ │ resp = self._pool.handle_request(req) │ │ 251 │ │ │ │ 252 │ │ assert isinstance(resp.stream, typing.Iterable) │ │ 253 │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ core/_sync/connection_pool.py:256 in handle_request │ │ │ │ 253 │ │ │ │ closing = self._assign_requests_to_connections() │ │ 254 │ │ │ │ │ 255 │ │ │ self._close_connections(closing) │ │ ❱ 256 │ │ │ raise exc from None │ │ 257 │ │ │ │ 258 │ │ # Return the response. Note that in this case we still have to │ │ manage │ │ 259 │ │ # the point at which the response is closed. │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ core/_sync/connection_pool.py:236 in handle_request │ │ │ │ 233 │ │ │ │ │ │ 234 │ │ │ │ try: │ │ 235 │ │ │ │ │ # Send the request on the assigned connection. │ │ ❱ 236 │ │ │ │ │ response = connection.handle_request( │ │ 237 │ │ │ │ │ │ pool_request.request │ │ 238 │ │ │ │ │ ) │ │ 239 │ │ │ │ except ConnectionNotAvailable: │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ core/_sync/connection.py:101 in handle_request │ │ │ │ 98 │ │ │ │ │ │ ) │ │ 99 │ │ except BaseException as exc: │ │ 100 │ │ │ self._connect_failed = True │ │ ❱ 101 │ │ │ raise exc │ │ 102 │ │ │ │ 103 │ │ return self._connection.handle_request(request) │ │ 104 │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ core/_sync/connection.py:78 in handle_request │ │ │ │ 75 │ │ try: │ │ 76 │ │ │ with self._request_lock: │ │ 77 │ │ │ │ if self._connection is None: │ │ ❱ 78 │ │ │ │ │ stream = self._connect(request) │ │ 79 │ │ │ │ │ │ │ 80 │ │ │ │ │ ssl_object = stream.get_extra_info("ssl_object") │ │ 81 │ │ │ │ │ http2_negotiated = ( │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ core/_sync/connection.py:156 in _connect │ │ │ │ 153 │ │ │ │ │ │ "timeout": timeout, │ │ 154 │ │ │ │ │ } │ │ 155 │ │ │ │ │ with Trace("start_tls", logger, request, kwargs) │ │ as trace: │ │ ❱ 156 │ │ │ │ │ │ stream = stream.start_tls(**kwargs) │ │ 157 │ │ │ │ │ │ trace.return_value = stream │ │ 158 │ │ │ │ return stream │ │ 159 │ │ │ except (ConnectError, ConnectTimeout): │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ core/_backends/sync.py:154 in start_tls │ │ │ │ 151 │ │ │ socket.timeout: ConnectTimeout, │ │ 152 │ │ │ OSError: ConnectError, │ │ 153 │ │ } │ │ ❱ 154 │ │ with map_exceptions(exc_map): │ │ 155 │ │ │ try: │ │ 156 │ │ │ │ if isinstance(self._sock, ssl.SSLSocket): # pragma: │ │ no cover │ │ 157 │ │ │ │ │ # If the underlying socket has already been │ │ upgraded │ │ │ │ /opt/uv-python-installs/cpython-3.14.1-linux-x86_64-gnu/lib/python3.14/conte │ │ xtlib.py:162 in __exit__ │ │ │ │ 159 │ │ │ │ # tell if we get the same exception back │ │ 160 │ │ │ │ value = typ() │ │ 161 │ │ │ try: │ │ ❱ 162 │ │ │ │ self.gen.throw(value) │ │ 163 │ │ │ except StopIteration as exc: │ │ 164 │ │ │ │ # Suppress StopIteration *unless* it's the same │ │ exception that │ │ 165 │ │ │ │ # was passed to throw(). This prevents a │ │ StopIteration │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ core/_exceptions.py:14 in map_exceptions │ │ │ │ 11 │ except Exception as exc: # noqa: PIE786 │ │ 12 │ │ for from_exc, to_exc in map.items(): │ │ 13 │ │ │ if isinstance(exc, from_exc): │ │ ❱ 14 │ │ │ │ raise to_exc(exc) from exc │ │ 15 │ │ raise # pragma: nocover │ │ 16 │ │ 17 │ ╰──────────────────────────────────────────────────────────────────────────────╯ ConnectError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: certificate has expired (_ssl.c:1081) The above exception was the direct cause of the following exception: ╭───────────────────── Traceback (most recent call last) ──────────────────────╮ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/slic │ │ es_clientlib_core/util/pagination.py:84 in __init__ │ │ │ │ 81 │ │ self._client = client │ │ 82 │ │ self._params = params │ │ 83 │ │ try: │ │ ❱ 84 │ │ │ response = self._client.get(url, params=params) │ │ 85 │ │ except HttpCoreConnectError as err: │ │ 86 │ │ │ raise ApiConnectError(url) from err │ │ 87 │ │ except HttpxConnectError as err: │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_client.py:1053 in get │ │ │ │ 1050 │ │ │ │ 1051 │ │ **Parameters**: See `httpx.request`. │ │ 1052 │ │ """ │ │ ❱ 1053 │ │ return self.request( │ │ 1054 │ │ │ "GET", │ │ 1055 │ │ │ url, │ │ 1056 │ │ │ params=params, │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_client.py:825 in request │ │ │ │ 822 │ │ │ timeout=timeout, │ │ 823 │ │ │ extensions=extensions, │ │ 824 │ │ ) │ │ ❱ 825 │ │ return self.send(request, auth=auth, │ │ follow_redirects=follow_redirects) │ │ 826 │ │ │ 827 │ @contextmanager │ │ 828 │ def stream( │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_client.py:914 in send │ │ │ │ 911 │ │ │ │ 912 │ │ auth = self._build_request_auth(request, auth) │ │ 913 │ │ │ │ ❱ 914 │ │ response = self._send_handling_auth( │ │ 915 │ │ │ request, │ │ 916 │ │ │ auth=auth, │ │ 917 │ │ │ follow_redirects=follow_redirects, │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_client.py:942 in _send_handling_auth │ │ │ │ 939 │ │ │ request = next(auth_flow) │ │ 940 │ │ │ │ │ 941 │ │ │ while True: │ │ ❱ 942 │ │ │ │ response = self._send_handling_redirects( │ │ 943 │ │ │ │ │ request, │ │ 944 │ │ │ │ │ follow_redirects=follow_redirects, │ │ 945 │ │ │ │ │ history=history, │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_client.py:979 in _send_handling_redirects │ │ │ │ 976 │ │ │ for hook in self._event_hooks["request"]: │ │ 977 │ │ │ │ hook(request) │ │ 978 │ │ │ │ │ ❱ 979 │ │ │ response = self._send_single_request(request) │ │ 980 │ │ │ try: │ │ 981 │ │ │ │ for hook in self._event_hooks["response"]: │ │ 982 │ │ │ │ │ hook(response) │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_client.py:1014 in _send_single_request │ │ │ │ 1011 │ │ │ ) │ │ 1012 │ │ │ │ 1013 │ │ with request_context(request=request): │ │ ❱ 1014 │ │ │ response = transport.handle_request(request) │ │ 1015 │ │ │ │ 1016 │ │ assert isinstance(response.stream, SyncByteStream) │ │ 1017 │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_transports/default.py:249 in handle_request │ │ │ │ 246 │ │ │ content=request.stream, │ │ 247 │ │ │ extensions=request.extensions, │ │ 248 │ │ ) │ │ ❱ 249 │ │ with map_httpcore_exceptions(): │ │ 250 │ │ │ resp = self._pool.handle_request(req) │ │ 251 │ │ │ │ 252 │ │ assert isinstance(resp.stream, typing.Iterable) │ │ │ │ /opt/uv-python-installs/cpython-3.14.1-linux-x86_64-gnu/lib/python3.14/conte │ │ xtlib.py:162 in __exit__ │ │ │ │ 159 │ │ │ │ # tell if we get the same exception back │ │ 160 │ │ │ │ value = typ() │ │ 161 │ │ │ try: │ │ ❱ 162 │ │ │ │ self.gen.throw(value) │ │ 163 │ │ │ except StopIteration as exc: │ │ 164 │ │ │ │ # Suppress StopIteration *unless* it's the same │ │ exception that │ │ 165 │ │ │ │ # was passed to throw(). This prevents a │ │ StopIteration │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/http │ │ x/_transports/default.py:118 in map_httpcore_exceptions │ │ │ │ 115 │ │ │ raise │ │ 116 │ │ │ │ 117 │ │ message = str(exc) │ │ ❱ 118 │ │ raise mapped_exc(message) from exc │ │ 119 │ │ 120 │ │ 121 class ResponseStream(SyncByteStream): │ ╰──────────────────────────────────────────────────────────────────────────────╯ ConnectError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: certificate has expired (_ssl.c:1081) The above exception was the direct cause of the following exception: ╭───────────────────── Traceback (most recent call last) ──────────────────────╮ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/slic │ │ es_cli_bi/commands/bi_flavor.py:37 in wrapper_handle_some_exceptions │ │ │ │ 34 │ def wrapper_handle_some_exceptions(*args, **kwargs): │ │ 35 │ │ """Function wrapper for handle_some_exceptions.""" # noqa: │ │ D401 │ │ 36 │ │ try: │ │ ❱ 37 │ │ │ return func(*args, **kwargs) │ │ 38 │ │ except ServiceException as e: │ │ 39 │ │ │ err_console.print("[red]There was a connection problem. │ │ The service might be down. :zap:") │ │ 40 │ │ │ err_console.print(f"[red]Details: │ │ {get_api_error_detail(e)}") │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/slic │ │ es_cli_bi/commands/bi_flavor.py:360 in list_flavors │ │ │ │ 357 │ ] = "table", # type: ignore │ │ 358 ): │ │ 359 │ """List flavors.""" │ │ ❱ 360 │ flavors = │ │ ctx.obj.api.for_project(ctx.obj.require_project_id()).bi(ctx.obj.infra │ │ _id).flavor.list() │ │ 361 │ │ │ 362 │ # we need to run over the flavors twice, so we need to store them │ │ in a list │ │ 363 │ flavors = list(flavors) │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/slic │ │ es_clientlib_bi/bi_flavor.py:239 in list │ │ │ │ 236 │ │ res: list[Collection[AnyFlavor]] = [] │ │ 237 │ │ │ │ 238 │ │ if include_global_flavors: │ │ ❱ 239 │ │ │ res.append(PagedCollection("flavor", AnyFlavor, │ │ f"{self.API_BASE_PATH}flavors/", self._client)) # pyright: ignore │ │ [reportArgumentType] │ │ 240 │ │ if include_project_flavors: │ │ 241 │ │ │ try: │ │ 242 │ │ │ │ res.append( │ │ │ │ /opt/slices-monitor-worker/slices-cli-venv/lib/python3.14/site-packages/slic │ │ es_clientlib_core/util/pagination.py:88 in __init__ │ │ │ │ 85 │ │ except HttpCoreConnectError as err: │ │ 86 │ │ │ raise ApiConnectError(url) from err │ │ 87 │ │ except HttpxConnectError as err: │ │ ❱ 88 │ │ │ raise ApiConnectError(url) from err │ │ 89 │ │ try: │ │ 90 │ │ │ response.raise_for_status() │ │ 91 │ │ │ self._first_page = self._decoder.decode(response.content) │ ╰──────────────────────────────────────────────────────────────────────────────╯ ApiConnectError: Connection Error connection to /apis/bi.slices.eu/v1/flavors/ 2026-05-11 18:14:30.314208 CEST - Error in test step 'List Flavors': "slices bi flavor list" failed 2026-05-11 18:14:30.314235 CEST - Step 'List Flavors' took 61.72 seconds, which is longer than the warning threshold of 5 seconds 2026-05-11 18:14:30.314261 CEST - Destroying tst-4a3c9982 tst 2026-05-11 18:14:30.314395 CEST - Run: slices bi --infra es-bilbao-bi-vm1 destroy --experiment tst-4a3c9982 tst 2026-05-11 18:14:30.930029 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/step_Destroy_command_1.txt': /opt/slices-monitor-worker/slices-cli-venv/bin/slices bi --infra es-bilbao-bi-vm1 destroy --experiment tst-4a3c9982 tst 2026-05-11 18:14:30.930109 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/destroy.txt': Could not retrieve experiment tst-4a3c9982 ❌ 2026-05-11 18:14:30.930133 CEST - Error in test step 'Destroy': "slices bi destroy" failed (return value is 1) 2026-05-11 18:14:30.930160 CEST - Wait 2s before retry 2026-05-11 18:14:33.546163 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/step_DestroyRetry1_retry1_command_1.txt': /opt/slices-monitor-worker/slices-cli-venv/bin/slices bi --infra es-bilbao-bi-vm1 destroy --experiment tst-4a3c9982 tst 2026-05-11 18:14:33.546243 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/destroy_retry1.txt': Could not retrieve experiment tst-4a3c9982 ❌ 2026-05-11 18:14:33.546266 CEST - Error in test step 'Destroy (Retry 1)': "slices bi destroy" failed (return value is 1) 2026-05-11 18:14:33.546292 CEST - Wait 2s before retry 2026-05-11 18:14:36.162357 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/step_DestroyRetry2_retry2_command_1.txt': /opt/slices-monitor-worker/slices-cli-venv/bin/slices bi --infra es-bilbao-bi-vm1 destroy --experiment tst-4a3c9982 tst 2026-05-11 18:14:36.162461 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/destroy_retry2.txt': Could not retrieve experiment tst-4a3c9982 ❌ 2026-05-11 18:14:36.162485 CEST - Error in test step 'Destroy (Retry 2)': "slices bi destroy" failed (return value is 1) 2026-05-11 18:14:36.162508 CEST - Wait 2s before retry 2026-05-11 18:14:38.829412 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/step_DestroyRetry3_retry3_command_1.txt': /opt/slices-monitor-worker/slices-cli-venv/bin/slices bi --infra es-bilbao-bi-vm1 destroy --experiment tst-4a3c9982 tst 2026-05-11 18:14:38.829513 CEST - Content of log file '/opt/slices-monitor-worker/slices_monitor_tests/18917b02-2aea-4cba-8fbb-a9a44cf2b58d/destroy_retry3.txt': Could not retrieve experiment tst-4a3c9982 ❌ 2026-05-11 18:14:38.829539 CEST - Error in test step 'Destroy (Retry 3)': "slices bi destroy" failed (return value is 1)