--- BVT pytest attempt 2026-05-31T19:55:29.321915+00:00 (/.local/bin/uv run pytest...) --- 2026-05-31T19:55:31.212887Z [info ] Writing tests log to /home/odh/opendatahub-tests/results/pytest-tests.log [conftest] 2026-05-31T19:55:31.213223Z [info ] Trying to get client via new_client_from_config [ocp_resources.resource] 2026-05-31T19:55:31.266458Z [info ] kind: DataScienceCluster api version: datasciencecluster.opendatahub.io/v2 [ocp_resources.resource] 2026-05-31T19:55:31.285993Z [info ] kind: DSCInitialization api version: dscinitialization.opendatahub.io/v2 [ocp_resources.resource] ============================= test session starts ============================== platform linux -- Python 3.14.5, pytest-9.0.3, pluggy-1.6.0 -- /home/odh/opendatahub-tests/.venv/bin/python cachedir: .pytest_cache metadata: {'Python': '3.14.5', 'Platform': 'Linux-5.14.0-427.115.1.el9_4.x86_64-x86_64-with-glibc2.42', 'Packages': {'pytest': '9.0.3', 'pluggy': '1.6.0'}, 'Plugins': {'anyio': '4.13.0', 'langsmith': '0.8.7', 'asyncio': '1.4.0', 'dependency': '0.6.1', 'html': '4.2.0', 'metadata': '3.1.1', 'order': '1.4.0', 'progress': '1.4.0', 'testconfig': '0.2.0', 'xdist': '3.8.0', 'syrupy': '5.2.0'}} rootdir: /home/odh/opendatahub-tests configfile: pytest.ini plugins: anyio-4.13.0, langsmith-0.8.7, asyncio-1.4.0, dependency-0.6.1, html-4.2.0, metadata-3.1.1, order-1.4.0, progress-1.4.0, testconfig-0.2.0, xdist-3.8.0, syrupy-5.2.0 asyncio: mode=Mode.STRICT, debug=False, asyncio_default_fixture_loop_scope=None, asyncio_default_test_loop_scope=function collecting ... collected 13 items / 8 deselected / 5 selected tests/workbenches/notebooks_server/controller/test_spawning.py::TestNotebook::test_create_simple_notebook[unprivileged_model_namespace0-users_persistent_volume_claim0-default_notebook0-notebook_pod0]  test_create_simple_notebook[unprivileged_model_namespace0-users_persistent_volume_claim0-default_notebook0-notebook_pod0]  -------------------------------------------------------- SETUP -------------------------------------------------------- 2026-05-31T19:55:31.363122Z [info ] Executing session fixture: event_loop_policy [conftest] 2026-05-31T19:55:31.363309Z [info ] Executing session fixture: _syrupy_apply_ide_patches [conftest] 2026-05-31T19:55:31.363473Z [info ] Executing session fixture: admin_client [conftest] 2026-05-31T19:55:31.364538Z [info ] Trying to get client via new_client_from_config [ocp_resources.resource] 2026-05-31T19:55:31.364825Z [info ] Executing session fixture: dsc_resource [conftest] 2026-05-31T19:55:31.365003Z [info ] kind: DataScienceCluster api version: datasciencecluster.opendatahub.io/v2 [ocp_resources.resource] 2026-05-31T19:55:31.391506Z [info ] Executing session fixture: tmp_path_factory [conftest] 2026-05-31T19:55:31.391792Z [info ] Executing session fixture: tests_tmp_dir [conftest] 2026-05-31T19:55:31.392648Z [info ] Executing session fixture: os_path_environment [conftest] 2026-05-31T19:55:31.392908Z [info ] Executing session fixture: tmpdir_factory [conftest] 2026-05-31T19:55:31.393136Z [info ] Executing session fixture: bin_directory [conftest] 2026-05-31T19:55:31.393954Z [info ] Executing session fixture: oc_binary_path [conftest] 2026-05-31T19:55:31.398499Z [info ] kind: ConsoleCLIDownload api version: console.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:55:31.405877Z [info ] All oc console cli download links: ['https://downloads-openshift-console.apps.4ed60ce3-84b6-41a8-991f-fe50c950dde5.prod.konfluxeaas.com/amd64/linux/oc.tar'] [utilities.infra] name=utilities.infra 2026-05-31T19:55:31.406050Z [info ] Downloading archive using: url=https://downloads-openshift-console.apps.4ed60ce3-84b6-41a8-991f-fe50c950dde5.prod.konfluxeaas.com/amd64/linux/oc.tar [utilities.infra] name=utilities.infra 2026-05-31T19:55:32.212731Z [info ] Extract the downloaded archive. [utilities.infra] name=utilities.infra 2026-05-31T19:55:32.306768Z [info ] Downloaded file: ['oc']  [utilities.infra] name=utilities.infra 2026-05-31T19:55:32.328531Z [info ] Executing session fixture: bin_directory_to_os_path [conftest] 2026-05-31T19:55:32.327018Z [info ] OC binary path: /tmp/pytest-nj6dLnTZx9VCBuYvU8su7f/bin0/oc [tests.conftest] name=tests.conftest 2026-05-31T19:55:32.327080Z [info ] Adding /tmp/pytest-nj6dLnTZx9VCBuYvU8su7f/bin0 to $PATH [tests.conftest] name=tests.conftest 2026-05-31T19:55:32.328994Z [info ] Executing session fixture: nodes [conftest] 2026-05-31T19:55:32.530261Z [info ] Executing session fixture: dsci_resource [conftest] 2026-05-31T19:55:32.530535Z [info ] kind: DSCInitialization api version: dscinitialization.opendatahub.io/v2 [ocp_resources.resource] 2026-05-31T19:55:32.534714Z [info ] Executing session fixture: record_testsuite_property [conftest] 2026-05-31T19:55:32.534960Z [info ] Executing session fixture: junitxml_plugin [conftest] 2026-05-31T19:55:32.535149Z [info ] Executing session fixture: cluster_sanity_scope_session [conftest] 2026-05-31T19:55:32.534025Z [info ] Check cluster sanity.  [utilities.infra] name=utilities.infra 2026-05-31T19:55:32.535515Z [info ] Verify all nodes are in a healthy condition. [ocp_utilities.infra] 2026-05-31T19:55:32.546357Z [info ] Verify all nodes are schedulable. [ocp_utilities.infra] 2026-05-31T19:55:32.558553Z [info ] Waiting for 120 seconds [0:02:00], retry every 5 seconds. (Function: utilities.infra.wait_for_dsci_status_ready Kwargs: {'dsci_resource': }) [timeout_sampler] 2026-05-31T19:55:32.557923Z [info ] Wait for DSCI default-dsci to be in Ready status. [utilities.infra] name=utilities.infra 2026-05-31T19:55:32.558892Z [info ] Get DSCInitialization default-dsci status [ocp_resources DSCInitialization] 2026-05-31T19:55:32.563165Z [info ] Elapsed time: 6.175041198730469e-05 [0:00:00.000062] [timeout_sampler] 2026-05-31T19:55:32.563434Z [info ] Waiting for 120 seconds [0:02:00], retry every 5 seconds. (Function: utilities.infra.wait_for_dsc_status_ready Kwargs: {'dsc_resource': }) [timeout_sampler] 2026-05-31T19:55:32.562461Z [info ] Wait for DSC default-dsc are Ready. [utilities.infra] name=utilities.infra 2026-05-31T19:55:32.563719Z [info ] Get DataScienceCluster default-dsc status [ocp_resources DataScienceCluster] 2026-05-31T19:55:32.568912Z [info ] Elapsed time: 8.58306884765625e-05 [0:00:00.000086] [timeout_sampler] 2026-05-31T19:55:32.569160Z [info ] Executing session fixture: autouse_fixtures [conftest] 2026-05-31T19:55:32.569512Z [info ] Executing session fixture: pytestconfig [conftest] 2026-05-31T19:55:32.569657Z [info ] Executing session fixture: use_unprivileged_client [conftest] 2026-05-31T19:55:32.569785Z [info ] Executing session fixture: kubconfig_filepath [conftest] 2026-05-31T19:55:32.569920Z [info ] Executing session fixture: cluster_authentication [conftest] 2026-05-31T19:55:32.570053Z [info ] kind: Authentication api version: config.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:55:32.572499Z [info ] Executing session fixture: is_byoidc [conftest] 2026-05-31T19:55:32.577586Z [info ] Executing session fixture: non_admin_user_password [conftest] 2026-05-31T19:55:32.577731Z [info ] Executing session fixture: unprivileged_client [conftest] 2026-05-31T19:55:32.575795Z [warning ] Unprivileged client is not enabled, using admin client [tests.conftest] name=tests.conftest 2026-05-31T19:55:32.577997Z [info ] Executing session fixture: teardown_resources [conftest] 2026-05-31T19:55:32.578130Z [info ] Executing class fixture: unprivileged_model_namespace [conftest] 2026-05-31T19:55:32.578265Z [info ] kind: ProjectRequest api version: project.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:55:32.578421Z [info ] Create ProjectRequest test-odh-notebook [ocp_resources ProjectRequest] 2026-05-31T19:55:32.578561Z [info ] Posting {'apiVersion': 'project.openshift.io/v1', 'kind': 'ProjectRequest', 'metadata': {'name': 'test-odh-notebook', 'labels': {'opendatahub.io/dashboard': 'true'}}} [ocp_resources ProjectRequest] 2026-05-31T19:55:32.639044Z [info ] kind: Project api version: project.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:55:32.639217Z [info ] Wait for Project test-odh-notebook status to be Active [ocp_resources Project] 2026-05-31T19:55:32.639413Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait_for_status.lambda: self.exists) [timeout_sampler] 2026-05-31T19:55:32.648548Z [info ] Status of Project test-odh-notebook is Active [ocp_resources Project] 2026-05-31T19:55:32.648780Z [info ] Elapsed time: 3.266334533691406e-05 [0:00:00.000033] [timeout_sampler] 2026-05-31T19:55:32.648945Z [info ] ResourceEdits: Updating data for resource Namespace test-odh-notebook [ocp_resources.resource] 2026-05-31T19:55:32.649101Z [info ] Update Namespace test-odh-notebook: {'metadata': {'labels': {'opendatahub.io/dashboard': 'true'}, 'name': 'test-odh-notebook'}} [ocp_resources Namespace] 2026-05-31T19:55:32.663712Z [info ] Executing function fixture: minimal_image [conftest] 2026-05-31T19:55:32.683483Z [info ] kind: ClusterServiceVersion api version: operators.coreos.com/v1alpha1 [ocp_resources.resource] 2026-05-31T19:55:32.779814Z [info ] Executing function fixture: notebook_image [conftest] 2026-05-31T19:55:32.855710Z [info ] kind: Config api version: imageregistry.operator.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:55:32.864928Z [info ] Image registry management state: managed, available: True [utilities.infra] name=utilities.infra 2026-05-31T19:55:32.866785Z [info ] Executing function fixture: users_persistent_volume_claim [conftest] 2026-05-31T19:55:32.866947Z [info ] Create PersistentVolumeClaim test-odh-notebook [ocp_resources PersistentVolumeClaim] 2026-05-31T19:55:32.867125Z [info ] Posting {'apiVersion': 'v1', 'kind': 'PersistentVolumeClaim', 'metadata': {'name': 'test-odh-notebook', 'labels': {'opendatahub.io/dashboard': 'true'}, 'namespace': 'test-odh-notebook'}, 'spec': {'volumeMode': 'Filesystem', 'accessModes': ['ReadWriteOnce'], 'resources': {'requests': {'storage': '10Gi'}}}} [ocp_resources PersistentVolumeClaim] 2026-05-31T19:55:32.903466Z [info ] Executing function fixture: default_notebook [conftest] 2026-05-31T19:55:32.903623Z [info ] kind: SelfSubjectReview api version: authentication.k8s.io/v1 [ocp_resources.resource] 2026-05-31T19:55:32.903752Z [info ] Create SelfSubjectReview selfSubjectReview [ocp_resources SelfSubjectReview] 2026-05-31T19:55:32.903878Z [info ] Posting {'apiVersion': 'authentication.k8s.io/v1', 'kind': 'SelfSubjectReview', 'metadata': {'name': 'selfSubjectReview'}} [ocp_resources SelfSubjectReview] 2026-05-31T19:55:32.930933Z [info ] kind: Notebook api version: kubeflow.org/v1 [ocp_resources.resource] 2026-05-31T19:55:32.931209Z [info ] Create Notebook test-odh-notebook [ocp_resources Notebook] 2026-05-31T19:55:32.931448Z [info ] Posting {'apiVersion': 'kubeflow.org/v1', 'kind': 'Notebook', 'metadata': {'annotations': {'notebooks.opendatahub.io/inject-auth': 'true', 'opendatahub.io/accelerator-name': '', 'notebooks.opendatahub.io/last-image-selection': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5'}, 'finalizers': ['notebook.opendatahub.io/kube-rbac-proxy-cleanup'], 'labels': {'app': 'test-odh-notebook', 'opendatahub.io/dashboard': 'true', 'opendatahub.io/odh-managed': 'true'}, 'name': 'test-odh-notebook', 'namespace': 'test-odh-notebook'}, 'spec': {'template': {'spec': {'affinity': {}, 'containers': [{'env': [{'name': 'NOTEBOOK_ARGS', 'value': "--ServerApp.port=8888\n --ServerApp.token=''\n --ServerApp.password=''\n --ServerApp.base_url=/notebook/test-odh-notebook/test-odh-notebook\n --ServerApp.quit_button=False\n"}, {'name': 'JUPYTER_IMAGE', 'value': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5'}], 'image': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5', 'imagePullPolicy': 'Always', 'livenessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/notebook/test-odh-notebook/test-odh-notebook/api', 'port': 'notebook-port', 'scheme': 'HTTP'}, 'initialDelaySeconds': 10, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'name': 'test-odh-notebook', 'ports': [{'containerPort': 8888, 'name': 'notebook-port', 'protocol': 'TCP'}], 'readinessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/notebook/test-odh-notebook/test-odh-notebook/api', 'port': 'notebook-port', 'scheme': 'HTTP'}, 'initialDelaySeconds': 10, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'resources': {'limits': {'cpu': '2', 'memory': '4Gi'}, 'requests': {'cpu': '1', 'memory': '1Gi'}}, 'volumeMounts': [{'mountPath': '/opt/app-root/src', 'name': 'test-odh-notebook'}, {'mountPath': '/dev/shm', 'name': 'shm'}], 'workingDir': '/opt/app-root/src'}], 'enableServiceLinks': False, 'serviceAccountName': 'test-odh-notebook', 'volumes': [{'name': 'test-odh-notebook', 'persistentVolumeClaim': {'claimName': 'test-odh-notebook'}}, {'emptyDir': {'medium': 'Memory'}, 'name': 'shm'}, {'name': 'kube-rbac-proxy-config', 'configMap': {'defaultMode': 420, 'name': 'test-kube-rbac-proxy-config'}}, {'name': 'kube-rbac-proxy-tls-certificates', 'secret': {'defaultMode': 420, 'secretName': 'test-kube-rbac-proxy-tls'}}]}}}} [ocp_resources Notebook] 2026-05-31T19:55:33.298120Z [info ] Executing function fixture: notebook_pod [conftest] 2026-05-31T19:55:33.298332Z [info ] Wait until Pod test-odh-notebook-0 is created [ocp_resources Pod] 2026-05-31T19:55:33.298506Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait.lambda: self.exists) [timeout_sampler] 2026-05-31T19:55:34.309170Z [info ] Elapsed time: 1.0054962635040283 [0:00:01.005496] [timeout_sampler] 2026-05-31T19:55:34.309421Z [info ] Wait for Pod/test-odh-notebook-0's 'Ready' condition to be 'True' [ocp_resources Pod] 2026-05-31T19:55:34.309590Z [info ] Wait until Pod test-odh-notebook-0 is created [ocp_resources Pod] 2026-05-31T19:55:34.309721Z [info ] Waiting for 120 seconds [0:02:00], retry every 1 seconds. (Function: ocp_resources.resource.wait.lambda: self.exists) [timeout_sampler] 2026-05-31T19:55:34.312417Z [info ] Elapsed time: 3.0517578125e-05 [0:00:00.000031] [timeout_sampler] 2026-05-31T19:55:34.312565Z [info ] Waiting for 119.99649214744568 seconds [0:01:59.996492], retry every 1 seconds. (Function: ocp_resources.resource.wait_for_condition.lambda: self.instance) [timeout_sampler] 2026-05-31T19:56:24.642234Z [info ] Elapsed time: 50.32203984260559 [0:00:50.322040] [timeout_sampler] --------------------------------------------------------- CALL --------------------------------------------------------- PASSED TEST: TestNotebook.test_create_simple_notebook[unprivileged_model_namespace0-users_persistent_volume_claim0-default_notebook0-notebook_pod0] STATUS: PASSED ------------------------------------------------------- TEARDOWN ------------------------------------------------------- 2026-05-31T19:56:24.651005Z [info ] Delete Notebook test-odh-notebook [ocp_resources Notebook] 2026-05-31T19:56:24.668720Z [info ] Deleting {'apiVersion': 'kubeflow.org/v1', 'kind': 'Notebook', 'metadata': {'annotations': {'notebooks.opendatahub.io/inject-auth': 'true', 'notebooks.opendatahub.io/last-image-selection': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5', 'opendatahub.io/accelerator-name': ''}, 'creationTimestamp': '2026-05-31T19:55:33Z', 'finalizers': ['notebook.opendatahub.io/kube-rbac-proxy-cleanup', 'notebook.opendatahub.io/httproute-cleanup', 'notebook.opendatahub.io/referencegrant-cleanup'], 'generation': 1, 'labels': {'app': 'test-odh-notebook', 'opendatahub.io/dashboard': 'true', 'opendatahub.io/odh-managed': 'true'}, 'managedFields': [{'apiVersion': 'kubeflow.org/v1', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'.': {}, 'f:notebooks.opendatahub.io/inject-auth': {}, 'f:notebooks.opendatahub.io/last-image-selection': {}, 'f:opendatahub.io/accelerator-name': {}}, 'f:finalizers': {'.': {}, 'v:"notebook.opendatahub.io/kube-rbac-proxy-cleanup"': {}}, 'f:labels': {'.': {}, 'f:app': {}, 'f:opendatahub.io/dashboard': {}, 'f:opendatahub.io/odh-managed': {}}}, 'f:spec': {'.': {}, 'f:template': {'.': {}, 'f:spec': {'.': {}, 'f:affinity': {}, 'f:containers': {'.': {}, 'k:{"name":"test-odh-notebook"}': {'.': {}, 'f:env': {'.': {}, 'k:{"name":"JUPYTER_IMAGE"}': {'.': {}, 'f:name': {}, 'f:value': {}}, 'k:{"name":"NOTEBOOK_ARGS"}': {'.': {}, 'f:name': {}, 'f:value': {}}}, 'f:image': {}, 'f:imagePullPolicy': {}, 'f:livenessProbe': {'.': {}, 'f:failureThreshold': {}, 'f:httpGet': {'.': {}, 'f:path': {}, 'f:port': {}, 'f:scheme': {}}, 'f:initialDelaySeconds': {}, 'f:periodSeconds': {}, 'f:successThreshold': {}, 'f:timeoutSeconds': {}}, 'f:name': {}, 'f:ports': {'.': {}, 'k:{"containerPort":8888,"protocol":"TCP"}': {'.': {}, 'f:containerPort': {}, 'f:name': {}, 'f:protocol': {}}}, 'f:readinessProbe': {'.': {}, 'f:failureThreshold': {}, 'f:httpGet': {'.': {}, 'f:path': {}, 'f:port': {}, 'f:scheme': {}}, 'f:initialDelaySeconds': {}, 'f:periodSeconds': {}, 'f:successThreshold': {}, 'f:timeoutSeconds': {}}, 'f:resources': {'.': {}, 'f:limits': {'.': {}, 'f:cpu': {}, 'f:memory': {}}, 'f:requests': {'.': {}, 'f:cpu': {}, 'f:memory': {}}}, 'f:volumeMounts': {'.': {}, 'k:{"mountPath":"/dev/shm"}': {'.': {}, 'f:mountPath': {}, 'f:name': {}}, 'k:{"mountPath":"/opt/app-root/src"}': {'.': {}, 'f:mountPath': {}, 'f:name': {}}}, 'f:workingDir': {}}}, 'f:enableServiceLinks': {}, 'f:serviceAccountName': {}, 'f:volumes': {'.': {}, 'k:{"name":"kube-rbac-proxy-config"}': {'.': {}, 'f:configMap': {}, 'f:name': {}}, 'k:{"name":"kube-rbac-proxy-tls-certificates"}': {'.': {}, 'f:name': {}, 'f:secret': {'.': {}, 'f:defaultMode': {}, 'f:secretName': {}}}, 'k:{"name":"shm"}': {'.': {}, 'f:emptyDir': {'.': {}, 'f:medium': {}}, 'f:name': {}}, 'k:{"name":"test-odh-notebook"}': {'.': {}, 'f:name': {}, 'f:persistentVolumeClaim': {'.': {}, 'f:claimName': {}}}}}}}}, 'manager': 'OpenAPI-Generator', 'operation': 'Update', 'time': '2026-05-31T19:55:32Z'}, {'apiVersion': 'kubeflow.org/v1', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:finalizers': {'v:"notebook.opendatahub.io/httproute-cleanup"': {}, 'v:"notebook.opendatahub.io/referencegrant-cleanup"': {}}}}, 'manager': 'manager', 'operation': 'Update', 'time': '2026-05-31T19:55:33Z'}, {'apiVersion': 'kubeflow.org/v1beta1', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:status': {'.': {}, 'f:conditions': {}, 'f:containerState': {'.': {}, 'f:running': {'.': {}, 'f:startedAt': {}}}, 'f:readyReplicas': {}}}, 'manager': 'manager', 'operation': 'Update', 'subresource': 'status', 'time': '2026-05-31T19:56:24Z'}], 'name': 'test-odh-notebook', 'namespace': 'test-odh-notebook', 'resourceVersion': '29233', 'uid': '6fe0e10c-0853-494b-96e1-1f719ffbfdb6'}, 'spec': {'template': {'spec': {'affinity': {}, 'containers': [{'env': [{'name': 'NOTEBOOK_ARGS', 'value': "--ServerApp.port=8888\n --ServerApp.token=''\n --ServerApp.password=''\n --ServerApp.base_url=/notebook/test-odh-notebook/test-odh-notebook\n --ServerApp.quit_button=False\n"}, {'name': 'JUPYTER_IMAGE', 'value': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5'}, {'name': 'GIT_SSL_CAINFO', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'PIP_CERT', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'REQUESTS_CA_BUNDLE', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'SSL_CERT_FILE', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'PIPELINES_SSL_SA_CERTS', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'KF_PIPELINES_SSL_SA_CERTS', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}], 'image': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5', 'imagePullPolicy': 'Always', 'livenessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/notebook/test-odh-notebook/test-odh-notebook/api', 'port': 'notebook-port', 'scheme': 'HTTP'}, 'initialDelaySeconds': 10, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'name': 'test-odh-notebook', 'ports': [{'containerPort': 8888, 'name': 'notebook-port', 'protocol': 'TCP'}], 'readinessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/notebook/test-odh-notebook/test-odh-notebook/api', 'port': 'notebook-port', 'scheme': 'HTTP'}, 'initialDelaySeconds': 10, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'resources': {'limits': {'cpu': '2', 'memory': '4Gi'}, 'requests': {'cpu': '1', 'memory': '1Gi'}}, 'volumeMounts': [{'mountPath': '/opt/app-root/src', 'name': 'test-odh-notebook'}, {'mountPath': '/dev/shm', 'name': 'shm'}, {'mountPath': '/etc/pki/tls/custom-certs', 'name': 'trusted-ca', 'readOnly': True}, {'mountPath': '/opt/app-root/pipeline-runtimes/', 'name': 'runtime-images'}], 'workingDir': '/opt/app-root/src'}, {'args': ['--secure-listen-address=0.0.0.0:8443', '--upstream=http://127.0.0.1:8888/', '--logtostderr=true', '--v=10', '--proxy-endpoints-port=8444', '--config-file=/etc/kube-rbac-proxy/config-file.yaml', '--tls-cert-file=/etc/tls/private/tls.crt', '--tls-private-key-file=/etc/tls/private/tls.key', '--auth-header-fields-enabled=true', '--auth-header-user-field-name=X-Auth-Request-User', '--auth-header-groups-field-name=X-Auth-Request-Groups'], 'image': 'quay.io/opendatahub/odh-kube-rbac-proxy@sha256:3daf2e94277e39b8b29814c0ccb87e83c578ba7b196e84eac288b4de3ce145b7', 'imagePullPolicy': 'Always', 'livenessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/healthz', 'port': 8444, 'scheme': 'HTTPS'}, 'initialDelaySeconds': 30, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'name': 'kube-rbac-proxy', 'ports': [{'containerPort': 8443, 'name': 'kube-rbac-proxy', 'protocol': 'TCP'}], 'readinessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/healthz', 'port': 8444, 'scheme': 'HTTPS'}, 'initialDelaySeconds': 5, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'resources': {'limits': {'cpu': '100m', 'memory': '64Mi'}, 'requests': {'cpu': '100m', 'memory': '64Mi'}}, 'volumeMounts': [{'mountPath': '/etc/kube-rbac-proxy', 'name': 'kube-rbac-proxy-config'}, {'mountPath': '/etc/tls/private', 'name': 'kube-rbac-proxy-tls-certificates'}]}], 'enableServiceLinks': False, 'serviceAccountName': 'test-odh-notebook', 'volumes': [{'name': 'test-odh-notebook', 'persistentVolumeClaim': {'claimName': 'test-odh-notebook'}}, {'emptyDir': {'medium': 'Memory'}, 'name': 'shm'}, {'configMap': {'defaultMode': 420, 'name': 'test-odh-notebook-kube-rbac-proxy-config'}, 'name': 'kube-rbac-proxy-config'}, {'name': 'kube-rbac-proxy-tls-certificates', 'secret': {'defaultMode': 420, 'secretName': 'test-odh-notebook-kube-rbac-proxy-tls'}}, {'configMap': {'name': 'workbench-trusted-ca-bundle', 'optional': True}, 'name': 'trusted-ca'}, {'configMap': {'name': 'pipeline-runtime-images', 'optional': True}, 'name': 'runtime-images'}]}}}, 'status': {'conditions': [{'lastProbeTime': '2026-05-31T19:56:24Z', 'lastTransitionTime': '2026-05-31T19:56:13Z', 'status': 'True', 'type': 'PodReadyToStartContainers'}, {'lastProbeTime': '2026-05-31T19:56:24Z', 'lastTransitionTime': '2026-05-31T19:55:37Z', 'status': 'True', 'type': 'Initialized'}, {'lastProbeTime': '2026-05-31T19:56:24Z', 'lastTransitionTime': '2026-05-31T19:56:24Z', 'status': 'True', 'type': 'Ready'}, {'lastProbeTime': '2026-05-31T19:56:24Z', 'lastTransitionTime': '2026-05-31T19:56:24Z', 'status': 'True', 'type': 'ContainersReady'}, {'lastProbeTime': '2026-05-31T19:56:24Z', 'lastTransitionTime': '2026-05-31T19:55:37Z', 'status': 'True', 'type': 'PodScheduled'}], 'containerState': {'running': {'startedAt': '2026-05-31T19:56:11Z'}}, 'readyReplicas': 1}} [ocp_resources Notebook] 2026-05-31T19:56:24.680811Z [info ] Wait until Notebook test-odh-notebook is deleted [ocp_resources Notebook] 2026-05-31T19:56:24.681054Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait_deleted.lambda: self.exists) [timeout_sampler] 2026-05-31T19:56:25.691321Z [info ] Elapsed time: 1.0043797492980957 [0:00:01.004380] [timeout_sampler] 2026-05-31T19:56:25.691518Z [info ] Delete PersistentVolumeClaim test-odh-notebook [ocp_resources PersistentVolumeClaim] 2026-05-31T19:56:25.704670Z [info ] Deleting {'kind': 'PersistentVolumeClaim', 'apiVersion': 'v1', 'metadata': {'name': 'test-odh-notebook', 'namespace': 'test-odh-notebook', 'uid': 'a591b326-a18a-41fd-8703-1c317f9410b8', 'resourceVersion': '28539', 'creationTimestamp': '2026-05-31T19:55:32Z', 'labels': {'opendatahub.io/dashboard': 'true'}, 'annotations': {'pv.kubernetes.io/bind-completed': 'yes', 'pv.kubernetes.io/bound-by-controller': 'yes', 'volume.beta.kubernetes.io/storage-provisioner': 'ebs.csi.aws.com', 'volume.kubernetes.io/selected-node': 'ip-10-0-130-57.ec2.internal', 'volume.kubernetes.io/storage-provisioner': 'ebs.csi.aws.com'}, 'finalizers': ['kubernetes.io/pvc-protection'], 'managedFields': [{'manager': 'OpenAPI-Generator', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:32Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:labels': {'.': {}, 'f:opendatahub.io/dashboard': {}}}, 'f:spec': {'f:accessModes': {}, 'f:resources': {'f:requests': {'.': {}, 'f:storage': {}}}, 'f:volumeMode': {}}}}, {'manager': 'kube-scheduler', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:34Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'.': {}, 'f:volume.kubernetes.io/selected-node': {}}}}}, {'manager': 'kube-controller-manager', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:36Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'f:pv.kubernetes.io/bind-completed': {}, 'f:pv.kubernetes.io/bound-by-controller': {}, 'f:volume.beta.kubernetes.io/storage-provisioner': {}, 'f:volume.kubernetes.io/storage-provisioner': {}}}, 'f:spec': {'f:volumeName': {}}}}, {'manager': 'kube-controller-manager', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:36Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:status': {'f:accessModes': {}, 'f:capacity': {'.': {}, 'f:storage': {}}, 'f:phase': {}}}, 'subresource': 'status'}]}, 'spec': {'accessModes': ['ReadWriteOnce'], 'resources': {'requests': {'storage': '10Gi'}}, 'volumeName': 'pvc-a591b326-a18a-41fd-8703-1c317f9410b8', 'storageClassName': 'gp3-csi', 'volumeMode': 'Filesystem'}, 'status': {'phase': 'Bound', 'accessModes': ['ReadWriteOnce'], 'capacity': {'storage': '10Gi'}}} [ocp_resources PersistentVolumeClaim] 2026-05-31T19:56:25.710760Z [info ] Wait until PersistentVolumeClaim test-odh-notebook is deleted [ocp_resources PersistentVolumeClaim] 2026-05-31T19:56:25.710916Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait_deleted.lambda: self.exists) [timeout_sampler] 2026-05-31T19:56:26.719897Z [info ] Elapsed time: 1.0033743381500244 [0:00:01.003374] [timeout_sampler] 2026-05-31T19:56:26.723212Z [info ] Delete Project test-odh-notebook [ocp_resources Project] 2026-05-31T19:56:26.737385Z [info ] Deleting {'kind': 'Project', 'apiVersion': 'project.openshift.io/v1', 'metadata': {'name': 'test-odh-notebook', 'uid': '4d7a85fa-86eb-41a9-b2d5-09b14225324d', 'resourceVersion': '28400', 'creationTimestamp': '2026-05-31T19:55:32Z', 'labels': {'kubernetes.io/metadata.name': 'test-odh-notebook', 'opendatahub.io/dashboard': 'true', 'pod-security.kubernetes.io/audit': 'restricted', 'pod-security.kubernetes.io/audit-version': 'latest', 'pod-security.kubernetes.io/warn': 'restricted', 'pod-security.kubernetes.io/warn-version': 'latest'}, 'annotations': {'openshift.io/description': '', 'openshift.io/display-name': '', 'openshift.io/requester': 'system:admin', 'openshift.io/sa.scc.mcs': 's0:c28,c7', 'openshift.io/sa.scc.supplemental-groups': '1000770000/10000', 'openshift.io/sa.scc.uid-range': '1000770000/10000', 'security.openshift.io/MinimallySufficientPodSecurityStandard': 'restricted'}, 'managedFields': [{'manager': 'pod-security-admission-label-synchronization-controller', 'operation': 'Apply', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:32Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'f:security.openshift.io/MinimallySufficientPodSecurityStandard': {}}, 'f:labels': {'f:pod-security.kubernetes.io/audit': {}, 'f:pod-security.kubernetes.io/audit-version': {}, 'f:pod-security.kubernetes.io/warn': {}, 'f:pod-security.kubernetes.io/warn-version': {}}}}}, {'manager': 'OpenAPI-Generator', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:32Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:labels': {'f:opendatahub.io/dashboard': {}}}}}, {'manager': 'cluster-policy-controller', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:32Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'f:openshift.io/sa.scc.mcs': {}, 'f:openshift.io/sa.scc.supplemental-groups': {}, 'f:openshift.io/sa.scc.uid-range': {}}}}}, {'manager': 'openshift-apiserver', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:32Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'.': {}, 'f:openshift.io/description': {}, 'f:openshift.io/display-name': {}, 'f:openshift.io/requester': {}}, 'f:labels': {'.': {}, 'f:kubernetes.io/metadata.name': {}}}}}, {'manager': 'openshift-controller-manager', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:55:32Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:spec': {'f:finalizers': {}}}, 'subresource': 'finalize'}]}, 'spec': {'finalizers': ['kubernetes']}, 'status': {'phase': 'Active'}} [ocp_resources Project] 2026-05-31T19:56:26.747665Z [info ] Wait until Project test-odh-notebook is deleted [ocp_resources Project] 2026-05-31T19:56:26.747851Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait_deleted.lambda: self.exists) [timeout_sampler] _ 1 of 5 completed, 1 Pass, 0 Fail, 0 Skip, 0 XPass, 0 XFail, 0 Error, 0 ReRun _ tests/workbenches/notebooks_server/controller/test_spawning.py::TestNotebook::test_auth_container_resource_customization[unprivileged_model_namespace0-users_persistent_volume_claim0-default_notebook0-notebook_pod0] 2026-05-31T19:56:33.803817Z [info ] Elapsed time: 7.047794342041016 [0:00:07.047794] [timeout_sampler]  test_auth_container_resource_customization[unprivileged_model_namespace0-users_persistent_volume_claim0-default_notebook0-notebook_pod0]  -------------------------------------------------------- SETUP -------------------------------------------------------- 2026-05-31T19:56:33.806148Z [info ] Executing class fixture: unprivileged_model_namespace [conftest] 2026-05-31T19:56:33.806341Z [info ] kind: ProjectRequest api version: project.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:56:33.806490Z [info ] Create ProjectRequest test-auth-notebook [ocp_resources ProjectRequest] 2026-05-31T19:56:33.806618Z [info ] Posting {'apiVersion': 'project.openshift.io/v1', 'kind': 'ProjectRequest', 'metadata': {'name': 'test-auth-notebook', 'labels': {'opendatahub.io/dashboard': 'true'}}} [ocp_resources ProjectRequest] 2026-05-31T19:56:33.868906Z [info ] kind: Project api version: project.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:56:33.869075Z [info ] Wait for Project test-auth-notebook status to be Active [ocp_resources Project] 2026-05-31T19:56:33.869232Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait_for_status.lambda: self.exists) [timeout_sampler] 2026-05-31T19:56:33.875517Z [info ] Status of Project test-auth-notebook is Active [ocp_resources Project] 2026-05-31T19:56:33.875722Z [info ] Elapsed time: 3.1948089599609375e-05 [0:00:00.000032] [timeout_sampler] 2026-05-31T19:56:33.876011Z [info ] ResourceEdits: Updating data for resource Namespace test-auth-notebook [ocp_resources.resource] 2026-05-31T19:56:33.876170Z [info ] Update Namespace test-auth-notebook: {'metadata': {'labels': {'opendatahub.io/dashboard': 'true'}, 'name': 'test-auth-notebook'}} [ocp_resources Namespace] 2026-05-31T19:56:33.884039Z [info ] Executing function fixture: minimal_image [conftest] 2026-05-31T19:56:33.931582Z [info ] Executing function fixture: notebook_image [conftest] 2026-05-31T19:56:33.980893Z [info ] kind: Config api version: imageregistry.operator.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:56:33.984744Z [info ] Image registry management state: managed, available: True [utilities.infra] name=utilities.infra 2026-05-31T19:56:33.986508Z [info ] Executing function fixture: users_persistent_volume_claim [conftest] 2026-05-31T19:56:33.986722Z [info ] Create PersistentVolumeClaim test-auth-notebook [ocp_resources PersistentVolumeClaim] 2026-05-31T19:56:33.986878Z [info ] Posting {'apiVersion': 'v1', 'kind': 'PersistentVolumeClaim', 'metadata': {'name': 'test-auth-notebook', 'labels': {'opendatahub.io/dashboard': 'true'}, 'namespace': 'test-auth-notebook'}, 'spec': {'volumeMode': 'Filesystem', 'accessModes': ['ReadWriteOnce'], 'resources': {'requests': {'storage': '10Gi'}}}} [ocp_resources PersistentVolumeClaim] 2026-05-31T19:56:34.000075Z [info ] Executing function fixture: default_notebook [conftest] 2026-05-31T19:56:34.000357Z [info ] kind: SelfSubjectReview api version: authentication.k8s.io/v1 [ocp_resources.resource] 2026-05-31T19:56:34.000527Z [info ] Create SelfSubjectReview selfSubjectReview [ocp_resources SelfSubjectReview] 2026-05-31T19:56:34.000656Z [info ] Posting {'apiVersion': 'authentication.k8s.io/v1', 'kind': 'SelfSubjectReview', 'metadata': {'name': 'selfSubjectReview'}} [ocp_resources SelfSubjectReview] 2026-05-31T19:56:34.010252Z [info ] kind: Notebook api version: kubeflow.org/v1 [ocp_resources.resource] 2026-05-31T19:56:34.010498Z [info ] Create Notebook test-auth-notebook [ocp_resources Notebook] 2026-05-31T19:56:34.010656Z [info ] Posting {'apiVersion': 'kubeflow.org/v1', 'kind': 'Notebook', 'metadata': {'annotations': {'notebooks.opendatahub.io/inject-auth': 'true', 'opendatahub.io/accelerator-name': '', 'notebooks.opendatahub.io/last-image-selection': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5', 'notebooks.opendatahub.io/auth-sidecar-cpu-request': '200m', 'notebooks.opendatahub.io/auth-sidecar-memory-request': '128Mi', 'notebooks.opendatahub.io/auth-sidecar-cpu-limit': '500m', 'notebooks.opendatahub.io/auth-sidecar-memory-limit': '256Mi'}, 'finalizers': ['notebook.opendatahub.io/kube-rbac-proxy-cleanup'], 'labels': {'app': 'test-auth-notebook', 'opendatahub.io/dashboard': 'true', 'opendatahub.io/odh-managed': 'true'}, 'name': 'test-auth-notebook', 'namespace': 'test-auth-notebook'}, 'spec': {'template': {'spec': {'affinity': {}, 'containers': [{'env': [{'name': 'NOTEBOOK_ARGS', 'value': "--ServerApp.port=8888\n --ServerApp.token=''\n --ServerApp.password=''\n --ServerApp.base_url=/notebook/test-auth-notebook/test-auth-notebook\n --ServerApp.quit_button=False\n"}, {'name': 'JUPYTER_IMAGE', 'value': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5'}], 'image': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5', 'imagePullPolicy': 'Always', 'livenessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/notebook/test-auth-notebook/test-auth-notebook/api', 'port': 'notebook-port', 'scheme': 'HTTP'}, 'initialDelaySeconds': 10, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'name': 'test-auth-notebook', 'ports': [{'containerPort': 8888, 'name': 'notebook-port', 'protocol': 'TCP'}], 'readinessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/notebook/test-auth-notebook/test-auth-notebook/api', 'port': 'notebook-port', 'scheme': 'HTTP'}, 'initialDelaySeconds': 10, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'resources': {'limits': {'cpu': '2', 'memory': '4Gi'}, 'requests': {'cpu': '1', 'memory': '1Gi'}}, 'volumeMounts': [{'mountPath': '/opt/app-root/src', 'name': 'test-auth-notebook'}, {'mountPath': '/dev/shm', 'name': 'shm'}], 'workingDir': '/opt/app-root/src'}], 'enableServiceLinks': False, 'serviceAccountName': 'test-auth-notebook', 'volumes': [{'name': 'test-auth-notebook', 'persistentVolumeClaim': {'claimName': 'test-auth-notebook'}}, {'emptyDir': {'medium': 'Memory'}, 'name': 'shm'}, {'name': 'kube-rbac-proxy-config', 'configMap': {'defaultMode': 420, 'name': 'test-kube-rbac-proxy-config'}}, {'name': 'kube-rbac-proxy-tls-certificates', 'secret': {'defaultMode': 420, 'secretName': 'test-kube-rbac-proxy-tls'}}]}}}} [ocp_resources Notebook] 2026-05-31T19:56:34.094539Z [info ] Executing function fixture: notebook_pod [conftest] 2026-05-31T19:56:34.094778Z [info ] Wait until Pod test-auth-notebook-0 is created [ocp_resources Pod] 2026-05-31T19:56:34.094939Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait.lambda: self.exists) [timeout_sampler] 2026-05-31T19:56:35.105595Z [info ] Elapsed time: 1.004608392715454 [0:00:01.004608] [timeout_sampler] 2026-05-31T19:56:35.105799Z [info ] Wait for Pod/test-auth-notebook-0's 'Ready' condition to be 'True' [ocp_resources Pod] 2026-05-31T19:56:35.105959Z [info ] Wait until Pod test-auth-notebook-0 is created [ocp_resources Pod] 2026-05-31T19:56:35.106112Z [info ] Waiting for 120 seconds [0:02:00], retry every 1 seconds. (Function: ocp_resources.resource.wait.lambda: self.exists) [timeout_sampler] 2026-05-31T19:56:35.110619Z [info ] Elapsed time: 3.075599670410156e-05 [0:00:00.000031] [timeout_sampler] 2026-05-31T19:56:35.110793Z [info ] Waiting for 119.99471092224121 seconds [0:01:59.994711], retry every 1 seconds. (Function: ocp_resources.resource.wait_for_condition.lambda: self.instance) [timeout_sampler] 2026-05-31T19:56:54.247116Z [info ] Elapsed time: 19.12855100631714 [0:00:19.128551] [timeout_sampler] --------------------------------------------------------- CALL --------------------------------------------------------- PASSED TEST: TestNotebook.test_auth_container_resource_customization[unprivileged_model_namespace0-users_persistent_volume_claim0-default_notebook0-notebook_pod0] STATUS: PASSED ------------------------------------------------------- TEARDOWN ------------------------------------------------------- 2026-05-31T19:56:54.251906Z [info ] Delete Notebook test-auth-notebook [ocp_resources Notebook] 2026-05-31T19:56:54.271370Z [info ] Deleting {'apiVersion': 'kubeflow.org/v1', 'kind': 'Notebook', 'metadata': {'annotations': {'notebooks.opendatahub.io/auth-sidecar-cpu-limit': '500m', 'notebooks.opendatahub.io/auth-sidecar-cpu-request': '200m', 'notebooks.opendatahub.io/auth-sidecar-memory-limit': '256Mi', 'notebooks.opendatahub.io/auth-sidecar-memory-request': '128Mi', 'notebooks.opendatahub.io/inject-auth': 'true', 'notebooks.opendatahub.io/last-image-selection': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5', 'opendatahub.io/accelerator-name': ''}, 'creationTimestamp': '2026-05-31T19:56:34Z', 'finalizers': ['notebook.opendatahub.io/kube-rbac-proxy-cleanup', 'notebook.opendatahub.io/httproute-cleanup', 'notebook.opendatahub.io/referencegrant-cleanup'], 'generation': 1, 'labels': {'app': 'test-auth-notebook', 'opendatahub.io/dashboard': 'true', 'opendatahub.io/odh-managed': 'true'}, 'managedFields': [{'apiVersion': 'kubeflow.org/v1', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'.': {}, 'f:notebooks.opendatahub.io/auth-sidecar-cpu-limit': {}, 'f:notebooks.opendatahub.io/auth-sidecar-cpu-request': {}, 'f:notebooks.opendatahub.io/auth-sidecar-memory-limit': {}, 'f:notebooks.opendatahub.io/auth-sidecar-memory-request': {}, 'f:notebooks.opendatahub.io/inject-auth': {}, 'f:notebooks.opendatahub.io/last-image-selection': {}, 'f:opendatahub.io/accelerator-name': {}}, 'f:finalizers': {'.': {}, 'v:"notebook.opendatahub.io/kube-rbac-proxy-cleanup"': {}}, 'f:labels': {'.': {}, 'f:app': {}, 'f:opendatahub.io/dashboard': {}, 'f:opendatahub.io/odh-managed': {}}}, 'f:spec': {'.': {}, 'f:template': {'.': {}, 'f:spec': {'.': {}, 'f:affinity': {}, 'f:containers': {'.': {}, 'k:{"name":"test-auth-notebook"}': {'.': {}, 'f:env': {'.': {}, 'k:{"name":"JUPYTER_IMAGE"}': {'.': {}, 'f:name': {}, 'f:value': {}}, 'k:{"name":"NOTEBOOK_ARGS"}': {'.': {}, 'f:name': {}, 'f:value': {}}}, 'f:image': {}, 'f:imagePullPolicy': {}, 'f:livenessProbe': {'.': {}, 'f:failureThreshold': {}, 'f:httpGet': {'.': {}, 'f:path': {}, 'f:port': {}, 'f:scheme': {}}, 'f:initialDelaySeconds': {}, 'f:periodSeconds': {}, 'f:successThreshold': {}, 'f:timeoutSeconds': {}}, 'f:name': {}, 'f:ports': {'.': {}, 'k:{"containerPort":8888,"protocol":"TCP"}': {'.': {}, 'f:containerPort': {}, 'f:name': {}, 'f:protocol': {}}}, 'f:readinessProbe': {'.': {}, 'f:failureThreshold': {}, 'f:httpGet': {'.': {}, 'f:path': {}, 'f:port': {}, 'f:scheme': {}}, 'f:initialDelaySeconds': {}, 'f:periodSeconds': {}, 'f:successThreshold': {}, 'f:timeoutSeconds': {}}, 'f:resources': {'.': {}, 'f:limits': {'.': {}, 'f:cpu': {}, 'f:memory': {}}, 'f:requests': {'.': {}, 'f:cpu': {}, 'f:memory': {}}}, 'f:volumeMounts': {'.': {}, 'k:{"mountPath":"/dev/shm"}': {'.': {}, 'f:mountPath': {}, 'f:name': {}}, 'k:{"mountPath":"/opt/app-root/src"}': {'.': {}, 'f:mountPath': {}, 'f:name': {}}}, 'f:workingDir': {}}}, 'f:enableServiceLinks': {}, 'f:serviceAccountName': {}, 'f:volumes': {'.': {}, 'k:{"name":"kube-rbac-proxy-config"}': {'.': {}, 'f:configMap': {}, 'f:name': {}}, 'k:{"name":"kube-rbac-proxy-tls-certificates"}': {'.': {}, 'f:name': {}, 'f:secret': {'.': {}, 'f:defaultMode': {}, 'f:secretName': {}}}, 'k:{"name":"shm"}': {'.': {}, 'f:emptyDir': {'.': {}, 'f:medium': {}}, 'f:name': {}}, 'k:{"name":"test-auth-notebook"}': {'.': {}, 'f:name': {}, 'f:persistentVolumeClaim': {'.': {}, 'f:claimName': {}}}}}}}}, 'manager': 'OpenAPI-Generator', 'operation': 'Update', 'time': '2026-05-31T19:56:34Z'}, {'apiVersion': 'kubeflow.org/v1', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:finalizers': {'v:"notebook.opendatahub.io/httproute-cleanup"': {}, 'v:"notebook.opendatahub.io/referencegrant-cleanup"': {}}}}, 'manager': 'manager', 'operation': 'Update', 'time': '2026-05-31T19:56:34Z'}, {'apiVersion': 'kubeflow.org/v1beta1', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:status': {'.': {}, 'f:conditions': {}, 'f:containerState': {'.': {}, 'f:running': {'.': {}, 'f:startedAt': {}}}, 'f:readyReplicas': {}}}, 'manager': 'manager', 'operation': 'Update', 'subresource': 'status', 'time': '2026-05-31T19:56:53Z'}], 'name': 'test-auth-notebook', 'namespace': 'test-auth-notebook', 'resourceVersion': '29877', 'uid': 'f2714cbc-c2c6-44ee-b7da-10bf3fa29043'}, 'spec': {'template': {'spec': {'affinity': {}, 'containers': [{'env': [{'name': 'NOTEBOOK_ARGS', 'value': "--ServerApp.port=8888\n --ServerApp.token=''\n --ServerApp.password=''\n --ServerApp.base_url=/notebook/test-auth-notebook/test-auth-notebook\n --ServerApp.quit_button=False\n"}, {'name': 'JUPYTER_IMAGE', 'value': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5'}, {'name': 'PIP_CERT', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'REQUESTS_CA_BUNDLE', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'SSL_CERT_FILE', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'PIPELINES_SSL_SA_CERTS', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'KF_PIPELINES_SSL_SA_CERTS', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}, {'name': 'GIT_SSL_CAINFO', 'value': '/etc/pki/tls/custom-certs/ca-bundle.crt'}], 'image': 'image-registry.openshift-image-registry.svc:5000/redhat-ods-applications/s2i-minimal-notebook:3.5', 'imagePullPolicy': 'Always', 'livenessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/notebook/test-auth-notebook/test-auth-notebook/api', 'port': 'notebook-port', 'scheme': 'HTTP'}, 'initialDelaySeconds': 10, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'name': 'test-auth-notebook', 'ports': [{'containerPort': 8888, 'name': 'notebook-port', 'protocol': 'TCP'}], 'readinessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/notebook/test-auth-notebook/test-auth-notebook/api', 'port': 'notebook-port', 'scheme': 'HTTP'}, 'initialDelaySeconds': 10, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'resources': {'limits': {'cpu': '2', 'memory': '4Gi'}, 'requests': {'cpu': '1', 'memory': '1Gi'}}, 'volumeMounts': [{'mountPath': '/opt/app-root/src', 'name': 'test-auth-notebook'}, {'mountPath': '/dev/shm', 'name': 'shm'}, {'mountPath': '/etc/pki/tls/custom-certs', 'name': 'trusted-ca', 'readOnly': True}, {'mountPath': '/opt/app-root/pipeline-runtimes/', 'name': 'runtime-images'}], 'workingDir': '/opt/app-root/src'}, {'args': ['--secure-listen-address=0.0.0.0:8443', '--upstream=http://127.0.0.1:8888/', '--logtostderr=true', '--v=10', '--proxy-endpoints-port=8444', '--config-file=/etc/kube-rbac-proxy/config-file.yaml', '--tls-cert-file=/etc/tls/private/tls.crt', '--tls-private-key-file=/etc/tls/private/tls.key', '--auth-header-fields-enabled=true', '--auth-header-user-field-name=X-Auth-Request-User', '--auth-header-groups-field-name=X-Auth-Request-Groups'], 'image': 'quay.io/opendatahub/odh-kube-rbac-proxy@sha256:3daf2e94277e39b8b29814c0ccb87e83c578ba7b196e84eac288b4de3ce145b7', 'imagePullPolicy': 'Always', 'livenessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/healthz', 'port': 8444, 'scheme': 'HTTPS'}, 'initialDelaySeconds': 30, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'name': 'kube-rbac-proxy', 'ports': [{'containerPort': 8443, 'name': 'kube-rbac-proxy', 'protocol': 'TCP'}], 'readinessProbe': {'failureThreshold': 3, 'httpGet': {'path': '/healthz', 'port': 8444, 'scheme': 'HTTPS'}, 'initialDelaySeconds': 5, 'periodSeconds': 5, 'successThreshold': 1, 'timeoutSeconds': 1}, 'resources': {'limits': {'cpu': '500m', 'memory': '256Mi'}, 'requests': {'cpu': '200m', 'memory': '128Mi'}}, 'volumeMounts': [{'mountPath': '/etc/kube-rbac-proxy', 'name': 'kube-rbac-proxy-config'}, {'mountPath': '/etc/tls/private', 'name': 'kube-rbac-proxy-tls-certificates'}]}], 'enableServiceLinks': False, 'serviceAccountName': 'test-auth-notebook', 'volumes': [{'name': 'test-auth-notebook', 'persistentVolumeClaim': {'claimName': 'test-auth-notebook'}}, {'emptyDir': {'medium': 'Memory'}, 'name': 'shm'}, {'configMap': {'defaultMode': 420, 'name': 'test-auth-notebook-kube-rbac-proxy-config'}, 'name': 'kube-rbac-proxy-config'}, {'name': 'kube-rbac-proxy-tls-certificates', 'secret': {'defaultMode': 420, 'secretName': 'test-auth-notebook-kube-rbac-proxy-tls'}}, {'configMap': {'name': 'workbench-trusted-ca-bundle', 'optional': True}, 'name': 'trusted-ca'}, {'configMap': {'name': 'pipeline-runtime-images', 'optional': True}, 'name': 'runtime-images'}]}}}, 'status': {'conditions': [{'lastProbeTime': '2026-05-31T19:56:53Z', 'lastTransitionTime': '2026-05-31T19:56:41Z', 'status': 'True', 'type': 'PodReadyToStartContainers'}, {'lastProbeTime': '2026-05-31T19:56:53Z', 'lastTransitionTime': '2026-05-31T19:56:37Z', 'status': 'True', 'type': 'Initialized'}, {'lastProbeTime': '2026-05-31T19:56:53Z', 'lastTransitionTime': '2026-05-31T19:56:53Z', 'status': 'True', 'type': 'Ready'}, {'lastProbeTime': '2026-05-31T19:56:53Z', 'lastTransitionTime': '2026-05-31T19:56:53Z', 'status': 'True', 'type': 'ContainersReady'}, {'lastProbeTime': '2026-05-31T19:56:53Z', 'lastTransitionTime': '2026-05-31T19:56:37Z', 'status': 'True', 'type': 'PodScheduled'}], 'containerState': {'running': {'startedAt': '2026-05-31T19:56:40Z'}}, 'readyReplicas': 1}} [ocp_resources Notebook] 2026-05-31T19:56:54.282476Z [info ] Wait until Notebook test-auth-notebook is deleted [ocp_resources Notebook] 2026-05-31T19:56:54.282709Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait_deleted.lambda: self.exists) [timeout_sampler] 2026-05-31T19:56:55.293823Z [info ] Elapsed time: 1.004913568496704 [0:00:01.004914] [timeout_sampler] 2026-05-31T19:56:55.294027Z [info ] Delete PersistentVolumeClaim test-auth-notebook [ocp_resources PersistentVolumeClaim] 2026-05-31T19:56:55.303248Z [info ] Deleting {'kind': 'PersistentVolumeClaim', 'apiVersion': 'v1', 'metadata': {'name': 'test-auth-notebook', 'namespace': 'test-auth-notebook', 'uid': 'ada18a9e-f8cd-4d08-88db-af452c05ea23', 'resourceVersion': '29607', 'creationTimestamp': '2026-05-31T19:56:33Z', 'labels': {'opendatahub.io/dashboard': 'true'}, 'annotations': {'pv.kubernetes.io/bind-completed': 'yes', 'pv.kubernetes.io/bound-by-controller': 'yes', 'volume.beta.kubernetes.io/storage-provisioner': 'ebs.csi.aws.com', 'volume.kubernetes.io/selected-node': 'ip-10-0-130-57.ec2.internal', 'volume.kubernetes.io/storage-provisioner': 'ebs.csi.aws.com'}, 'finalizers': ['kubernetes.io/pvc-protection'], 'managedFields': [{'manager': 'OpenAPI-Generator', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:33Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:labels': {'.': {}, 'f:opendatahub.io/dashboard': {}}}, 'f:spec': {'f:accessModes': {}, 'f:resources': {'f:requests': {'.': {}, 'f:storage': {}}}, 'f:volumeMode': {}}}}, {'manager': 'kube-scheduler', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:34Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'.': {}, 'f:volume.kubernetes.io/selected-node': {}}}}}, {'manager': 'kube-controller-manager', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:36Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'f:pv.kubernetes.io/bind-completed': {}, 'f:pv.kubernetes.io/bound-by-controller': {}, 'f:volume.beta.kubernetes.io/storage-provisioner': {}, 'f:volume.kubernetes.io/storage-provisioner': {}}}, 'f:spec': {'f:volumeName': {}}}}, {'manager': 'kube-controller-manager', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:36Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:status': {'f:accessModes': {}, 'f:capacity': {'.': {}, 'f:storage': {}}, 'f:phase': {}}}, 'subresource': 'status'}]}, 'spec': {'accessModes': ['ReadWriteOnce'], 'resources': {'requests': {'storage': '10Gi'}}, 'volumeName': 'pvc-ada18a9e-f8cd-4d08-88db-af452c05ea23', 'storageClassName': 'gp3-csi', 'volumeMode': 'Filesystem'}, 'status': {'phase': 'Bound', 'accessModes': ['ReadWriteOnce'], 'capacity': {'storage': '10Gi'}}} [ocp_resources PersistentVolumeClaim] 2026-05-31T19:56:55.310725Z [info ] Wait until PersistentVolumeClaim test-auth-notebook is deleted [ocp_resources PersistentVolumeClaim] 2026-05-31T19:56:55.310976Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait_deleted.lambda: self.exists) [timeout_sampler] 2026-05-31T19:56:56.320927Z [info ] Elapsed time: 1.0039300918579102 [0:00:01.003930] [timeout_sampler] 2026-05-31T19:56:56.324598Z [info ] Delete Project test-auth-notebook [ocp_resources Project] 2026-05-31T19:56:56.339803Z [info ] Deleting {'kind': 'Project', 'apiVersion': 'project.openshift.io/v1', 'metadata': {'name': 'test-auth-notebook', 'uid': '822716f5-fbac-43da-9e3e-ab23e1a15850', 'resourceVersion': '29483', 'creationTimestamp': '2026-05-31T19:56:33Z', 'labels': {'kubernetes.io/metadata.name': 'test-auth-notebook', 'opendatahub.io/dashboard': 'true', 'pod-security.kubernetes.io/audit': 'restricted', 'pod-security.kubernetes.io/audit-version': 'latest', 'pod-security.kubernetes.io/warn': 'restricted', 'pod-security.kubernetes.io/warn-version': 'latest'}, 'annotations': {'openshift.io/description': '', 'openshift.io/display-name': '', 'openshift.io/requester': 'system:admin', 'openshift.io/sa.scc.mcs': 's0:c28,c12', 'openshift.io/sa.scc.supplemental-groups': '1000780000/10000', 'openshift.io/sa.scc.uid-range': '1000780000/10000', 'security.openshift.io/MinimallySufficientPodSecurityStandard': 'restricted'}, 'managedFields': [{'manager': 'pod-security-admission-label-synchronization-controller', 'operation': 'Apply', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:33Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'f:security.openshift.io/MinimallySufficientPodSecurityStandard': {}}, 'f:labels': {'f:pod-security.kubernetes.io/audit': {}, 'f:pod-security.kubernetes.io/audit-version': {}, 'f:pod-security.kubernetes.io/warn': {}, 'f:pod-security.kubernetes.io/warn-version': {}}}}}, {'manager': 'OpenAPI-Generator', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:33Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:labels': {'f:opendatahub.io/dashboard': {}}}}}, {'manager': 'cluster-policy-controller', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:33Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'f:openshift.io/sa.scc.mcs': {}, 'f:openshift.io/sa.scc.supplemental-groups': {}, 'f:openshift.io/sa.scc.uid-range': {}}}}}, {'manager': 'openshift-apiserver', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:33Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'.': {}, 'f:openshift.io/description': {}, 'f:openshift.io/display-name': {}, 'f:openshift.io/requester': {}}, 'f:labels': {'.': {}, 'f:kubernetes.io/metadata.name': {}}}}}, {'manager': 'openshift-controller-manager', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T19:56:33Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:spec': {'f:finalizers': {}}}, 'subresource': 'finalize'}]}, 'spec': {'finalizers': ['kubernetes']}, 'status': {'phase': 'Active'}} [ocp_resources Project] 2026-05-31T19:56:56.350695Z [info ] Wait until Project test-auth-notebook is deleted [ocp_resources Project] 2026-05-31T19:56:56.350883Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait_deleted.lambda: self.exists) [timeout_sampler] _ 2 of 5 completed, 2 Pass, 0 Fail, 0 Skip, 0 XPass, 0 XFail, 0 Error, 0 ReRun _ tests/workbenches/notebooks_server/operator/test_imagestream_health.py::test_workbench_imagestreams_health[notebook_imagestreams] 2026-05-31T19:57:02.403264Z [info ] Elapsed time: 6.042590379714966 [0:00:06.042590] [timeout_sampler]  ------------------------------ test_workbench_imagestreams_health[notebook_imagestreams] ------------------------------ -------------------------------------------------------- SETUP -------------------------------------------------------- 2026-05-31T19:57:02.403986Z [info ] Executing function fixture: label_selector [conftest] 2026-05-31T19:57:02.404126Z [info ] Executing function fixture: expected_imagestream_count [conftest] --------------------------------------------------------- CALL --------------------------------------------------------- 2026-05-31T19:57:02.404426Z [info ] kind: ImageStream api version: image.openshift.io/v1 [ocp_resources.resource] 2026-05-31T19:57:02.415276Z [info ] Checking ImageStreams for label selector 'opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches': expected_count=11, actual_count=11 [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.415369Z [info ] ImageStreams matched for 'opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches': code-server-notebook, jupyter-pytorch-llmcompressor, jupyter-rocm-minimal, jupyter-rocm-pytorch, jupyter-rocm-tensorflow, minimal-gpu, odh-trustyai-notebook, pytorch, s2i-generic-data-science-notebook, s2i-minimal-notebook, tensorflow [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.420619Z [info ] Validating ImageStream code-server-notebook (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.420691Z [info ] ImageStream code-server-notebook tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.420733Z [info ] Checked ImageStream tag code-server-notebook:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.420770Z [info ] Checked ImageStream tag code-server-notebook:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.420801Z [info ] Checked ImageStream tag code-server-notebook:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.420830Z [info ] Checked ImageStream tag code-server-notebook:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.425569Z [info ] Validating ImageStream jupyter-pytorch-llmcompressor (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.425636Z [info ] ImageStream jupyter-pytorch-llmcompressor tag coverage: spec_tags=['2025.2', '3.4', '3.5'], status_tags=['2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.425676Z [info ] Checked ImageStream tag jupyter-pytorch-llmcompressor:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.425709Z [info ] Checked ImageStream tag jupyter-pytorch-llmcompressor:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.425740Z [info ] Checked ImageStream tag jupyter-pytorch-llmcompressor:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.431125Z [info ] Validating ImageStream jupyter-rocm-minimal (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.431222Z [info ] ImageStream jupyter-rocm-minimal tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.431274Z [info ] Checked ImageStream tag jupyter-rocm-minimal:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.431350Z [info ] Checked ImageStream tag jupyter-rocm-minimal:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.431390Z [info ] Checked ImageStream tag jupyter-rocm-minimal:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.431427Z [info ] Checked ImageStream tag jupyter-rocm-minimal:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.436341Z [info ] Validating ImageStream jupyter-rocm-pytorch (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.436418Z [info ] ImageStream jupyter-rocm-pytorch tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.436458Z [info ] Checked ImageStream tag jupyter-rocm-pytorch:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.436493Z [info ] Checked ImageStream tag jupyter-rocm-pytorch:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.436525Z [info ] Checked ImageStream tag jupyter-rocm-pytorch:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.436556Z [info ] Checked ImageStream tag jupyter-rocm-pytorch:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.443493Z [info ] Validating ImageStream jupyter-rocm-tensorflow (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.443560Z [info ] ImageStream jupyter-rocm-tensorflow tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.443598Z [info ] Checked ImageStream tag jupyter-rocm-tensorflow:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.443632Z [info ] Checked ImageStream tag jupyter-rocm-tensorflow:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.443664Z [info ] Checked ImageStream tag jupyter-rocm-tensorflow:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.443692Z [info ] Checked ImageStream tag jupyter-rocm-tensorflow:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.449499Z [info ] Validating ImageStream minimal-gpu (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.449566Z [info ] ImageStream minimal-gpu tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.449605Z [info ] Checked ImageStream tag minimal-gpu:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.449639Z [info ] Checked ImageStream tag minimal-gpu:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.449671Z [info ] Checked ImageStream tag minimal-gpu:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.449699Z [info ] Checked ImageStream tag minimal-gpu:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.454208Z [info ] Validating ImageStream odh-trustyai-notebook (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.454275Z [info ] ImageStream odh-trustyai-notebook tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.454336Z [info ] Checked ImageStream tag odh-trustyai-notebook:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.454372Z [info ] Checked ImageStream tag odh-trustyai-notebook:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.454403Z [info ] Checked ImageStream tag odh-trustyai-notebook:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.454432Z [info ] Checked ImageStream tag odh-trustyai-notebook:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.459447Z [info ] Validating ImageStream pytorch (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.459509Z [info ] ImageStream pytorch tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.459547Z [info ] Checked ImageStream tag pytorch:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.459580Z [info ] Checked ImageStream tag pytorch:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.459610Z [info ] Checked ImageStream tag pytorch:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.459639Z [info ] Checked ImageStream tag pytorch:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.464326Z [info ] Validating ImageStream s2i-generic-data-science-notebook (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.464389Z [info ] ImageStream s2i-generic-data-science-notebook tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.464425Z [info ] Checked ImageStream tag s2i-generic-data-science-notebook:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.464457Z [info ] Checked ImageStream tag s2i-generic-data-science-notebook:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.464485Z [info ] Checked ImageStream tag s2i-generic-data-science-notebook:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.464513Z [info ] Checked ImageStream tag s2i-generic-data-science-notebook:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.469270Z [info ] Validating ImageStream s2i-minimal-notebook (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.469353Z [info ] ImageStream s2i-minimal-notebook tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.469392Z [info ] Checked ImageStream tag s2i-minimal-notebook:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.469424Z [info ] Checked ImageStream tag s2i-minimal-notebook:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.469453Z [info ] Checked ImageStream tag s2i-minimal-notebook:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.469479Z [info ] Checked ImageStream tag s2i-minimal-notebook:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health PASSED _ 3 of 5 completed, 3 Pass, 0 Fail, 0 Skip, 0 XPass, 0 XFail, 0 Error, 0 ReRun _ tests/workbenches/notebooks_server/operator/test_imagestream_health.py::test_workbench_imagestreams_health[runtime_imagestreams] 2026-05-31T19:57:02.473636Z [info ] Validating ImageStream tensorflow (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.473698Z [info ] ImageStream tensorflow tag coverage: spec_tags=['2025.1', '2025.2', '3.4', '3.5'], status_tags=['2025.1', '2025.2', '3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.473735Z [info ] Checked ImageStream tag tensorflow:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.473766Z [info ] Checked ImageStream tag tensorflow:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.473794Z [info ] Checked ImageStream tag tensorflow:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.473820Z [info ] Checked ImageStream tag tensorflow:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health  TEST: test_workbench_imagestreams_health[notebook_imagestreams] STATUS: PASSED ------------------------------------------------------- TEARDOWN -------------------------------------------------------  ------------------------------- test_workbench_imagestreams_health[runtime_imagestreams] ------------------------------- -------------------------------------------------------- SETUP -------------------------------------------------------- 2026-05-31T19:57:02.477776Z [info ] Executing function fixture: label_selector [conftest] 2026-05-31T19:57:02.477901Z [info ] Executing function fixture: expected_imagestream_count [conftest] --------------------------------------------------------- CALL --------------------------------------------------------- 2026-05-31T19:57:02.481244Z [info ] Checking ImageStreams for label selector 'opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches': expected_count=7, actual_count=7 [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.481323Z [info ] ImageStreams matched for 'opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches': runtime-datascience, runtime-minimal, runtime-pytorch, runtime-pytorch-llmcompressor, runtime-rocm-pytorch, runtime-rocm-tensorflow, runtime-tensorflow [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.485418Z [info ] Validating ImageStream runtime-datascience (label selector: opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.485508Z [info ] ImageStream runtime-datascience tag coverage: spec_tags=['datascience'], status_tags=['datascience'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.485564Z [info ] Checked ImageStream tag runtime-datascience:datascience (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.490611Z [info ] Validating ImageStream runtime-minimal (label selector: opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.490702Z [info ] ImageStream runtime-minimal tag coverage: spec_tags=['minimal'], status_tags=['minimal'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.490760Z [info ] Checked ImageStream tag runtime-minimal:minimal (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.496337Z [info ] Validating ImageStream runtime-pytorch (label selector: opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.496395Z [info ] ImageStream runtime-pytorch tag coverage: spec_tags=['pytorch'], status_tags=['pytorch'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.496432Z [info ] Checked ImageStream tag runtime-pytorch:pytorch (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.501156Z [info ] Validating ImageStream runtime-pytorch-llmcompressor (label selector: opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.501217Z [info ] ImageStream runtime-pytorch-llmcompressor tag coverage: spec_tags=['pytorch-llmcompressor'], status_tags=['pytorch-llmcompressor'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.501254Z [info ] Checked ImageStream tag runtime-pytorch-llmcompressor:pytorch-llmcompressor (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.505686Z [info ] Validating ImageStream runtime-rocm-pytorch (label selector: opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.505774Z [info ] ImageStream runtime-rocm-pytorch tag coverage: spec_tags=['rocm-pytorch'], status_tags=['rocm-pytorch'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.505830Z [info ] Checked ImageStream tag runtime-rocm-pytorch:rocm-pytorch (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.510571Z [info ] Validating ImageStream runtime-rocm-tensorflow (label selector: opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.510662Z [info ] ImageStream runtime-rocm-tensorflow tag coverage: spec_tags=['rocm-tensorflow'], status_tags=['rocm-tensorflow'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.510718Z [info ] Checked ImageStream tag runtime-rocm-tensorflow:rocm-tensorflow (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health PASSED _ 4 of 5 completed, 4 Pass, 0 Fail, 0 Skip, 0 XPass, 0 XFail, 0 Error, 0 ReRun _ tests/workbenches/notebooks_server/operator/test_imagestream_health.py::test_workbench_imagestreams_health[trainer_imagestreams] 2026-05-31T19:57:02.515710Z [info ] Validating ImageStream runtime-tensorflow (label selector: opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.515816Z [info ] ImageStream runtime-tensorflow tag coverage: spec_tags=['tensorflow'], status_tags=['tensorflow'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.515887Z [info ] Checked ImageStream tag runtime-tensorflow:tensorflow (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health  TEST: test_workbench_imagestreams_health[runtime_imagestreams] STATUS: PASSED ------------------------------------------------------- TEARDOWN -------------------------------------------------------  ------------------------------- test_workbench_imagestreams_health[trainer_imagestreams] ------------------------------- -------------------------------------------------------- SETUP -------------------------------------------------------- 2026-05-31T19:57:02.519110Z [info ] Executing function fixture: label_selector [conftest] 2026-05-31T19:57:02.519229Z [info ] Executing function fixture: expected_imagestream_count [conftest] --------------------------------------------------------- CALL --------------------------------------------------------- 2026-05-31T19:57:02.525913Z [info ] Checking ImageStreams for label selector 'opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=trainer': expected_count=3, actual_count=3 [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.525971Z [info ] ImageStreams matched for 'opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=trainer': training-hub-universal-cpu, training-hub-universal-cuda, training-hub-universal-rocm [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.530422Z [info ] Validating ImageStream training-hub-universal-cpu (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=trainer) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.530483Z [info ] ImageStream training-hub-universal-cpu tag coverage: spec_tags=['3.4', '3.5'], status_tags=['3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.530521Z [info ] Checked ImageStream tag training-hub-universal-cpu:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.530554Z [info ] Checked ImageStream tag training-hub-universal-cpu:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.535203Z [info ] Validating ImageStream training-hub-universal-cuda (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=trainer) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.535331Z [info ] ImageStream training-hub-universal-cuda tag coverage: spec_tags=['3.4', '3.5'], status_tags=['3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.535370Z [info ] Checked ImageStream tag training-hub-universal-cuda:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.535404Z [info ] Checked ImageStream tag training-hub-universal-cuda:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health PASSED2026-05-31T19:57:02.539482Z [info ] Validating ImageStream training-hub-universal-rocm (label selector: opendatahub.io/notebook-image=true,platform.opendatahub.io/part-of=trainer) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.539571Z [info ] ImageStream training-hub-universal-rocm tag coverage: spec_tags=['3.4', '3.5'], status_tags=['3.4', '3.5'] [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.539626Z [info ] Checked ImageStream tag training-hub-universal-rocm:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T19:57:02.539672Z [info ] Checked ImageStream tag training-hub-universal-rocm:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health  TEST: test_workbench_imagestreams_health[trainer_imagestreams] STATUS: PASSED ------------------------------------------------------- TEARDOWN ------------------------------------------------------- _ 5 of 5 completed, 5 Pass, 0 Fail, 0 Skip, 0 XPass, 0 XFail, 0 Error, 0 ReRun _ ================== 5 passed, 8 deselected in 91.26s (0:01:31) ================== ------------- generated xml file: /artifacts/workbenches-smoke.xml ------------- ================== 5 passed, 8 deselected in 91.26s (0:01:31) ==================