--- BVT pytest attempt 2026-05-31T20:26:22.555030+00:00 (/.local/bin/uv run pytest...) --- 2026-05-31T20:26:24.827936Z [info ] Writing tests log to /home/odh/opendatahub-tests/results/pytest-tests.log [conftest] 2026-05-31T20:26:24.831619Z [info ] Trying to get client via new_client_from_config [ocp_resources.resource] 2026-05-31T20:26:24.918771Z [info ] kind: DataScienceCluster api version: datasciencecluster.opendatahub.io/v2 [ocp_resources.resource] 2026-05-31T20:26:24.940058Z [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-31T20:26:25.029534Z [info ] Executing session fixture: event_loop_policy [conftest] 2026-05-31T20:26:25.030998Z [info ] Executing session fixture: _syrupy_apply_ide_patches [conftest] 2026-05-31T20:26:25.031241Z [info ] Executing session fixture: admin_client [conftest] 2026-05-31T20:26:25.031400Z [info ] Trying to get client via new_client_from_config [ocp_resources.resource] 2026-05-31T20:26:25.031540Z [info ] Executing session fixture: dsc_resource [conftest] 2026-05-31T20:26:25.031672Z [info ] kind: DataScienceCluster api version: datasciencecluster.opendatahub.io/v2 [ocp_resources.resource] 2026-05-31T20:26:25.059119Z [info ] Executing session fixture: tmp_path_factory [conftest] 2026-05-31T20:26:25.059513Z [info ] Executing session fixture: tests_tmp_dir [conftest] 2026-05-31T20:26:25.060890Z [info ] Executing session fixture: os_path_environment [conftest] 2026-05-31T20:26:25.061299Z [info ] Executing session fixture: tmpdir_factory [conftest] 2026-05-31T20:26:25.061535Z [info ] Executing session fixture: bin_directory [conftest] 2026-05-31T20:26:25.062891Z [info ] Executing session fixture: oc_binary_path [conftest] 2026-05-31T20:26:25.068688Z [info ] kind: ConsoleCLIDownload api version: console.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:26:25.074855Z [info ] All oc console cli download links: ['https://downloads-openshift-console.apps.ab1158ce-9b15-41d2-b2d2-3455e7864afe.prod.konfluxeaas.com/amd64/linux/oc.tar'] [utilities.infra] name=utilities.infra 2026-05-31T20:26:25.075022Z [info ] Downloading archive using: url=https://downloads-openshift-console.apps.ab1158ce-9b15-41d2-b2d2-3455e7864afe.prod.konfluxeaas.com/amd64/linux/oc.tar [utilities.infra] name=utilities.infra 2026-05-31T20:26:25.862286Z [info ] Extract the downloaded archive. [utilities.infra] name=utilities.infra 2026-05-31T20:26:25.949250Z [info ] Downloaded file: ['oc']  [utilities.infra] name=utilities.infra 2026-05-31T20:26:25.972527Z [info ] Executing session fixture: bin_directory_to_os_path [conftest] 2026-05-31T20:26:25.970713Z [info ] OC binary path: /tmp/pytest-DSvHiqVazf3B9zwY99yKuN/bin0/oc [tests.conftest] name=tests.conftest 2026-05-31T20:26:25.970791Z [info ] Adding /tmp/pytest-DSvHiqVazf3B9zwY99yKuN/bin0 to $PATH [tests.conftest] name=tests.conftest 2026-05-31T20:26:25.973078Z [info ] Executing session fixture: nodes [conftest] 2026-05-31T20:26:26.166070Z [info ] Executing session fixture: dsci_resource [conftest] 2026-05-31T20:26:26.166259Z [info ] kind: DSCInitialization api version: dscinitialization.opendatahub.io/v2 [ocp_resources.resource] 2026-05-31T20:26:26.170918Z [info ] Executing session fixture: record_testsuite_property [conftest] 2026-05-31T20:26:26.171113Z [info ] Executing session fixture: junitxml_plugin [conftest] 2026-05-31T20:26:26.171257Z [info ] Executing session fixture: cluster_sanity_scope_session [conftest] 2026-05-31T20:26:26.169865Z [info ] Check cluster sanity.  [utilities.infra] name=utilities.infra 2026-05-31T20:26:26.171531Z [info ] Verify all nodes are in a healthy condition. [ocp_utilities.infra] 2026-05-31T20:26:26.182763Z [info ] Verify all nodes are schedulable. [ocp_utilities.infra] 2026-05-31T20:26:26.193119Z [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-31T20:26:26.192430Z [info ] Wait for DSCI default-dsci to be in Ready status. [utilities.infra] name=utilities.infra 2026-05-31T20:26:26.193552Z [info ] Get DSCInitialization default-dsci status [ocp_resources DSCInitialization] 2026-05-31T20:26:26.197020Z [info ] Elapsed time: 7.486343383789062e-05 [0:00:00.000075] [timeout_sampler] 2026-05-31T20:26:26.197179Z [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-31T20:26:26.196383Z [info ] Wait for DSC default-dsc are Ready. [utilities.infra] name=utilities.infra 2026-05-31T20:26:26.197447Z [info ] Get DataScienceCluster default-dsc status [ocp_resources DataScienceCluster] 2026-05-31T20:26:26.201890Z [info ] Elapsed time: 3.62396240234375e-05 [0:00:00.000036] [timeout_sampler] 2026-05-31T20:26:26.202163Z [info ] Executing session fixture: autouse_fixtures [conftest] 2026-05-31T20:26:26.202355Z [info ] Executing session fixture: pytestconfig [conftest] 2026-05-31T20:26:26.202482Z [info ] Executing session fixture: use_unprivileged_client [conftest] 2026-05-31T20:26:26.202602Z [info ] Executing session fixture: kubconfig_filepath [conftest] 2026-05-31T20:26:26.202722Z [info ] Executing session fixture: cluster_authentication [conftest] 2026-05-31T20:26:26.202846Z [info ] kind: Authentication api version: config.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:26:26.205570Z [info ] Executing session fixture: is_byoidc [conftest] 2026-05-31T20:26:26.210764Z [info ] Executing session fixture: non_admin_user_password [conftest] 2026-05-31T20:26:26.211024Z [info ] Executing session fixture: unprivileged_client [conftest] 2026-05-31T20:26:26.208988Z [warning ] Unprivileged client is not enabled, using admin client [tests.conftest] name=tests.conftest 2026-05-31T20:26:26.211297Z [info ] Executing session fixture: teardown_resources [conftest] 2026-05-31T20:26:26.211424Z [info ] Executing class fixture: unprivileged_model_namespace [conftest] 2026-05-31T20:26:26.211544Z [info ] kind: ProjectRequest api version: project.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:26:26.211678Z [info ] Create ProjectRequest test-odh-notebook [ocp_resources ProjectRequest] 2026-05-31T20:26:26.211812Z [info ] Posting {'apiVersion': 'project.openshift.io/v1', 'kind': 'ProjectRequest', 'metadata': {'name': 'test-odh-notebook', 'labels': {'opendatahub.io/dashboard': 'true'}}} [ocp_resources ProjectRequest] 2026-05-31T20:26:26.296510Z [info ] kind: Project api version: project.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:26:26.296674Z [info ] Wait for Project test-odh-notebook status to be Active [ocp_resources Project] 2026-05-31T20:26:26.296826Z [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-31T20:26:26.305727Z [info ] Status of Project test-odh-notebook is Active [ocp_resources Project] 2026-05-31T20:26:26.305884Z [info ] Elapsed time: 3.910064697265625e-05 [0:00:00.000039] [timeout_sampler] 2026-05-31T20:26:26.306114Z [info ] ResourceEdits: Updating data for resource Namespace test-odh-notebook [ocp_resources.resource] 2026-05-31T20:26:26.306254Z [info ] Update Namespace test-odh-notebook: {'metadata': {'labels': {'opendatahub.io/dashboard': 'true'}, 'name': 'test-odh-notebook'}} [ocp_resources Namespace] 2026-05-31T20:26:26.316223Z [info ] Executing function fixture: minimal_image [conftest] 2026-05-31T20:26:26.342280Z [info ] kind: ClusterServiceVersion api version: operators.coreos.com/v1alpha1 [ocp_resources.resource] 2026-05-31T20:26:26.396320Z [info ] Executing function fixture: notebook_image [conftest] 2026-05-31T20:26:26.488594Z [info ] kind: Config api version: imageregistry.operator.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:26:26.492252Z [info ] Image registry management state: managed, available: True [utilities.infra] name=utilities.infra 2026-05-31T20:26:26.494442Z [info ] Executing function fixture: users_persistent_volume_claim [conftest] 2026-05-31T20:26:26.494584Z [info ] Create PersistentVolumeClaim test-odh-notebook [ocp_resources PersistentVolumeClaim] 2026-05-31T20:26:26.494726Z [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-31T20:26:26.508345Z [info ] Executing function fixture: default_notebook [conftest] 2026-05-31T20:26:26.508625Z [info ] kind: SelfSubjectReview api version: authentication.k8s.io/v1 [ocp_resources.resource] 2026-05-31T20:26:26.508818Z [info ] Create SelfSubjectReview selfSubjectReview [ocp_resources SelfSubjectReview] 2026-05-31T20:26:26.509065Z [info ] Posting {'apiVersion': 'authentication.k8s.io/v1', 'kind': 'SelfSubjectReview', 'metadata': {'name': 'selfSubjectReview'}} [ocp_resources SelfSubjectReview] 2026-05-31T20:26:26.535838Z [info ] kind: Notebook api version: kubeflow.org/v1 [ocp_resources.resource] 2026-05-31T20:26:26.536052Z [info ] Create Notebook test-odh-notebook [ocp_resources Notebook] 2026-05-31T20:26:26.536244Z [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-31T20:26:26.882378Z [info ] Executing function fixture: notebook_pod [conftest] 2026-05-31T20:26:26.882582Z [info ] Wait until Pod test-odh-notebook-0 is created [ocp_resources Pod] 2026-05-31T20:26:26.882740Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait.lambda: self.exists) [timeout_sampler] 2026-05-31T20:26:27.898582Z [info ] Elapsed time: 1.004657506942749 [0:00:01.004658] [timeout_sampler] 2026-05-31T20:26:27.898781Z [info ] Wait for Pod/test-odh-notebook-0's 'Ready' condition to be 'True' [ocp_resources Pod] 2026-05-31T20:26:27.898940Z [info ] Wait until Pod test-odh-notebook-0 is created [ocp_resources Pod] 2026-05-31T20:26:27.899125Z [info ] Waiting for 120 seconds [0:02:00], retry every 1 seconds. (Function: ocp_resources.resource.wait.lambda: self.exists) [timeout_sampler] 2026-05-31T20:26:27.902647Z [info ] Elapsed time: 2.9087066650390625e-05 [0:00:00.000029] [timeout_sampler] 2026-05-31T20:26:27.902809Z [info ] Waiting for 119.99562430381775 seconds [0:01:59.995624], retry every 1 seconds. (Function: ocp_resources.resource.wait_for_condition.lambda: self.instance) [timeout_sampler] 2026-05-31T20:27:23.396819Z [info ] Elapsed time: 55.481738805770874 [0:00:55.481739] [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-31T20:27:23.407225Z [info ] Delete Notebook test-odh-notebook [ocp_resources Notebook] 2026-05-31T20:27:23.428821Z [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-31T20:26:26Z', '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-31T20:26:26Z'}, {'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-31T20:26:27Z'}, {'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-31T20:27:22Z'}], 'name': 'test-odh-notebook', 'namespace': 'test-odh-notebook', 'resourceVersion': '31884', 'uid': 'b04e9bd8-e9ac-4388-8249-eac3bb3cb602'}, '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': '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-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-31T20:27:22Z', 'lastTransitionTime': '2026-05-31T20:27:10Z', 'status': 'True', 'type': 'PodReadyToStartContainers'}, {'lastProbeTime': '2026-05-31T20:27:22Z', 'lastTransitionTime': '2026-05-31T20:26:30Z', 'status': 'True', 'type': 'Initialized'}, {'lastProbeTime': '2026-05-31T20:27:22Z', 'lastTransitionTime': '2026-05-31T20:27:22Z', 'status': 'True', 'type': 'Ready'}, {'lastProbeTime': '2026-05-31T20:27:22Z', 'lastTransitionTime': '2026-05-31T20:27:22Z', 'status': 'True', 'type': 'ContainersReady'}, {'lastProbeTime': '2026-05-31T20:27:22Z', 'lastTransitionTime': '2026-05-31T20:26:30Z', 'status': 'True', 'type': 'PodScheduled'}], 'containerState': {'running': {'startedAt': '2026-05-31T20:27:08Z'}}, 'readyReplicas': 1}} [ocp_resources Notebook] 2026-05-31T20:27:23.441225Z [info ] Wait until Notebook test-odh-notebook is deleted [ocp_resources Notebook] 2026-05-31T20:27:23.441408Z [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-31T20:27:24.457909Z [info ] Elapsed time: 1.005277156829834 [0:00:01.005277] [timeout_sampler] 2026-05-31T20:27:24.458219Z [info ] Delete PersistentVolumeClaim test-odh-notebook [ocp_resources PersistentVolumeClaim] 2026-05-31T20:27:24.475141Z [info ] Deleting {'kind': 'PersistentVolumeClaim', 'apiVersion': 'v1', 'metadata': {'name': 'test-odh-notebook', 'namespace': 'test-odh-notebook', 'uid': 'cd88e510-50d9-412f-b23c-6df10fd54f2f', 'resourceVersion': '31126', 'creationTimestamp': '2026-05-31T20:26:26Z', '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-140-21.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-31T20:26:26Z', '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-31T20:26:27Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'.': {}, 'f:volume.kubernetes.io/selected-node': {}}}}}, {'manager': 'kube-controller-manager', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T20:26:30Z', '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-31T20:26:30Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:status': {'f:accessModes': {}, 'f:capacity': {'.': {}, 'f:storage': {}}, 'f:phase': {}}}, 'subresource': 'status'}]}, 'spec': {'accessModes': ['ReadWriteOnce'], 'resources': {'requests': {'storage': '10Gi'}}, 'volumeName': 'pvc-cd88e510-50d9-412f-b23c-6df10fd54f2f', 'storageClassName': 'gp3-csi', 'volumeMode': 'Filesystem'}, 'status': {'phase': 'Bound', 'accessModes': ['ReadWriteOnce'], 'capacity': {'storage': '10Gi'}}} [ocp_resources PersistentVolumeClaim] 2026-05-31T20:27:24.490765Z [info ] Wait until PersistentVolumeClaim test-odh-notebook is deleted [ocp_resources PersistentVolumeClaim] 2026-05-31T20:27:24.490989Z [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-31T20:27:25.507468Z [info ] Elapsed time: 1.004579782485962 [0:00:01.004580] [timeout_sampler] 2026-05-31T20:27:25.516598Z [info ] Delete Project test-odh-notebook [ocp_resources Project] 2026-05-31T20:27:25.556508Z [info ] Deleting {'kind': 'Project', 'apiVersion': 'project.openshift.io/v1', 'metadata': {'name': 'test-odh-notebook', 'uid': '9719cf34-44d8-4857-bfd4-298914c4c85b', 'resourceVersion': '30988', 'creationTimestamp': '2026-05-31T20:26:26Z', '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-31T20:26:26Z', '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-31T20:26:26Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:labels': {'f:opendatahub.io/dashboard': {}}}}}, {'manager': 'cluster-policy-controller', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T20:26:26Z', '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-31T20:26:26Z', '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-31T20:26:26Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:spec': {'f:finalizers': {}}}, 'subresource': 'finalize'}]}, 'spec': {'finalizers': ['kubernetes']}, 'status': {'phase': 'Active'}} [ocp_resources Project] 2026-05-31T20:27:25.585634Z [info ] Wait until Project test-odh-notebook is deleted [ocp_resources Project] 2026-05-31T20:27:25.585869Z [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-31T20:27:36.831243Z [info ] Elapsed time: 11.226981401443481 [0:00:11.226981] [timeout_sampler]  test_auth_container_resource_customization[unprivileged_model_namespace0-users_persistent_volume_claim0-default_notebook0-notebook_pod0]  -------------------------------------------------------- SETUP -------------------------------------------------------- 2026-05-31T20:27:36.832027Z [info ] Executing class fixture: unprivileged_model_namespace [conftest] 2026-05-31T20:27:36.832161Z [info ] kind: ProjectRequest api version: project.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:27:36.832289Z [info ] Create ProjectRequest test-auth-notebook [ocp_resources ProjectRequest] 2026-05-31T20:27:36.832418Z [info ] Posting {'apiVersion': 'project.openshift.io/v1', 'kind': 'ProjectRequest', 'metadata': {'name': 'test-auth-notebook', 'labels': {'opendatahub.io/dashboard': 'true'}}} [ocp_resources ProjectRequest] 2026-05-31T20:27:37.109686Z [info ] kind: Project api version: project.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:27:37.109886Z [info ] Wait for Project test-auth-notebook status to be Active [ocp_resources Project] 2026-05-31T20:27:37.110091Z [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-31T20:27:37.132004Z [info ] Status of Project test-auth-notebook is Active [ocp_resources Project] 2026-05-31T20:27:37.132247Z [info ] Elapsed time: 4.029273986816406e-05 [0:00:00.000040] [timeout_sampler] 2026-05-31T20:27:37.132405Z [info ] ResourceEdits: Updating data for resource Namespace test-auth-notebook [ocp_resources.resource] 2026-05-31T20:27:37.132549Z [info ] Update Namespace test-auth-notebook: {'metadata': {'labels': {'opendatahub.io/dashboard': 'true'}, 'name': 'test-auth-notebook'}} [ocp_resources Namespace] 2026-05-31T20:27:37.156322Z [info ] Executing function fixture: minimal_image [conftest] 2026-05-31T20:27:37.226085Z [info ] Executing function fixture: notebook_image [conftest] 2026-05-31T20:27:37.329803Z [info ] kind: Config api version: imageregistry.operator.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:27:37.342043Z [info ] Image registry management state: managed, available: True [utilities.infra] name=utilities.infra 2026-05-31T20:27:37.344257Z [info ] Executing function fixture: users_persistent_volume_claim [conftest] 2026-05-31T20:27:37.344418Z [info ] Create PersistentVolumeClaim test-auth-notebook [ocp_resources PersistentVolumeClaim] 2026-05-31T20:27:37.344568Z [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-31T20:27:37.394044Z [info ] Executing function fixture: default_notebook [conftest] 2026-05-31T20:27:37.394316Z [info ] kind: SelfSubjectReview api version: authentication.k8s.io/v1 [ocp_resources.resource] 2026-05-31T20:27:37.394491Z [info ] Create SelfSubjectReview selfSubjectReview [ocp_resources SelfSubjectReview] 2026-05-31T20:27:37.394630Z [info ] Posting {'apiVersion': 'authentication.k8s.io/v1', 'kind': 'SelfSubjectReview', 'metadata': {'name': 'selfSubjectReview'}} [ocp_resources SelfSubjectReview] 2026-05-31T20:27:37.406204Z [info ] kind: Notebook api version: kubeflow.org/v1 [ocp_resources.resource] 2026-05-31T20:27:37.406446Z [info ] Create Notebook test-auth-notebook [ocp_resources Notebook] 2026-05-31T20:27:37.406625Z [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-31T20:27:37.632465Z [info ] Executing function fixture: notebook_pod [conftest] 2026-05-31T20:27:37.632634Z [info ] Wait until Pod test-auth-notebook-0 is created [ocp_resources Pod] 2026-05-31T20:27:37.632776Z [info ] Waiting for 240 seconds [0:04:00], retry every 1 seconds. (Function: ocp_resources.resource.wait.lambda: self.exists) [timeout_sampler] 2026-05-31T20:27:39.674806Z [info ] Elapsed time: 2.0219714641571045 [0:00:02.021971] [timeout_sampler] 2026-05-31T20:27:39.675043Z [info ] Wait for Pod/test-auth-notebook-0's 'Ready' condition to be 'True' [ocp_resources Pod] 2026-05-31T20:27:39.675187Z [info ] Wait until Pod test-auth-notebook-0 is created [ocp_resources Pod] 2026-05-31T20:27:39.675317Z [info ] Waiting for 120 seconds [0:02:00], retry every 1 seconds. (Function: ocp_resources.resource.wait.lambda: self.exists) [timeout_sampler] 2026-05-31T20:27:39.690288Z [info ] Elapsed time: 3.504753112792969e-05 [0:00:00.000035] [timeout_sampler] 2026-05-31T20:27:39.690478Z [info ] Waiting for 119.98430871963501 seconds [0:01:59.984309], retry every 1 seconds. (Function: ocp_resources.resource.wait_for_condition.lambda: self.instance) [timeout_sampler] 2026-05-31T20:28:04.989120Z [info ] Elapsed time: 25.284165143966675 [0:00:25.284165] [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-31T20:28:04.996380Z [info ] Delete Notebook test-auth-notebook [ocp_resources Notebook] 2026-05-31T20:28:05.019366Z [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-31T20:27:37Z', '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-31T20:27:37Z'}, {'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-31T20:27:37Z'}, {'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-31T20:28:04Z'}], 'name': 'test-auth-notebook', 'namespace': 'test-auth-notebook', 'resourceVersion': '32706', 'uid': '4f6c8876-c5a8-4d45-96e9-4f3c79d483e7'}, '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': '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'}, {'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'}], '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-31T20:28:04Z', 'lastTransitionTime': '2026-05-31T20:27:52Z', 'status': 'True', 'type': 'PodReadyToStartContainers'}, {'lastProbeTime': '2026-05-31T20:28:04Z', 'lastTransitionTime': '2026-05-31T20:27:42Z', 'status': 'True', 'type': 'Initialized'}, {'lastProbeTime': '2026-05-31T20:28:04Z', 'lastTransitionTime': '2026-05-31T20:28:04Z', 'status': 'True', 'type': 'Ready'}, {'lastProbeTime': '2026-05-31T20:28:04Z', 'lastTransitionTime': '2026-05-31T20:28:04Z', 'status': 'True', 'type': 'ContainersReady'}, {'lastProbeTime': '2026-05-31T20:28:04Z', 'lastTransitionTime': '2026-05-31T20:27:41Z', 'status': 'True', 'type': 'PodScheduled'}], 'containerState': {'running': {'startedAt': '2026-05-31T20:27:52Z'}}, 'readyReplicas': 1}} [ocp_resources Notebook] 2026-05-31T20:28:05.039290Z [info ] Wait until Notebook test-auth-notebook is deleted [ocp_resources Notebook] 2026-05-31T20:28:05.039451Z [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-31T20:28:06.063766Z [info ] Elapsed time: 1.0119197368621826 [0:00:01.011920] [timeout_sampler] 2026-05-31T20:28:06.063954Z [info ] Delete PersistentVolumeClaim test-auth-notebook [ocp_resources PersistentVolumeClaim] 2026-05-31T20:28:06.086730Z [info ] Deleting {'kind': 'PersistentVolumeClaim', 'apiVersion': 'v1', 'metadata': {'name': 'test-auth-notebook', 'namespace': 'test-auth-notebook', 'uid': '9d139ce1-aea9-4dc1-9280-38f793fc6c86', 'resourceVersion': '32347', 'creationTimestamp': '2026-05-31T20:27:37Z', '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-140-21.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-31T20:27:37Z', '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-31T20:27:38Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:annotations': {'.': {}, 'f:volume.kubernetes.io/selected-node': {}}}}}, {'manager': 'kube-controller-manager', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T20:27:41Z', '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-31T20:27:41Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:status': {'f:accessModes': {}, 'f:capacity': {'.': {}, 'f:storage': {}}, 'f:phase': {}}}, 'subresource': 'status'}]}, 'spec': {'accessModes': ['ReadWriteOnce'], 'resources': {'requests': {'storage': '10Gi'}}, 'volumeName': 'pvc-9d139ce1-aea9-4dc1-9280-38f793fc6c86', 'storageClassName': 'gp3-csi', 'volumeMode': 'Filesystem'}, 'status': {'phase': 'Bound', 'accessModes': ['ReadWriteOnce'], 'capacity': {'storage': '10Gi'}}} [ocp_resources PersistentVolumeClaim] 2026-05-31T20:28:06.102430Z [info ] Wait until PersistentVolumeClaim test-auth-notebook is deleted [ocp_resources PersistentVolumeClaim] 2026-05-31T20:28:06.102659Z [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-31T20:28:07.119803Z [info ] Elapsed time: 1.0064899921417236 [0:00:01.006490] [timeout_sampler] 2026-05-31T20:28:07.138229Z [info ] Delete Project test-auth-notebook [ocp_resources Project] 2026-05-31T20:28:07.177299Z [info ] Deleting {'kind': 'Project', 'apiVersion': 'project.openshift.io/v1', 'metadata': {'name': 'test-auth-notebook', 'uid': 'c47e20d4-657a-4296-81b9-c912503e2efc', 'resourceVersion': '32210', 'creationTimestamp': '2026-05-31T20:27:36Z', '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-31T20:27:36Z', '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': 'cluster-policy-controller', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T20:27:36Z', '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-31T20:27:36Z', '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-31T20:27:36Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:spec': {'f:finalizers': {}}}, 'subresource': 'finalize'}, {'manager': 'OpenAPI-Generator', 'operation': 'Update', 'apiVersion': 'v1', 'time': '2026-05-31T20:27:37Z', 'fieldsType': 'FieldsV1', 'fieldsV1': {'f:metadata': {'f:labels': {'f:opendatahub.io/dashboard': {}}}}}]}, 'spec': {'finalizers': ['kubernetes']}, 'status': {'phase': 'Active'}} [ocp_resources Project] 2026-05-31T20:28:07.209685Z [info ] Wait until Project test-auth-notebook is deleted [ocp_resources Project] 2026-05-31T20:28:07.209885Z [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-31T20:28:16.399650Z [info ] Elapsed time: 9.179160356521606 [0:00:09.179160] [timeout_sampler]  ------------------------------ test_workbench_imagestreams_health[notebook_imagestreams] ------------------------------ -------------------------------------------------------- SETUP -------------------------------------------------------- 2026-05-31T20:28:16.400202Z [info ] Executing function fixture: label_selector [conftest] 2026-05-31T20:28:16.400341Z [info ] Executing function fixture: expected_imagestream_count [conftest] --------------------------------------------------------- CALL --------------------------------------------------------- 2026-05-31T20:28:16.400595Z [info ] kind: ImageStream api version: image.openshift.io/v1 [ocp_resources.resource] 2026-05-31T20:28:16.415008Z [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-31T20:28:16.415093Z [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-31T20:28:16.420868Z [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-31T20:28:16.420945Z [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-31T20:28:16.421020Z [info ] Checked ImageStream tag code-server-notebook:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.421069Z [info ] Checked ImageStream tag code-server-notebook:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.421105Z [info ] Checked ImageStream tag code-server-notebook:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.421133Z [info ] Checked ImageStream tag code-server-notebook:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.426742Z [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-31T20:28:16.426823Z [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-31T20:28:16.426870Z [info ] Checked ImageStream tag jupyter-pytorch-llmcompressor:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.426909Z [info ] Checked ImageStream tag jupyter-pytorch-llmcompressor:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.426939Z [info ] Checked ImageStream tag jupyter-pytorch-llmcompressor:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.432140Z [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-31T20:28:16.432209Z [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-31T20:28:16.432246Z [info ] Checked ImageStream tag jupyter-rocm-minimal:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.432278Z [info ] Checked ImageStream tag jupyter-rocm-minimal:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.432306Z [info ] Checked ImageStream tag jupyter-rocm-minimal:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.432334Z [info ] Checked ImageStream tag jupyter-rocm-minimal:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.438174Z [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-31T20:28:16.438240Z [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-31T20:28:16.438276Z [info ] Checked ImageStream tag jupyter-rocm-pytorch:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.438306Z [info ] Checked ImageStream tag jupyter-rocm-pytorch:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.438336Z [info ] Checked ImageStream tag jupyter-rocm-pytorch:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.438366Z [info ] Checked ImageStream tag jupyter-rocm-pytorch:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.443465Z [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-31T20:28:16.443528Z [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-31T20:28:16.443565Z [info ] Checked ImageStream tag jupyter-rocm-tensorflow:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.443597Z [info ] Checked ImageStream tag jupyter-rocm-tensorflow:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.443624Z [info ] Checked ImageStream tag jupyter-rocm-tensorflow:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.443651Z [info ] Checked ImageStream tag jupyter-rocm-tensorflow:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.448877Z [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-31T20:28:16.448941Z [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-31T20:28:16.449003Z [info ] Checked ImageStream tag minimal-gpu:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.449038Z [info ] Checked ImageStream tag minimal-gpu:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.449067Z [info ] Checked ImageStream tag minimal-gpu:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.449094Z [info ] Checked ImageStream tag minimal-gpu:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.455261Z [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-31T20:28:16.455409Z [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-31T20:28:16.455480Z [info ] Checked ImageStream tag odh-trustyai-notebook:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.455536Z [info ] Checked ImageStream tag odh-trustyai-notebook:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.455889Z [info ] Checked ImageStream tag odh-trustyai-notebook:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.456032Z [info ] Checked ImageStream tag odh-trustyai-notebook:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.462629Z [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-31T20:28:16.462806Z [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-31T20:28:16.462880Z [info ] Checked ImageStream tag pytorch:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.462938Z [info ] Checked ImageStream tag pytorch:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.463044Z [info ] Checked ImageStream tag pytorch:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.463105Z [info ] Checked ImageStream tag pytorch:3.5 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.478854Z [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-31T20:28:16.479020Z [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-31T20:28:16.479065Z [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-31T20:28:16.479100Z [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-31T20:28:16.479130Z [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-31T20:28:16.479157Z [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-31T20:28:16.485635Z [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-31T20:28:16.485730Z [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-31T20:28:16.485777Z [info ] Checked ImageStream tag s2i-minimal-notebook:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.485817Z [info ] Checked ImageStream tag s2i-minimal-notebook:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.485852Z [info ] Checked ImageStream tag s2i-minimal-notebook:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.485885Z [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-31T20:28:16.492097Z [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-31T20:28:16.492170Z [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-31T20:28:16.492207Z [info ] Checked ImageStream tag tensorflow:2025.1 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.492240Z [info ] Checked ImageStream tag tensorflow:2025.2 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.492268Z [info ] Checked ImageStream tag tensorflow:3.4 (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.492295Z [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-31T20:28:16.496812Z [info ] Executing function fixture: label_selector [conftest] 2026-05-31T20:28:16.496938Z [info ] Executing function fixture: expected_imagestream_count [conftest] --------------------------------------------------------- CALL --------------------------------------------------------- 2026-05-31T20:28:16.507897Z [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-31T20:28:16.507993Z [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-31T20:28:16.513277Z [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-31T20:28:16.513352Z [info ] ImageStream runtime-datascience tag coverage: spec_tags=['datascience'], status_tags=['datascience'] [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.513391Z [info ] Checked ImageStream tag runtime-datascience:datascience (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.518526Z [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-31T20:28:16.518607Z [info ] ImageStream runtime-minimal tag coverage: spec_tags=['minimal'], status_tags=['minimal'] [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.518663Z [info ] Checked ImageStream tag runtime-minimal:minimal (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.524676Z [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-31T20:28:16.524752Z [info ] ImageStream runtime-pytorch tag coverage: spec_tags=['pytorch'], status_tags=['pytorch'] [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.524808Z [info ] Checked ImageStream tag runtime-pytorch:pytorch (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.530980Z [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-31T20:28:16.531055Z [info ] ImageStream runtime-pytorch-llmcompressor tag coverage: spec_tags=['pytorch-llmcompressor'], status_tags=['pytorch-llmcompressor'] [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.531094Z [info ] Checked ImageStream tag runtime-pytorch-llmcompressor:pytorch-llmcompressor (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.537536Z [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-31T20:28:16.537610Z [info ] ImageStream runtime-rocm-pytorch tag coverage: spec_tags=['rocm-pytorch'], status_tags=['rocm-pytorch'] [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.537648Z [info ] Checked ImageStream tag runtime-rocm-pytorch:rocm-pytorch (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.544637Z [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-31T20:28:16.544802Z [info ] ImageStream runtime-rocm-tensorflow tag coverage: spec_tags=['rocm-tensorflow'], status_tags=['rocm-tensorflow'] [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.544897Z [info ] Checked ImageStream tag runtime-rocm-tensorflow:rocm-tensorflow (items_count=1, import_success=N/A) [_pytest.compat] name=test_imagestream_health PASSED2026-05-31T20:28:16.554131Z [info ] Validating ImageStream runtime-tensorflow (label selector: opendatahub.io/runtime-image=true,platform.opendatahub.io/part-of=workbenches) [_pytest.compat] name=test_imagestream_health _ 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-31T20:28:16.554319Z [info ] ImageStream runtime-tensorflow tag coverage: spec_tags=['tensorflow'], status_tags=['tensorflow'] [_pytest.compat] name=test_imagestream_health 2026-05-31T20:28:16.554448Z [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-31T20:28:16.561620Z [info ] Executing function fixture: label_selector [conftest] 2026-05-31T20:28:16.561783Z [info ] Executing function fixture: expected_imagestream_count [conftest] --------------------------------------------------------- CALL --------------------------------------------------------- 2026-05-31T20:28:16.615109Z [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-31T20:28:16.615231Z [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-31T20:28:16.625873Z [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-31T20:28:16.625987Z [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-31T20:28:16.626095Z [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-31T20:28:16.626137Z [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-31T20:28:16.642571Z [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-31T20:28:16.642650Z [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-31T20:28:16.642690Z [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-31T20:28:16.642742Z [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-31T20:28:16.653148Z [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-31T20:28:16.653252Z [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-31T20:28:16.653308Z [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-31T20:28:16.653355Z [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 111.72s (0:01:51) ================== ------------- generated xml file: /artifacts/workbenches-smoke.xml ------------- ================= 5 passed, 8 deselected in 111.72s (0:01:51) ==================