From a5750c261be0991d8ebbe107115c9c5b01236f8d Mon Sep 17 00:00:00 2001 From: Lucas Di Pentima Date: Fri, 8 Apr 2022 11:28:00 -0300 Subject: [PATCH] 18881: Adds integration test for error & warning runtime status indicators. Arvados-DCO-1.1-Signed-off-by: Lucas Di Pentima --- cypress/integration/process.spec.js | 54 +++++++++++++++++++ .../process-runtime-status.tsx | 8 +-- 2 files changed, 58 insertions(+), 4 deletions(-) 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 -- 2.30.2