Initial Upload
This commit is contained in:
85
cypress/e2e/Layout/Editor/layout_editor_background.cy.js
Normal file
85
cypress/e2e/Layout/Editor/layout_editor_background.cy.js
Normal file
@@ -0,0 +1,85 @@
|
||||
/*
|
||||
* Copyright (C) 2025 Xibo Signage Ltd
|
||||
*
|
||||
* Xibo - Digital Signage - https://xibosignage.com
|
||||
*
|
||||
* This file is part of Xibo.
|
||||
*
|
||||
* Xibo is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Affero General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* any later version.
|
||||
*
|
||||
* Xibo is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Affero General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Affero General Public License
|
||||
* along with Xibo. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
/* eslint-disable max-len */
|
||||
describe('Layout Editor Background', function() {
|
||||
const SELECTORS = {
|
||||
layoutAddButton: 'button.layout-add-button',
|
||||
layoutViewer: '#layout-viewer',
|
||||
propertiesPanel: '#properties-panel',
|
||||
colorPickerTrigger: '.input-group-prepend',
|
||||
colorPickerSaturation: '.colorpicker-saturation',
|
||||
backgroundColorInput: '#input_backgroundColor',
|
||||
backgroundzIndex: '#input_backgroundzIndex',
|
||||
resolutionDropdown: '#input_resolutionId',
|
||||
select2Selection: '.select2-selection',
|
||||
select2SearchInput: '.select2-container--open input[type="search"]',
|
||||
layoutInfoDimensions: '.layout-info-dimensions span',
|
||||
};
|
||||
|
||||
beforeEach(function() {
|
||||
cy.login();
|
||||
cy.visit('/layout/view');
|
||||
cy.get(SELECTORS.layoutAddButton).click();
|
||||
cy.get(SELECTORS.layoutViewer).should('be.visible'); // Assert that the URL has changed to the layout editor
|
||||
});
|
||||
|
||||
it('should update the background according to the colour set via colour picker', function() {
|
||||
cy.get(SELECTORS.propertiesPanel).should('be.visible'); // Verify properties panel is present
|
||||
cy.get(SELECTORS.colorPickerTrigger).click(); // Open colour picker
|
||||
cy.get(SELECTORS.colorPickerSaturation).click(68, 28); // Select on a specific saturation
|
||||
cy.get(SELECTORS.propertiesPanel).click(30, 60); // Click outside color picker to close
|
||||
|
||||
// Verify the selected color is applied to the background
|
||||
cy.get(SELECTORS.layoutViewer).should('have.css', 'background-color', 'rgb(243, 248, 255)');
|
||||
});
|
||||
|
||||
it('should update the background according to the colour set via hex input', function() {
|
||||
cy.get(SELECTORS.propertiesPanel).should('be.visible');
|
||||
cy.get(SELECTORS.backgroundColorInput).clear().type('#b53939{enter}');
|
||||
|
||||
// Verify the selected color is applied to the background
|
||||
cy.get(SELECTORS.layoutViewer).should('have.css', 'background-color', 'rgb(243, 248, 255)');
|
||||
});
|
||||
|
||||
it('should update the layer according to the input', function() {
|
||||
cy.get(SELECTORS.propertiesPanel).should('be.visible');
|
||||
cy.get(SELECTORS.backgroundzIndex).clear().type('1{enter}');
|
||||
|
||||
// Verify the selected number is applied to the layer
|
||||
cy.get(SELECTORS.backgroundzIndex).should('have.value', '1');
|
||||
});
|
||||
|
||||
// This is failing and a bug reported
|
||||
it.skip('should update the layout resolution', function() {
|
||||
cy.get(SELECTORS.propertiesPanel).should('be.visible');
|
||||
const resName = 'cinema';
|
||||
|
||||
cy.get(SELECTORS.resolutionDropdown).parent().find(SELECTORS.select2Selection).click();
|
||||
cy.get(SELECTORS.select2SearchInput).type(resName);
|
||||
cy.selectOption(resName);
|
||||
|
||||
cy.get(SELECTORS.layoutInfoDimensions)
|
||||
.should('be.visible')
|
||||
.and('contain', '4096x2304');
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user