From d9e9860a2377ef7b40b43dee4ac515ad113098b0 Mon Sep 17 00:00:00 2001 From: Kirill Lakhov Date: Fri, 24 Jan 2025 14:45:19 +0300 Subject: [PATCH] Test cases for improved quality UX (#8956) --- .../components/quality-control/styles.scss | 8 ++---- .../task-quality/quality-table-header.tsx | 6 ++--- .../cypress/e2e/features/ground_truth_jobs.js | 27 +++++++++++++++++++ tests/cypress/support/commands.js | 13 +++++++++ 4 files changed, 45 insertions(+), 9 deletions(-) diff --git a/cvat-ui/src/components/quality-control/styles.scss b/cvat-ui/src/components/quality-control/styles.scss index 9b8f7e8d590..89001833798 100644 --- a/cvat-ui/src/components/quality-control/styles.scss +++ b/cvat-ui/src/components/quality-control/styles.scss @@ -77,7 +77,7 @@ $excluded-background: #d9d9d973; } } -.cvat-frame-allocation-actions { +.cvat-quality-table-header { span[role='img'] { padding: 0 $grid-unit-size; } @@ -87,7 +87,7 @@ $excluded-background: #d9d9d973; } } -.cvat-frame-allocation-header { +.cvat-quality-table-header-title { margin-bottom: 0; font-size: 20px; font-weight: bold; @@ -120,10 +120,6 @@ $excluded-background: #d9d9d973; transform: translate(-50%, -50%); } -.cvat-quality-control-overview-tab { - min-height: 50vh; -} - .cvat-annotations-quality-allocation-table-summary { margin-bottom: $grid-unit-size * 2; diff --git a/cvat-ui/src/components/quality-control/task-quality/quality-table-header.tsx b/cvat-ui/src/components/quality-control/task-quality/quality-table-header.tsx index f73316aa0d9..d8cb928dda0 100644 --- a/cvat-ui/src/components/quality-control/task-quality/quality-table-header.tsx +++ b/cvat-ui/src/components/quality-control/task-quality/quality-table-header.tsx @@ -45,12 +45,12 @@ function QualityTableHeader(props: TableHeaderProps): JSX.Element { }; return ( - + - {title} + {title} - + {actions} {!!onSearch && ( diff --git a/tests/cypress/e2e/features/ground_truth_jobs.js b/tests/cypress/e2e/features/ground_truth_jobs.js index f5260ddf9ed..61cec62c748 100644 --- a/tests/cypress/e2e/features/ground_truth_jobs.js +++ b/tests/cypress/e2e/features/ground_truth_jobs.js @@ -356,6 +356,33 @@ context('Ground truth jobs', () => { cy.contains('.cvat-allocation-summary-excluded', '0').should('exist'); cy.contains('.cvat-allocation-summary-active', '3').should('exist'); }); + + it('Check search feature', () => { + cy.get('.cvat-quality-table-search-bar input').clear(); + serverFiles.forEach((file, index) => { + cy.get('.cvat-quality-table-search-bar input').type(`image_${index + 1}`); + cy.get('.cvat-quality-table-search-bar .ant-input-search-button').click(); + cy.get('.cvat-allocation-frame-row').should('have.length', 1); + cy.get('.cvat-allocation-frame-row').within(() => { + cy.contains(file).should('exist'); + }); + cy.get('.cvat-quality-table-search-bar input').clear(); + }); + + cy.get('.cvat-quality-table-search-bar .ant-input-search-button').click(); + cy.get('.cvat-allocation-frame-row').should('have.length', 3); + }); + + it('Check management table .csv representation is available for download', () => { + cy.get('.cvat-quality-control-management-tab .cvat-quality-table-dowload-button').click(); + + const expectedFileName = `allocation-table-task_${taskID}.csv`; + cy.verifyDownload(expectedFileName); + cy.checkCsvFileContent(expectedFileName, 'frame,name,active', 4, (row, index) => { + expect(row).to.include(`images/image_${index + 1}.jpg`); + expect(row).to.include('true'); + }); + }); }); describe('Regression tests', () => { diff --git a/tests/cypress/support/commands.js b/tests/cypress/support/commands.js index bc929c4b558..2d72fb9b24f 100644 --- a/tests/cypress/support/commands.js +++ b/tests/cypress/support/commands.js @@ -1705,6 +1705,19 @@ Cypress.Commands.add('checkDeletedFrameVisibility', () => { cy.closeSettings(); }); +Cypress.Commands.add('checkCsvFileContent', (expectedFileName, header, rowsCount, checkRow = null) => { + const downloadsFolder = Cypress.config('downloadsFolder'); + const filePath = `${downloadsFolder}/${expectedFileName}`; + cy.readFile(filePath).then((csv) => { + const rows = csv.split('\n'); + expect(rows.length).to.equal(rowsCount); + expect(rows[0]).to.include(header); + if (checkRow) { + rows.slice(1).forEach(checkRow); + } + }); +}); + Cypress.Commands.overwrite('visit', (orig, url, options) => { orig(url, options); cy.closeModalUnsupportedPlatform();