From e994f5d99c17439af878c762fafb9a28b4e2b133 Mon Sep 17 00:00:00 2001 From: Odei Maiz <33152403+odeimaiz@users.noreply.github.com> Date: Wed, 30 Oct 2024 09:25:57 +0100 Subject: [PATCH] =?UTF-8?q?=F0=9F=8E=A8=20[e2e-frontend]=20Check=20study?= =?UTF-8?q?=20browser=20(#6635)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../class/osparc/dashboard/ResourceFilter.js | 3 + .../dashboard/WorkspacesAndFoldersTreeItem.js | 2 + .../class/osparc/navigation/UserMenu.js | 1 + .../client/source/class/osparc/utils/Utils.js | 4 +- .../class/osparc/widget/NodeTreeItem.js | 4 +- .../e2e-frontend/tests/fixtures/loginPage.js | 6 ++ .../tests/navigationBar/navigationBar.spec.js | 10 +-- .../tests/studyBrowser/leftFilters.spec.js | 54 +++++++++++++ .../tests/studyBrowser/mainView.spec.js | 81 +++++++++++++++++++ .../tests/userMenu/userMenuButtons.spec.js | 16 ++-- .../tests/userMenu/userMenuWindows.spec.js | 26 +++--- tests/e2e/utils/auto.js | 2 +- tests/e2e/utils/utils.js | 2 +- 13 files changed, 180 insertions(+), 31 deletions(-) create mode 100644 tests/e2e-frontend/tests/studyBrowser/leftFilters.spec.js create mode 100644 tests/e2e-frontend/tests/studyBrowser/mainView.spec.js diff --git a/services/static-webserver/client/source/class/osparc/dashboard/ResourceFilter.js b/services/static-webserver/client/source/class/osparc/dashboard/ResourceFilter.js index 92d0b1dc1b3..0cbb3357737 100644 --- a/services/static-webserver/client/source/class/osparc/dashboard/ResourceFilter.js +++ b/services/static-webserver/client/source/class/osparc/dashboard/ResourceFilter.js @@ -65,6 +65,7 @@ qx.Class.define("osparc.dashboard.ResourceFilter", { /* WORKSPACES AND FOLDERS */ __createWorkspacesAndFoldersTree: function() { const workspacesAndFoldersTree = this.__workspacesAndFoldersTree = new osparc.dashboard.WorkspacesAndFoldersTree(); + osparc.utils.Utils.setIdToWidget(workspacesAndFoldersTree, "contextTree"); // Height needs to be calculated manually to make it flexible workspacesAndFoldersTree.set({ minHeight: 60, @@ -137,6 +138,7 @@ qx.Class.define("osparc.dashboard.ResourceFilter", { /* TAGS */ __createTagsFilterLayout: function() { const layout = new qx.ui.container.Composite(new qx.ui.layout.VBox(5)); + osparc.utils.Utils.setIdToWidget(layout, "tagsFilter"); this.__populateTags(layout, []); osparc.store.Store.getInstance().addListener("changeTags", () => { @@ -157,6 +159,7 @@ qx.Class.define("osparc.dashboard.ResourceFilter", { layout.removeAll(); osparc.store.Store.getInstance().getTags().forEach((tag, idx) => { const button = new qx.ui.form.ToggleButton(tag.name, "@FontAwesome5Solid/tag/18"); + osparc.utils.Utils.setIdToWidget(button, "tagFilterItem"); button.id = tag.id; button.set({ appearance: "filter-toggle-button", diff --git a/services/static-webserver/client/source/class/osparc/dashboard/WorkspacesAndFoldersTreeItem.js b/services/static-webserver/client/source/class/osparc/dashboard/WorkspacesAndFoldersTreeItem.js index f643218243b..071ba7e3d6d 100644 --- a/services/static-webserver/client/source/class/osparc/dashboard/WorkspacesAndFoldersTreeItem.js +++ b/services/static-webserver/client/source/class/osparc/dashboard/WorkspacesAndFoldersTreeItem.js @@ -32,6 +32,8 @@ qx.Class.define("osparc.dashboard.WorkspacesAndFoldersTreeItem", { this.setNotHoveredStyle(); this.__attachEventHandlers(); + + osparc.utils.Utils.setIdToWidget(this, "workspacesAndFoldersTreeItem"); }, members: { diff --git a/services/static-webserver/client/source/class/osparc/navigation/UserMenu.js b/services/static-webserver/client/source/class/osparc/navigation/UserMenu.js index 025c7e5024c..b18f0a4d7b3 100644 --- a/services/static-webserver/client/source/class/osparc/navigation/UserMenu.js +++ b/services/static-webserver/client/source/class/osparc/navigation/UserMenu.js @@ -116,6 +116,7 @@ qx.Class.define("osparc.navigation.UserMenu", { } case "license": control = new qx.ui.menu.Button(this.tr("License")); + osparc.utils.Utils.setIdToWidget(control, "userMenuLicenseBtn"); osparc.store.Support.getLicenseURL() .then(licenseURL => control.addListener("execute", () => window.open(licenseURL))); this.add(control); diff --git a/services/static-webserver/client/source/class/osparc/utils/Utils.js b/services/static-webserver/client/source/class/osparc/utils/Utils.js index ab86392270c..ead285bccab 100644 --- a/services/static-webserver/client/source/class/osparc/utils/Utils.js +++ b/services/static-webserver/client/source/class/osparc/utils/Utils.js @@ -1033,9 +1033,9 @@ qx.Class.define("osparc.utils.Utils", { return null; }, - setMoreToWidget: (qWidget, id) => { + setKeyToWidget: (qWidget, id) => { if (qWidget.getContentElement) { - qWidget.getContentElement().setAttribute("osparc-test-more", id); + qWidget.getContentElement().setAttribute("osparc-test-key", id); } }, diff --git a/services/static-webserver/client/source/class/osparc/widget/NodeTreeItem.js b/services/static-webserver/client/source/class/osparc/widget/NodeTreeItem.js index 7ce4509cc56..d424973944f 100644 --- a/services/static-webserver/client/source/class/osparc/widget/NodeTreeItem.js +++ b/services/static-webserver/client/source/class/osparc/widget/NodeTreeItem.js @@ -107,7 +107,7 @@ qx.Class.define("osparc.widget.NodeTreeItem", { __applyStudy: function(study) { const label = this.getChildControl("label"); - osparc.utils.Utils.setMoreToWidget(label, "root"); + osparc.utils.Utils.setKeyToWidget(label, "root"); study.bind("name", this, "toolTipText"); @@ -116,7 +116,7 @@ qx.Class.define("osparc.widget.NodeTreeItem", { __applyNode: function(node) { const label = this.getChildControl("label"); - osparc.utils.Utils.setMoreToWidget(label, node.getNodeId()); + osparc.utils.Utils.setKeyToWidget(label, node.getNodeId()); node.bind("label", this, "toolTipText"); diff --git a/tests/e2e-frontend/tests/fixtures/loginPage.js b/tests/e2e-frontend/tests/fixtures/loginPage.js index ffee8c3fc58..04e29e66b90 100644 --- a/tests/e2e-frontend/tests/fixtures/loginPage.js +++ b/tests/e2e-frontend/tests/fixtures/loginPage.js @@ -17,6 +17,8 @@ export class LoginPage { * @param {string} password */ async login(email, password) { + await this.page.goto(this.productUrl); + const usernameField = this.page.getByTestId("loginUserEmailFld"); const passwordField = this.page.getByTestId("loginPasswordFld"); const submitButton = this.page.getByTestId("loginSubmitBtn"); @@ -24,6 +26,10 @@ export class LoginPage { await usernameField.fill(email); await passwordField.fill(password); await submitButton.click(); + + const response = await this.page.waitForResponse('**/me'); + const meData = await response.json(); + return meData["data"]["role"]; } async logout() { diff --git a/tests/e2e-frontend/tests/navigationBar/navigationBar.spec.js b/tests/e2e-frontend/tests/navigationBar/navigationBar.spec.js index 27bb724cef8..0c981ef8777 100644 --- a/tests/e2e-frontend/tests/navigationBar/navigationBar.spec.js +++ b/tests/e2e-frontend/tests/navigationBar/navigationBar.spec.js @@ -153,15 +153,9 @@ for (const product in products) { test.beforeAll(async ({ browser }) => { page = await browser.newPage(); - loginPageFixture = new LoginPage(page, productUrl); - await loginPageFixture.goto(); - - await loginPageFixture.login(user.email, user.password); - - const response = await page.waitForResponse('**/me'); - const meData = await response.json(); - expect(meData["data"]["role"]).toBe(role); + const role = await loginPageFixture.login(user.email, user.password); + expect(role).toBe(user.role); }); test.afterAll(async ({ browser }) => { diff --git a/tests/e2e-frontend/tests/studyBrowser/leftFilters.spec.js b/tests/e2e-frontend/tests/studyBrowser/leftFilters.spec.js new file mode 100644 index 00000000000..2a8dfa724d7 --- /dev/null +++ b/tests/e2e-frontend/tests/studyBrowser/leftFilters.spec.js @@ -0,0 +1,54 @@ +/* eslint-disable no-undef */ + +const { test, expect } = require('@playwright/test'); + +import { LoginPage } from '../fixtures/loginPage'; + +import products from '../products.json'; +import users from '../users.json'; + +const product = "osparc"; +const productUrl = products[product]; +const user = users[product][0]; + +test.describe.serial(`Left Filters:`, () => { + let page = null; + let loginPageFixture = null; + + test.beforeAll(async ({ browser }) => { + page = await browser.newPage(); + loginPageFixture = new LoginPage(page, productUrl); + const role = await loginPageFixture.login(user.email, user.password); + expect(role).toBe(user.role); + }); + + test.afterAll(async ({ browser }) => { + await loginPageFixture.logout(); + await page.close(); + await browser.close(); + }); + + test(`Context`, async () => { + const contextTree = page.getByTestId("contextTree"); + await expect(contextTree).toBeVisible({ + timeout: 30000 // it will take some time to load the Study Browser + }); + + const workspacesAndFoldersTreeItems = page.getByTestId("workspacesAndFoldersTreeItem"); + const count = await workspacesAndFoldersTreeItems.count(); + // at least two: My Workspace and Shared Workspaces + expect(count > 1).toBeTruthy(); + }); + + test(`Tags`, async () => { + const tagsFilter = page.getByTestId("tagsFilter"); + await expect(tagsFilter).toBeVisible({ + timeout: 30000 // it will take some time to load the Study Browser + }); + + const tagFilterItems = page.getByTestId("tagFilterItem"); + const count = await tagFilterItems.count(); + // at least two and less than 6 (max five are shown) + expect(count > 1 && count < 6).toBeTruthy(); + }); +}); diff --git a/tests/e2e-frontend/tests/studyBrowser/mainView.spec.js b/tests/e2e-frontend/tests/studyBrowser/mainView.spec.js new file mode 100644 index 00000000000..ff8890af572 --- /dev/null +++ b/tests/e2e-frontend/tests/studyBrowser/mainView.spec.js @@ -0,0 +1,81 @@ +/* eslint-disable no-undef */ + +const { test, expect } = require('@playwright/test'); + +import { LoginPage } from '../fixtures/loginPage'; + +import products from '../products.json'; +import users from '../users.json'; + +const expectedElements = { + "osparc": { + "plusButton": { + "id": "newStudyBtn", + }, + }, + "s4l": { + "plusButton": { + "id": "startS4LButton", + }, + }, + "s4lacad": { + "plusButton": { + "id": "startS4LButton", + }, + }, + "s4llite": { + "plusButton": { + "id": "startS4LButton", + }, + }, + "tis": { + "plusButton": { + "id": "newStudyBtn", + }, + }, + "tiplite": { + "plusButton": { + "id": "newStudyBtn", + }, + }, +}; + +for (const product in products) { + if (product in users) { + const productUrl = products[product]; + const productUsers = users[product]; + for (const user of productUsers) { + // expected roles for users: "USER" + const role = "USER"; + expect(user.role).toBe(role); + + test.describe.serial(`Main View: ${product}`, () => { + let page = null; + let loginPageFixture = null; + + test.beforeAll(async ({ browser }) => { + page = await browser.newPage(); + loginPageFixture = new LoginPage(page, productUrl); + const role = await loginPageFixture.login(user.email, user.password); + expect(role).toBe(user.role); + }); + + test.afterAll(async ({ browser }) => { + await loginPageFixture.logout(); + await page.close(); + await browser.close(); + }); + + test(`Plus button`, async () => { + expect(expectedElements[product]["plusButton"]).toBeDefined(); + + const plusButtonId = expectedElements[product]["plusButton"]["id"]; + const plusButton = page.getByTestId(plusButtonId); + await expect(plusButton).toBeVisible({ + timeout: 30000 // it will take some time to load the Study Browser + }); + }); + }); + } + } +} diff --git a/tests/e2e-frontend/tests/userMenu/userMenuButtons.spec.js b/tests/e2e-frontend/tests/userMenu/userMenuButtons.spec.js index d590d4429a5..053bc38f6e3 100644 --- a/tests/e2e-frontend/tests/userMenu/userMenuButtons.spec.js +++ b/tests/e2e-frontend/tests/userMenu/userMenuButtons.spec.js @@ -16,6 +16,7 @@ const userMenuButtons = { "userMenuThemeSwitcherBtn": true, "userMenuAboutBtn": true, "userMenuAboutProductBtn": true, + "userMenuLicenseBtn": true, "userMenuAccessTIPBtn": false, "userMenuLogoutBtn": true, }, @@ -27,6 +28,7 @@ const userMenuButtons = { "userMenuThemeSwitcherBtn": true, "userMenuAboutBtn": true, "userMenuAboutProductBtn": true, + "userMenuLicenseBtn": true, "userMenuAccessTIPBtn": false, "userMenuLogoutBtn": true, }, @@ -38,6 +40,7 @@ const userMenuButtons = { "userMenuThemeSwitcherBtn": true, "userMenuAboutBtn": true, "userMenuAboutProductBtn": true, + "userMenuLicenseBtn": true, "userMenuAccessTIPBtn": false, "userMenuLogoutBtn": true, }, @@ -49,6 +52,7 @@ const userMenuButtons = { "userMenuThemeSwitcherBtn": true, "userMenuAboutBtn": true, "userMenuAboutProductBtn": true, + "userMenuLicenseBtn": true, "userMenuAccessTIPBtn": false, "userMenuLogoutBtn": true, }, @@ -60,6 +64,7 @@ const userMenuButtons = { "userMenuThemeSwitcherBtn": true, "userMenuAboutBtn": true, "userMenuAboutProductBtn": true, + "userMenuLicenseBtn": true, "userMenuAccessTIPBtn": false, "userMenuLogoutBtn": true, }, @@ -71,6 +76,7 @@ const userMenuButtons = { "userMenuThemeSwitcherBtn": true, "userMenuAboutBtn": true, "userMenuAboutProductBtn": true, + "userMenuLicenseBtn": true, "userMenuAccessTIPBtn": true, "userMenuLogoutBtn": true, }, @@ -108,15 +114,9 @@ for (const product in products) { test.beforeAll(async ({ browser }) => { page = await browser.newPage(); - loginPageFixture = new LoginPage(page, productUrl); - await loginPageFixture.goto(); - - await loginPageFixture.login(user.email, user.password); - - const response = await page.waitForResponse('**/me'); - const meData = await response.json(); - expect(meData["data"]["role"]).toBe(role); + const role = await loginPageFixture.login(user.email, user.password); + expect(role).toBe(user.role); }); test.afterAll(async ({ browser }) => { diff --git a/tests/e2e-frontend/tests/userMenu/userMenuWindows.spec.js b/tests/e2e-frontend/tests/userMenu/userMenuWindows.spec.js index 4a50cd45153..6303528c8c0 100644 --- a/tests/e2e-frontend/tests/userMenu/userMenuWindows.spec.js +++ b/tests/e2e-frontend/tests/userMenu/userMenuWindows.spec.js @@ -9,7 +9,7 @@ import users from '../users.json'; const product = "osparc"; const productUrl = products[product]; -const user = users[product]; +const user = users[product][0]; test.describe.serial(`User Menu Windows: ${product}`, () => { let page = null; @@ -17,15 +17,9 @@ test.describe.serial(`User Menu Windows: ${product}`, () => { test.beforeAll(async ({ browser }) => { page = await browser.newPage(); - loginPageFixture = new LoginPage(page, productUrl); - await loginPageFixture.goto(); - - await loginPageFixture.login(user.email, user.password); - - const response = await page.waitForResponse('**/me'); - const meData = await response.json(); - expect(meData["data"]["role"]).toBe(user.role); + const role = await loginPageFixture.login(user.email, user.password); + expect(role).toBe(user.role); }); test.afterAll(async ({ browser }) => { @@ -51,4 +45,18 @@ test.describe.serial(`User Menu Windows: ${product}`, () => { // close window await page.getByTestId("organizationsWindowCloseBtn").click(); }); + + test(`License pop up`, async () => { + // open user menu + await page.getByTestId("userMenuBtn").click(); + + // open license in new tab + await page.getByTestId("userMenuLicenseBtn").click(); + const newTabPromise = page.waitForEvent("popup"); + const newTab = await newTabPromise; + await newTab.waitForLoadState(); + + // close tab + await newTab.close(); + }); }); diff --git a/tests/e2e/utils/auto.js b/tests/e2e/utils/auto.js index 8c7a45e3d44..3a745adaccd 100644 --- a/tests/e2e/utils/auto.js +++ b/tests/e2e/utils/auto.js @@ -334,7 +334,7 @@ async function openNode(page, pos) { } const nodeId = children[pos]; - const childId = '[osparc-test-more="' + nodeId + '"]'; + const childId = '[osparc-test-key="' + nodeId + '"]'; await utils.waitAndClick(page, childId); return nodeId; diff --git a/tests/e2e/utils/utils.js b/tests/e2e/utils/utils.js index c2d976dad97..43226419615 100644 --- a/tests/e2e/utils/utils.js +++ b/tests/e2e/utils/utils.js @@ -231,7 +231,7 @@ async function getNodeTreeItemIDs(page) { const children = []; const nodeTreeItems = document.querySelectorAll(selector); nodeTreeItems.forEach(nodeTreeItem => { - const nodeId = nodeTreeItem.getAttribute("osparc-test-more") + const nodeId = nodeTreeItem.getAttribute("osparc-test-key") if (nodeId !== "root") { children.push(nodeId); }