Skip to content

Commit

Permalink
Cypress/unit tests. Label deleting feature. (#2953)
Browse files Browse the repository at this point in the history
* Add dummy second label

* Add unit tests

* Update cypress command

* Add cypress tests

* Revert command.js requare

* Add css classes

* Add css class
  • Loading branch information
dvkruchinin authored Mar 19, 2021
1 parent eb1cb83 commit c3fb14b
Show file tree
Hide file tree
Showing 9 changed files with 200 additions and 6 deletions.
19 changes: 18 additions & 1 deletion cvat-core/tests/api/projects.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// Copyright (C) 2019-2020 Intel Corporation
// Copyright (C) 2019-2021 Intel Corporation
//
// SPDX-License-Identifier: MIT

Expand Down Expand Up @@ -168,3 +168,20 @@ describe('Feature: delete a project', () => {
expect(result).toHaveLength(0);
});
});

describe('Feature: delete a label', () => {
test('delete a label', async () => {
let result = await window.cvat.projects.get({
id: 2,
});

const labelsLength = result[0].labels.length;
const deletedLabels = result[0].labels.filter((el) => el.name !== 'bicycle');
result[0].labels = deletedLabels;
result[0].save();
result = await window.cvat.projects.get({
id: 2,
});
expect(result[0].labels).toHaveLength(labelsLength - 1);
});
});
19 changes: 18 additions & 1 deletion cvat-core/tests/api/tasks.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// Copyright (C) 2020 Intel Corporation
// Copyright (C) 2020-2021 Intel Corporation
//
// SPDX-License-Identifier: MIT

Expand Down Expand Up @@ -196,3 +196,20 @@ describe('Feature: delete a task', () => {
expect(result).toHaveLength(0);
});
});

describe('Feature: delete a label', () => {
test('delete a label', async () => {
let result = await window.cvat.tasks.get({
id: 100,
});

const labelsLength = result[0].labels.length;
const deletedLabels = result[0].labels.filter((el) => el.name !== 'person');
result[0].labels = deletedLabels;
result[0].save();
result = await window.cvat.tasks.get({
id: 100,
});
expect(result[0].labels).toHaveLength(labelsLength - 1);
});
});
6 changes: 6 additions & 0 deletions cvat-core/tests/mocks/dummy-data.mock.js
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,12 @@ const projectsDummyData = {
},
],
},
{
id: 2,
name: 'bicycle',
color: '#bb20c0',
attributes: [],
},
],
tasks: [
{
Expand Down
1 change: 1 addition & 0 deletions cvat-ui/src/components/annotation-page/annotation-page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,7 @@ export default function AnnotationPageComponent(props: Props): JSX.Element {
</span>
),
placement: 'topRight',
className: 'cvat-notification-no-labels',
});
}
}, [job, fetching, prevJob, prevFetching]);
Expand Down
1 change: 1 addition & 0 deletions cvat-ui/src/components/labels-editor/labels-editor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,7 @@ export default class LabelsEditor extends React.PureComponent<LabelsEditortProps

if (typeof label.id !== 'undefined' && label.id >= 0) {
ModalConfirm({
className: 'cvat-modal-delete-label',
title: `Do you want to delete "${label.name}" label?`,
icon: <ExclamationCircleOutlined />,
content: 'This action is irreversible. Annotation corresponding with this label will be deleted.',
Expand Down
1 change: 1 addition & 0 deletions cvat-ui/src/reducers/notifications-reducer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -665,6 +665,7 @@ export default function (state = defaultState, action: AnyAction): Notifications
jobFetching: {
message: 'Error during fetching a job',
reason: action.payload.error.toString(),
className: 'cvat-notification-notice-fetch-job-failed',
},
},
},
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
// Copyright (C) 2021 Intel Corporation
//
// SPDX-License-Identifier: MIT

/// <reference types="cypress" />

import { projectName, labelName } from '../../support/const_project';

context('Delete a label from a project.', () => {
const caseID = 57;
const taskName = `Task case ${caseID}`;
const attrName = `Attr for ${labelName}`;
const textDefaultValue = 'Some value for type Text';
const imagesCount = 1;
const imageFileName = `image_${taskName.replace(/\s+/g, '_').toLowerCase()}`;
const width = 800;
const height = 800;
const posX = 10;
const posY = 10;
const color = 'white';
const archiveName = `${imageFileName}.zip`;
const archivePath = `cypress/fixtures/${archiveName}`;
const imagesFolder = `cypress/fixtures/${imageFileName}`;
const directoryToArchive = imagesFolder;
const advancedConfigurationParams = false;
const forProject = true;
const attachToProject = false;
const multiAttrParams = false;
let projectID = '';

function getProjectID(projectName) {
cy.contains('.cvat-project-name', projectName)
.parents('.cvat-project-details')
.should('have.attr', 'cvat-project-id')
.then(($projectID) => {
projectID = $projectID;
});
}

before(() => {
cy.imageGenerator(imagesFolder, imageFileName, width, height, color, posX, posY, labelName, imagesCount);
cy.createZipArchive(directoryToArchive, archivePath);
cy.openProject(projectName);
});

after(() => {
cy.goToProjectsList();
cy.deleteProject(projectName, projectID);
});

describe(`Testing "Case ${caseID}"`, () => {
it('Create a task from project.', () => {
cy.createAnnotationTask(
taskName,
labelName,
attrName,
textDefaultValue,
archiveName,
multiAttrParams,
advancedConfigurationParams,
forProject,
attachToProject,
projectName,
);
});

it('Delete a label from project.', () => {
cy.openProject(projectName);
getProjectID(projectName);
cy.contains('.cvat-constructor-viewer-item', labelName)
.should('exist')
.and('be.visible')
.find('[aria-label="close"]')
.click();
cy.get('.cvat-modal-delete-label')
.should('be.visible')
.within(() => {
cy.contains('[type="button"]', 'OK').click();
});
cy.contains('.cvat-constructor-viewer-item', labelName).should('not.exist');
});

it('Try to open job with no labels in the project. Successful.', () => {
cy.openTaskJob(taskName);
cy.get('.cvat-disabled-canvas-control').should('exist');
cy.contains('.cvat-notification-no-labels', 'does not contain any label').should('exist').and('be.visible');
});
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
// Copyright (C) 2021 Intel Corporation
//
// SPDX-License-Identifier: MIT

/// <reference types="cypress" />

context('Delete a label from a task.', () => {
const caseId = '58';
const labelName = `Case ${caseId}`;
const taskName = `New annotation task for ${labelName}`;
const attrName = `Attr for ${labelName}`;
const textDefaultValue = 'Some default value for type Text';
const imagesCount = 1;
const imageFileName = `image_${labelName.replace(' ', '_').toLowerCase()}`;
const width = 800;
const height = 800;
const posX = 10;
const posY = 10;
const color = 'gray';
const archiveName = `${imageFileName}.zip`;
const archivePath = `cypress/fixtures/${archiveName}`;
const imagesFolder = `cypress/fixtures/${imageFileName}`;
const directoryToArchive = imagesFolder;

before(() => {
cy.visit('auth/login');
cy.login();
cy.imageGenerator(imagesFolder, imageFileName, width, height, color, posX, posY, labelName, imagesCount);
cy.createZipArchive(directoryToArchive, archivePath);
cy.createAnnotationTask(taskName, labelName, attrName, textDefaultValue, archiveName);
cy.openTask(taskName);
});

after(() => {
cy.goToTaskList();
cy.deleteTask(taskName);
});

describe(`Testing "${labelName}"`, () => {
it('Delete a label from the task.', () => {
cy.contains('.cvat-constructor-viewer-item', labelName)
.should('exist')
.and('be.visible')
.find('[aria-label="close"]')
.click();
cy.get('.cvat-modal-delete-label')
.should('be.visible')
.within(() => {
cy.contains('[type="button"]', 'OK').click();
});
cy.contains('.cvat-constructor-viewer-item', labelName).should('not.exist');
});

it('Try to open a job with no labels. Successful.', () => {
cy.openJob();
cy.get('.cvat-disabled-canvas-control').should('exist');
cy.contains('.cvat-notification-no-labels', 'does not contain any label').should('exist').and('be.visible');
});
});
});
10 changes: 6 additions & 4 deletions tests/cypress/support/commands.js
Original file line number Diff line number Diff line change
Expand Up @@ -162,12 +162,14 @@ Cypress.Commands.add('getJobNum', (jobID) => {
});
});

Cypress.Commands.add('openJob', (jobID = 0, removeAnnotations = true) => {
Cypress.Commands.add('openJob', (jobID = 0, removeAnnotations = true, expectedFail = false) => {
cy.getJobNum(jobID).then(($job) => {
cy.get('.cvat-task-jobs-table-row').contains('a', `Job #${$job}`).click();
});
cy.url().should('include', '/jobs');
cy.get('.cvat-canvas-container').should('exist');
expectedFail
? cy.get('.cvat-canvas-container').should('not.exist')
: cy.get('.cvat-canvas-container').should('exist');
if (removeAnnotations) {
cy.document().then((doc) => {
const objects = Array.from(doc.querySelectorAll('.cvat_canvas_shape'));
Expand All @@ -179,9 +181,9 @@ Cypress.Commands.add('openJob', (jobID = 0, removeAnnotations = true) => {
}
});

Cypress.Commands.add('openTaskJob', (taskName, jobID = 0, removeAnnotations = true) => {
Cypress.Commands.add('openTaskJob', (taskName, jobID = 0, removeAnnotations = true, expectedFail = false) => {
cy.openTask(taskName);
cy.openJob(jobID, removeAnnotations);
cy.openJob(jobID, removeAnnotations, expectedFail);
});

Cypress.Commands.add('interactControlButton', (objectType) => {
Expand Down

0 comments on commit c3fb14b

Please sign in to comment.