From: Lucas Di Pentima Date: Fri, 8 Apr 2022 14:28:00 +0000 (-0300) Subject: 18881: Adds integration test for error & warning runtime status indicators. X-Git-Tag: 2.4.1~5^2~3 X-Git-Url: https://git.arvados.org/arvados-workbench2.git/commitdiff_plain/a5750c261be0991d8ebbe107115c9c5b01236f8d 18881: Adds integration test for error & warning runtime status indicators. Arvados-DCO-1.1-Signed-off-by: Lucas Di Pentima --- diff --git a/cypress/integration/process.spec.js b/cypress/integration/process.spec.js index 75c318db..3234f7c4 100644 --- a/cypress/integration/process.spec.js +++ b/cypress/integration/process.spec.js @@ -191,4 +191,58 @@ describe('Process tests', function() { }); }); }); + + it('should show runtime status indicators', function() { + // Setup running container with runtime_status error & warning messages + createContainerRequest( + activeUser, + 'test_container_request', + 'arvados/jobs', + ['echo', 'hello world'], + false, 'Committed') + .as('containerRequest') + .then(function(containerRequest) { + expect(containerRequest.state).to.equal('Committed'); + expect(containerRequest.container_uuid).not.to.be.equal(''); + + cy.getContainer(activeUser.token, containerRequest.container_uuid) + .then(function(queuedContainer) { + expect(queuedContainer.state).to.be.equal('Queued'); + }); + cy.updateContainer(adminUser.token, containerRequest.container_uuid, { + state: 'Locked' + }).then(function(lockedContainer) { + expect(lockedContainer.state).to.be.equal('Locked'); + + cy.updateContainer(adminUser.token, lockedContainer.uuid, { + state: 'Running', + runtime_status: { + error: 'Something went wrong', + errorDetail: 'Process exited with status 1', + warning: 'Free disk space is low', + } + }) + .as('runningContainer') + .then(function(runningContainer) { + expect(runningContainer.state).to.be.equal('Running'); + expect(runningContainer.runtime_status).to.be.deep.equal({ + 'error': 'Something went wrong', + 'errorDetail': 'Process exited with status 1', + 'warning': 'Free disk space is low', + }); + }); + }) + }); + // Test that the UI shows the error and warning messages + cy.getAll('@containerRequest', '@runningContainer').then(function([containerRequest]) { + cy.loginAs(activeUser); + cy.goToPath(`/processes/${containerRequest.uuid}`); + cy.get('[data-cy=process-runtime-status-error]') + .should('contain', 'Something went wrong') + .and('contain', 'Process exited with status 1'); + cy.get('[data-cy=process-runtime-status-warning]') + .should('contain', 'Free disk space is low') + .and('contain', 'No additional warning details available'); + }); + }); }); \ No newline at end of file diff --git a/src/views-components/process-runtime-status/process-runtime-status.tsx b/src/views-components/process-runtime-status/process-runtime-status.tsx index fdd635d2..26e0459d 100644 --- a/src/views-components/process-runtime-status/process-runtime-status.tsx +++ b/src/views-components/process-runtime-status/process-runtime-status.tsx @@ -55,7 +55,7 @@ export const ProcessRuntimeStatus = withStyles(styles)( ({ runtimeStatus, classes }: ProcessRuntimeStatusProps) => { return <> { runtimeStatus?.error && - +
}> {`Error: ${runtimeStatus.error }`} @@ -66,10 +66,10 @@ export const ProcessRuntimeStatus = withStyles(styles)( {runtimeStatus?.errorDetail || 'No additional error details available'} - +
} { runtimeStatus?.warning && - +
}> {`Warning: ${runtimeStatus.warning }`} @@ -80,7 +80,7 @@ export const ProcessRuntimeStatus = withStyles(styles)( {runtimeStatus?.warningDetail || 'No additional warning details available'} - +
} }); \ No newline at end of file