diff --git a/cvat-ui/.eslintrc.js b/cvat-ui/.eslintrc.js index 0c726f0458bb..28d9241e9e38 100644 --- a/cvat-ui/.eslintrc.js +++ b/cvat-ui/.eslintrc.js @@ -59,7 +59,7 @@ module.exports = { settings: { 'import/resolver': { node: { - paths: ['src'], + paths: ['src', `${__dirname}/src`], }, }, }, diff --git a/cvat-ui/src/components/annotation-page/standard-workspace/propagate-confirm.tsx b/cvat-ui/src/components/annotation-page/standard-workspace/propagate-confirm.tsx index 1ac36d169d14..6b5b6bd97fea 100644 --- a/cvat-ui/src/components/annotation-page/standard-workspace/propagate-confirm.tsx +++ b/cvat-ui/src/components/annotation-page/standard-workspace/propagate-confirm.tsx @@ -1,4 +1,4 @@ -// Copyright (C) 2020 Intel Corporation +// Copyright (C) 2020-2021 Intel Corporation // // SPDX-License-Identifier: MIT @@ -49,6 +49,7 @@ export default function PropagateConfirmComponent(props: Props): JSX.Element {
Do you want to make a copy of the object on 1 ? frames : frame } up to the + +import { taskName, labelName } from '../../support/const'; + +context('Object propagate.', () => { + const caseId = '53'; + const createCuboidShape2Points = { + points: 'From rectangle', + type: 'Shape', + labelName: labelName, + firstX: 250, + firstY: 350, + secondX: 350, + secondY: 450, + }; + const propagateOnOneFrame = 1; + const propagateOnTwoFrames = 2; + + function startPropagation() { + cy.get('#cvat-objects-sidebar-state-item-1').find('[aria-label="more"]').trigger('mouseover'); + cy.get('.cvat-object-item-menu').within(() => { + cy.contains('button', 'Propagate').click(); + }); + } + + before(() => { + cy.openTaskJob(taskName); + cy.createCuboid(createCuboidShape2Points); + }); + + describe(`Testing case "${caseId}"`, () => { + it('On the 1st frame propagate object on 1 frame.', () => { + startPropagation(); + cy.get('.cvat-propagate-confirm-object-on-frames') // Change value in the "copy of the object on frame" field + .find('input') + .clear() + .type(propagateOnOneFrame); + cy.get('.cvat-propagate-confirm-object-up-to-frame') // Value of "up to the frame" field should be same + .find('input') + .should('have.attr', 'value', propagateOnOneFrame); + cy.contains('button', 'Yes').click(); + }); + + it('On the 1st and 2nd frames, the number of objects is equal to 1. On the 3rd frame is 0.', () => { + cy.get('.cvat_canvas_shape_cuboid').then(($cuboidCountFirstFrame) => { + cy.goCheckFrameNumber(1); // Go to 2nd frame + cy.get('.cvat_canvas_shape_cuboid').then(($cuboidCountSecondFrame) => { + expect($cuboidCountFirstFrame.length).to.be.equal($cuboidCountSecondFrame.length); + }); + }); + cy.goCheckFrameNumber(2); // Go to 3rd frame + cy.get('.cvat_canvas_shape_cuboid').should('not.exist'); + cy.get('.cvat-player-first-button').click(); + }); + + it('From the 1st frame propagate again on 2 frames.', () => { + startPropagation(); + cy.get('.cvat-propagate-confirm-object-up-to-frame') // Change value in the "up to the frame" field + .find('input') + .clear() + .type(propagateOnTwoFrames) + .should('have.attr', 'value', propagateOnTwoFrames); + cy.get('.cvat-propagate-confirm-object-on-frames') // Value of "copy of the object on frames" field should be same + .find('input') + .should('have.attr', 'value', propagateOnTwoFrames); + cy.contains('button', 'Yes').click(); + }); + + it('On the 1st and 3rd frames the number of objects is equal to 1. On the 2nd frame equal to 2. On the 4th frame equal to 0', () => { + cy.get('.cvat_canvas_shape_cuboid').then(($cuboidCountFirstFrame) => { + cy.goCheckFrameNumber(2); // Go to 3rd frame + cy.get('.cvat_canvas_shape_cuboid').then(($cuboidCountThirdFrame) => { + expect($cuboidCountFirstFrame.length).to.be.equal($cuboidCountThirdFrame.length); + }); + }); + cy.goCheckFrameNumber(1); // Go to 2nd frame + cy.get('.cvat_canvas_shape_cuboid').then(($cuboidCountSecondFrame) => { + expect($cuboidCountSecondFrame.length).to.be.equal(2); + }); + cy.goCheckFrameNumber(3); // Go to 4th frame + cy.get('.cvat_canvas_shape_cuboid').should('not.exist'); + }); + }); +});