diff --git a/frontend/src/__tests__/cypress/cypress/e2e/modelServing/ServingRuntimeList.cy.ts b/frontend/src/__tests__/cypress/cypress/e2e/modelServing/ServingRuntimeList.cy.ts index c920156135..5d171c4034 100644 --- a/frontend/src/__tests__/cypress/cypress/e2e/modelServing/ServingRuntimeList.cy.ts +++ b/frontend/src/__tests__/cypress/cypress/e2e/modelServing/ServingRuntimeList.cy.ts @@ -931,6 +931,25 @@ describe('Serving Runtime List', () => { kserveModal.findLocationPathInput().type('correct-path'); kserveModal.findSubmitButton().should('be.enabled'); }); + + it('Check authentication section', () => { + initIntercepts({ + disableModelMeshConfig: false, + disableKServeConfig: false, + servingRuntimes: [], + }); + projectDetails.visitSection('test-project', 'model-server'); + + modelServingSection.getServingPlatformCard('single-serving').findDeployModelButton().click(); + + kserveModal.shouldBeOpen(); + + kserveModal.findSubmitButton().should('be.disabled'); + + // test filling in minimum required fields + kserveModal.findAuthenticationCheckbox().contains('Require token authentication'); + kserveModal.findAuthenticationCheckbox().contains('Token authentication'); + }); }); describe('ModelMesh model server', () => { @@ -1565,7 +1584,7 @@ describe('Serving Runtime List', () => { const kserveRow = modelServingSection.getKServeRow('Llama Caikit'); kserveRow.findExpansion().should(be.collapsed); kserveRow.findToggleButton().click(); - kserveRow.findDescriptionListItem('Token authorization').should('exist'); + kserveRow.findDescriptionListItem('Token authentication').should('exist'); }); it('Check token section is disabled if capability is disabled', () => { @@ -1579,7 +1598,7 @@ describe('Serving Runtime List', () => { const kserveRow = modelServingSection.getKServeRow('Llama Caikit'); kserveRow.findExpansion().should(be.collapsed); kserveRow.findToggleButton().click(); - kserveRow.findDescriptionListItem('Token authorization').should('not.exist'); + kserveRow.findDescriptionListItem('Token authentication').should('not.exist'); }); }); diff --git a/frontend/src/__tests__/cypress/cypress/pages/modelServing.ts b/frontend/src/__tests__/cypress/cypress/pages/modelServing.ts index 0af165b0c2..e3f4cb2f01 100644 --- a/frontend/src/__tests__/cypress/cypress/pages/modelServing.ts +++ b/frontend/src/__tests__/cypress/cypress/pages/modelServing.ts @@ -171,6 +171,10 @@ class ServingRuntimeModal extends Modal { return this.find().findByTestId('serving-runtime-template-selection'); } + findAuthenticationSection() { + return this.find().findByTestId('auth-section'); + } + findModelRouteCheckbox() { return this.find().findByTestId('alt-form-checkbox-route'); } diff --git a/frontend/src/pages/home/aiFlows/DeployAndMonitorGallery.tsx b/frontend/src/pages/home/aiFlows/DeployAndMonitorGallery.tsx index 45da98f2b1..7860d6e1e3 100644 --- a/frontend/src/pages/home/aiFlows/DeployAndMonitorGallery.tsx +++ b/frontend/src/pages/home/aiFlows/DeployAndMonitorGallery.tsx @@ -24,8 +24,8 @@ const DeployAndMonitorGallery: React.FC<{ onClose: () => void }> = ({ onClose }) Use model servers to deploy models for testing and implementing in intelligent applications. Configuring a model server includes specifying the number of replicas - being deployed, the server size, the token authorization, the serving runtime, and how - the project that the model server belongs to is accessed. + being deployed, the server size, the token authentication, the serving runtime, and + how the project that the model server belongs to is accessed. } diff --git a/frontend/src/pages/modelServing/screens/projects/KServeSection/KServeInferenceServiceTableRow.tsx b/frontend/src/pages/modelServing/screens/projects/KServeSection/KServeInferenceServiceTableRow.tsx index e6bffc8749..2bcf8154b2 100644 --- a/frontend/src/pages/modelServing/screens/projects/KServeSection/KServeInferenceServiceTableRow.tsx +++ b/frontend/src/pages/modelServing/screens/projects/KServeSection/KServeInferenceServiceTableRow.tsx @@ -109,7 +109,7 @@ const KServeInferenceServiceTableRow: React.FC - Token authorization + Token authentication { title={modelMeshEnabled ? 'Start by adding a model server' : 'Start by deploying a model'} description={ modelMeshEnabled - ? 'Model servers are used to deploy models and to allow apps to send requests to your models. Configuring a model server includes specifying the number of replicas being deployed, the server size, the token authorization, the serving runtime, and how the project that the model server belongs to is accessed.\n' + ? 'Model servers are used to deploy models and to allow apps to send requests to your models. Configuring a model server includes specifying the number of replicas being deployed, the server size, the token authentication, the serving runtime, and how the project that the model server belongs to is accessed.\n' : 'Each model is deployed on its own model server.' } createButton={ diff --git a/frontend/src/pages/modelServing/screens/projects/ServingRuntimeModal/AuthServingRuntimeSection.tsx b/frontend/src/pages/modelServing/screens/projects/ServingRuntimeModal/AuthServingRuntimeSection.tsx index b0dd5b7bcd..5726b31c11 100644 --- a/frontend/src/pages/modelServing/screens/projects/ServingRuntimeModal/AuthServingRuntimeSection.tsx +++ b/frontend/src/pages/modelServing/screens/projects/ServingRuntimeModal/AuthServingRuntimeSection.tsx @@ -49,21 +49,21 @@ const AuthServingRuntimeSection: React.FC = ({ }, [data.tokens, setData]); return ( - + {!allowCreate && ( diff --git a/frontend/src/pages/modelServing/screens/projects/ServingRuntimeModal/ServingRuntimeTokenSection.tsx b/frontend/src/pages/modelServing/screens/projects/ServingRuntimeModal/ServingRuntimeTokenSection.tsx index ec938c4e28..2ed8b7f496 100644 --- a/frontend/src/pages/modelServing/screens/projects/ServingRuntimeModal/ServingRuntimeTokenSection.tsx +++ b/frontend/src/pages/modelServing/screens/projects/ServingRuntimeModal/ServingRuntimeTokenSection.tsx @@ -32,7 +32,7 @@ const ServingRuntimeTokenSection: React.FC = ({ allowCreate, createNewToken, }) => ( - + = ({ isExpandable isInline variant="warning" - title="Token authorization service not installed" + title="Token authentication service not installed" actionClose={ setAlertVisible(false)} />} >

The single model serving platform used by this project allows deployed models to - be accessible via external routes. It is recommended that token authorization be + be accessible via external routes. It is recommended that token authentication be enabled to protect these routes. The serving platform requires the Authorino - operator be installed on the cluster for token authorization. Contact a cluster + operator be installed on the cluster for token authentication. Contact a cluster administrator to install the operator.