diff --git a/cypress/integration/ui/__snapshots__/scenario4.js.snap b/cypress/integration/ui/__snapshots__/scenario4.js.snap
new file mode 100644
index 00000000..0716bc69
--- /dev/null
+++ b/cypress/integration/ui/__snapshots__/scenario4.js.snap
@@ -0,0 +1,965 @@
+exports[`use all parts of svg-edit > check tool_source_set #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_rect #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_fhrect #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_square #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_rect_change_fill_color #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_rect_change_rotation #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_rect_change_blur #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_rect_change_opacity #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_fhrect_change_x_y_coordinate #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_fhrect_change_width_height #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_square_clone #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_square_bring_to_back #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_square_bring_to_front #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_square_change_corner_radius #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_rect_change_to_path #0`] = `
+
+`;
+
+exports[`use all parts of svg-edit > check tool_rect_delete #0`] = `
+
+`;
diff --git a/cypress/integration/ui/scenario4.js b/cypress/integration/ui/scenario4.js
new file mode 100644
index 00000000..3553f4e2
--- /dev/null
+++ b/cypress/integration/ui/scenario4.js
@@ -0,0 +1,144 @@
+import {
+ visitAndApproveStorage
+} from '../../support/ui-test-helper.js';
+
+const testSnapshot = () => {
+ cy.get('#svgcontent').cleanSnapshot();
+};
+
+describe('use all parts of svg-edit', function () {
+ before(() => {
+ visitAndApproveStorage();
+ });
+
+ it('check tool_source_set', function () {
+ cy.get('#tool_source').click({ force: true });
+ cy.get('#svg_source_textarea')
+ .type('{selectall}', { force: true })
+ .type(``, { force: true, parseSpecialCharSequences: false });
+ cy.get('#tool_source_save').click({ force: true });
+ testSnapshot();
+ });
+ it('check tool_rect', function () {
+ cy.get('#tool_rect')
+ .click({ force: true });
+ cy.get('#svgcontent')
+ .trigger('mousedown', 150, 150, { force: true })
+ .trigger('mousemove', 250, 200, { force: true })
+ .trigger('mouseup', { force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_fhrect', function () {
+ cy.get('#tool_fhrect')
+ .click({ force: true });
+ cy.get('#svgcontent')
+ .trigger('mousedown', 200, 80, { force: true })
+ .trigger('mousemove', 320, 80, { force: true })
+ .trigger('mousemove', 320, 180, { force: true })
+ .trigger('mousemove', 200, 180, { force: true })
+ .trigger('mousemove', 200, 80, { force: true })
+ .trigger('mouseup', 200, 80, { force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_square', function () {
+ cy.get('#tool_square').click({ force: true });
+ cy.get('#svgcontent')
+ .trigger('mousedown', 75, 150, { force: true })
+ .trigger('mousemove', 125, 200, { force: true })
+ .trigger('mouseup', { force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_rect_change_fill_color', function () {
+ cy.get('#svg_1').click({ force: true });
+ cy.get('#js-se-palette').find('.square').eq(8)
+ .click({ force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_rect_change_rotation', function () {
+ cy.get('#svg_1').click({ force: true });
+ for(let n = 0; n < 5; n ++){
+ cy.get('#angle').shadow().find('elix-number-spin-box').eq(0).shadow().find('#upButton').eq(0)
+ .click({ force: true });
+ }
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_rect_change_blur', function () {
+ cy.get('#svg_1').click({ force: true });
+ for(let n = 0; n < 10; n ++){
+ cy.get('#blur').shadow().find('elix-number-spin-box').eq(0).shadow().find('#upButton').eq(0)
+ .click({ force: true });
+ }
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_rect_change_opacity', function () {
+ cy.get('#svg_1').click({ force: true });
+ for(let n = 0; n < 10; n ++){
+ cy.get('#opacity').shadow().find('elix-number-spin-box').eq(0).shadow().find('#downButton').eq(0)
+ .click({ force: true });
+ }
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_fhrect_change_x_y_coordinate', function () {
+ cy.get('#svg_2').click({ force: true });
+ for(let n = 0; n < 25; n ++){
+ cy.get('#ellipse_cx').shadow().find('elix-number-spin-box').eq(0).shadow().find('#upButton').eq(0)
+ .click({ force: true });
+ }
+ for(let n = 0; n < 25; n ++){
+ cy.get('#ellipse_cy').shadow().find('elix-number-spin-box').eq(0).shadow().find('#upButton').eq(0)
+ .click({ force: true });
+ }
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_fhrect_change_width_height', function () {
+ cy.get('#svg_2').click({ force: true });
+ for(let n = 0; n < 25; n ++){
+ cy.get('#rect_width').shadow().find('elix-number-spin-box').eq(0).shadow().find('#upButton').eq(0)
+ .click({ force: true });
+ }
+ for(let n = 0; n < 25; n ++){
+ cy.get('#rect_height').shadow().find('elix-number-spin-box').eq(0).shadow().find('#upButton').eq(0)
+ .click({ force: true });
+ }
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_square_clone', function () {
+ cy.get('#svg_3').click({ force: true });
+ cy.get('#tool_clone').click({ force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_square_bring_to_back', function () {
+ cy.get('#svg_3').click({ force: true });
+ cy.get('#tool_move_bottom').click({ force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_square_bring_to_front', function () {
+ cy.get('#svg_3').click({ force: true });
+ cy.get('#tool_move_top').click({ force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_square_change_corner_radius', function () {
+ cy.get('#svg_4').click({ force: true });
+ for(let n = 0; n < 25; n ++){
+ cy.get('#rect_rx').shadow().find('elix-number-spin-box').eq(0).shadow().find('#upButton').eq(0)
+ .click({ force: true });
+ }
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_rect_change_to_path', function () {
+ cy.get('#svg_2').click({ force: true });
+ cy.get('#tool_topath').click({ force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+ it('check tool_rect_delete', function () {
+ cy.get('#svg_1').click({ force: true });
+ cy.get('#tool_delete').click({ force: true });
+ cy.get('#svg_3').click({ force: true });
+ cy.get('#tool_delete').click({ force: true });
+ cy.get('#svgcontent').toMatchSnapshot();
+ });
+});