diff --git a/e2e/playwright/info-drawer/src/tests/comments.spec.ts b/e2e/playwright/info-drawer/src/tests/comments.spec.ts
index 098241a92..e198f612e 100755
--- a/e2e/playwright/info-drawer/src/tests/comments.spec.ts
+++ b/e2e/playwright/info-drawer/src/tests/comments.spec.ts
@@ -80,7 +80,7 @@ test.describe('Info Drawer - Comments', () => {
test('[C299209] from Favorites - Add a comment on a folder', async ({ favoritePage }) => {
const favoriteFolderName = `favoriteFolder-e2e-${Utils.random()}`;
- const folderFavId: string = (await nodesApi.createFolder(favoriteFolderName)).entry.id;
+ const folderFavId = (await nodesApi.createFolder(favoriteFolderName)).entry.id;
await favoritesActions.addFavoritesByIds('folder', [folderFavId]);
await fileActionsApi.waitForNodes(favoriteFolderName, { expect: 1 });
await favoritePage.navigate();
@@ -99,7 +99,7 @@ test.describe('Info Drawer - Comments', () => {
const sharedFileName = `sharedFile-e2e-${Utils.random()}`;
const e2eCommentFirst = `e2e-comment-${Utils.random()}`;
const e2eCommentSecond = `e2e-comment-${Utils.random()}`;
- const sharedFileId: string = (await nodesApi.createFile(sharedFileName)).entry.id;
+ const sharedFileId = (await nodesApi.createFile(sharedFileName)).entry.id;
await fileActionsApi.waitForNodes(sharedFileName, { expect: 1 });
await apiClientFactory.commentsApi.createComment(sharedFileId, { content: e2eCommentFirst });
await apiClientFactory.commentsApi.createComment(sharedFileId, { content: e2eCommentSecond });
@@ -135,7 +135,7 @@ test.describe('Info Drawer - Comments', () => {
test('[C299196] Comment info display - File from Favorites', async ({ favoritePage }) => {
const e2eCommentFirst = `e2e-comment-${Utils.random()}`;
const commentInfoFileName = `e2e-commentFile-${Utils.random()}`;
- const commentInfoFileId: string = (await nodesApi.createFile(commentInfoFileName)).entry.id;
+ const commentInfoFileId = (await nodesApi.createFile(commentInfoFileName)).entry.id;
await favoritesActions.addFavoritesByIds('file', [commentInfoFileId]);
await fileActionsApi.waitForNodes(commentInfoFileName, { expect: 1 });
await apiClientFactory.commentsApi.createComment(commentInfoFileId, { content: e2eCommentFirst });
diff --git a/e2e/playwright/info-drawer/src/tests/file-folder-properties.spec.ts b/e2e/playwright/info-drawer/src/tests/file-folder-properties.spec.ts
new file mode 100755
index 000000000..ea03d8eef
--- /dev/null
+++ b/e2e/playwright/info-drawer/src/tests/file-folder-properties.spec.ts
@@ -0,0 +1,97 @@
+/*!
+ * Copyright © 2005-2023 Hyland Software, Inc. and its affiliates. All rights reserved.
+ *
+ * Alfresco Example Content Application
+ *
+ * This file is part of the Alfresco Example Content Application.
+ * If the software was purchased under a paid Alfresco license, the terms of
+ * the paid license agreement will prevail. Otherwise, the software is
+ * provided under the following open source license terms:
+ *
+ * The Alfresco Example Content Application is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * The Alfresco Example Content Application 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 Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * from Hyland Software. If not, see .
+ */
+
+import { expect } from '@playwright/test';
+import { ApiClientFactory, Utils, test, TrashcanApi, NodesApi, FileActionsApi } from '@alfresco/playwright-shared';
+
+test.describe('Info Drawer - File Folder Properties', () => {
+ let nodesApi: NodesApi;
+ let trashcanApi: TrashcanApi;
+ let fileActionsApi: FileActionsApi;
+ const username = `user-e2e-${Utils.random()}`;
+
+ test.beforeAll(async () => {
+ try {
+ const apiClientFactory = new ApiClientFactory();
+ await apiClientFactory.setUpAcaBackend('admin');
+ await apiClientFactory.createUser({ username });
+ nodesApi = await NodesApi.initialize(username, username);
+ trashcanApi = await TrashcanApi.initialize(username, username);
+ fileActionsApi = await FileActionsApi.initialize(username, username);
+ } catch (error) {
+ console.error(`beforeAll failed : ${error}`);
+ }
+ });
+
+ test.afterAll(async () => {
+ try {
+ await nodesApi.deleteCurrentUserNodes();
+ await trashcanApi.emptyTrashcan();
+ } catch (error) {
+ console.error(`Main afterAll failed: ${error}`);
+ }
+ });
+
+ test.beforeEach(async ({ loginPage }) => {
+ try {
+ await loginPage.loginUser({ username, password: username }, { withNavigation: true, waitForLoading: true });
+ } catch (error) {
+ console.error(`Main beforeEach failed: ${error}`);
+ }
+ });
+
+ test('[C299162] View properties - Default tabs', async ({ personalFiles }) => {
+ const defaultTabsFolderName = `defaultTabsFolder-e2e-${Utils.random()}`;
+ await nodesApi.createFolder(defaultTabsFolderName);
+ await fileActionsApi.waitForNodes(defaultTabsFolderName, { expect: 1 });
+ await personalFiles.navigate();
+ await expect(personalFiles.dataTable.getRowByName(defaultTabsFolderName)).toBeVisible();
+ await personalFiles.dataTable.getRowByName(defaultTabsFolderName).click();
+ await personalFiles.acaHeader.viewDetails.click();
+
+ expect(await personalFiles.infoDrawer.getHeaderTitle()).toEqual(defaultTabsFolderName);
+ await expect(personalFiles.infoDrawer.propertiesTab).toBeVisible();
+ await expect(personalFiles.infoDrawer.commentsTab).toBeVisible();
+ expect(await personalFiles.infoDrawer.getTabsCount()).toEqual(2);
+ });
+
+ test('[C599174] View properties - Should be able to make the files/folders info drawer expandable as for Sites', async ({ personalFiles }) => {
+ const expandDetailsFolderName = `expandDetailsFolder-e2e-${Utils.random()}`;
+ await nodesApi.createFolder(expandDetailsFolderName);
+ await fileActionsApi.waitForNodes(expandDetailsFolderName, { expect: 1 });
+ await personalFiles.navigate();
+ await expect(personalFiles.dataTable.getRowByName(expandDetailsFolderName)).toBeVisible();
+ await personalFiles.dataTable.getRowByName(expandDetailsFolderName).click();
+ await personalFiles.acaHeader.viewDetails.click();
+
+ await personalFiles.infoDrawer.expandDetailsButton.click();
+ await expect(personalFiles.infoDrawer.expandedDetailsPermissionsTab).toBeVisible();
+
+ await personalFiles.navigate();
+ await expect(personalFiles.dataTable.getRowByName(expandDetailsFolderName)).toBeVisible();
+ await personalFiles.dataTable.getRowByName(expandDetailsFolderName).click({ button: 'right' });
+ await personalFiles.pagination.clickMenuItem('Permissions');
+ await expect(personalFiles.infoDrawer.expandedDetailsPermissionsTab).toBeVisible();
+ });
+});
diff --git a/e2e/playwright/list-views/exclude.tests.json b/e2e/playwright/list-views/exclude.tests.json
index 3fc985918..7489df278 100644
--- a/e2e/playwright/list-views/exclude.tests.json
+++ b/e2e/playwright/list-views/exclude.tests.json
@@ -18,5 +18,6 @@
"C213666": "https://alfresco.atlassian.net/browse/ACS-6688",
"C280490": "https://alfresco.atlassian.net/browse/ACS-6688",
"C280491": "https://alfresco.atlassian.net/browse/ACS-6688",
- "C213217": "https://alfresco.atlassian.net/browse/ACS-6710"
+ "C213217": "https://alfresco.atlassian.net/browse/ACS-6710",
+ "C213245": "https://alfresco.atlassian.net/browse/ACS-6717"
}
diff --git a/e2e/playwright/list-views/src/tests/sort-list.spec.ts b/e2e/playwright/list-views/src/tests/sort-list.spec.ts
index 66d58c99d..569d94e01 100644
--- a/e2e/playwright/list-views/src/tests/sort-list.spec.ts
+++ b/e2e/playwright/list-views/src/tests/sort-list.spec.ts
@@ -68,33 +68,37 @@ test.describe('Remember sorting', () => {
let nodeActionUser1: NodesApi;
test.beforeAll(async () => {
- test.setTimeout(timeouts.extendedTest);
- const apiClientFactory = new ApiClientFactory();
- await apiClientFactory.setUpAcaBackend('admin');
- await apiClientFactory.createUser({ username: user1 });
- await apiClientFactory.createUser({ username: user2 });
- const fileActionUser1 = await FileActionsApi.initialize(user1, user1);
- const fileActionUser2 = await FileActionsApi.initialize(user2, user2);
- const favoritesActions = await FavoritesPageApi.initialize(user1, user1);
- nodeActionUser1 = await NodesApi.initialize(user1, user1);
- const filesIdsUser1: { [key: string]: string } = {};
- const filesIdsUser2: { [key: string]: string } = {};
- await Promise.all(
- testData.user1.files.pdf.map(
- async (i) => (filesIdsUser1[i] = (await fileActionUser1.uploadFileWithRename(TEST_FILES.PDF.path, i, '-my-')).entry.id)
- )
- );
- await Promise.all(
- testData.user1.files.jpg.map(
- async (i) => (filesIdsUser1[i] = (await fileActionUser1.uploadFileWithRename(TEST_FILES.JPG_FILE.path, i, '-my-')).entry.id)
- )
- );
- await Promise.all(
- testData.user2.files.map(
- async (i) => (filesIdsUser2[i] = (await fileActionUser2.uploadFileWithRename(TEST_FILES.PDF.path, i, '-my-')).entry.id)
- )
- );
- await favoritesActions.addFavoritesByIds('file', [filesIdsUser1[pdfFileNames[0]], filesIdsUser1[pdfFileNames[1]]]);
+ try {
+ test.setTimeout(timeouts.extendedTest);
+ const apiClientFactory = new ApiClientFactory();
+ await apiClientFactory.setUpAcaBackend('admin');
+ await apiClientFactory.createUser({ username: user1 });
+ await apiClientFactory.createUser({ username: user2 });
+ const fileActionUser1 = await FileActionsApi.initialize(user1, user1);
+ const fileActionUser2 = await FileActionsApi.initialize(user2, user2);
+ const favoritesActions = await FavoritesPageApi.initialize(user1, user1);
+ nodeActionUser1 = await NodesApi.initialize(user1, user1);
+ const filesIdsUser1: { [key: string]: string } = {};
+ const filesIdsUser2: { [key: string]: string } = {};
+ await Promise.all(
+ testData.user1.files.pdf.map(
+ async (i) => (filesIdsUser1[i] = (await fileActionUser1.uploadFileWithRename(TEST_FILES.PDF.path, i, '-my-')).entry.id)
+ )
+ );
+ await Promise.all(
+ testData.user1.files.jpg.map(
+ async (i) => (filesIdsUser1[i] = (await fileActionUser1.uploadFileWithRename(TEST_FILES.JPG_FILE.path, i, '-my-')).entry.id)
+ )
+ );
+ await Promise.all(
+ testData.user2.files.map(
+ async (i) => (filesIdsUser2[i] = (await fileActionUser2.uploadFileWithRename(TEST_FILES.PDF.path, i, '-my-')).entry.id)
+ )
+ );
+ await favoritesActions.addFavoritesByIds('file', [filesIdsUser1[pdfFileNames[0]], filesIdsUser1[pdfFileNames[1]]]);
+ } catch (error) {
+ console.error(`beforeAll failed : ${error}`);
+ }
});
test.beforeEach(async ({ loginPage, personalFiles }) => {
diff --git a/e2e/playwright/list-views/src/tests/trash.spec.ts b/e2e/playwright/list-views/src/tests/trash.spec.ts
index 6c47c8fb1..4c32d2eea 100755
--- a/e2e/playwright/list-views/src/tests/trash.spec.ts
+++ b/e2e/playwright/list-views/src/tests/trash.spec.ts
@@ -66,8 +66,12 @@ test.describe('Trash', () => {
});
test.afterAll(async () => {
- await nodesApi.deleteCurrentUserNodes();
- await siteActionsAdmin.deleteSites([siteName]);
+ try {
+ await nodesApi.deleteCurrentUserNodes();
+ await siteActionsAdmin.deleteSites([siteName]);
+ } catch (error) {
+ console.error(`Main afterAll failed: ${error}`);
+ }
});
test.describe(`Regular user's personal files`, () => {
diff --git a/projects/aca-playwright-shared/src/page-objects/components/adf-info-drawer.component.ts b/projects/aca-playwright-shared/src/page-objects/components/adf-info-drawer.component.ts
index bd2c5d7e5..3edb4ce8d 100644
--- a/projects/aca-playwright-shared/src/page-objects/components/adf-info-drawer.component.ts
+++ b/projects/aca-playwright-shared/src/page-objects/components/adf-info-drawer.component.ts
@@ -36,8 +36,9 @@ export class AdfInfoDrawerComponent extends BaseComponent {
public getIdField = (labelText: string) => this.getChild('[data-automation-id="library-id-properties-wrapper"]', { hasText: labelText });
public getVisibilityField = (labelText: string) => this.getChild('[data-automation-id="library-visibility-properties-wrapper"]', { hasText: labelText });
public getDescriptionField = this.getChild('[data-automation-id="library-description-properties-wrapper"] textarea');
- public propertiesTab = this.getChild('.adf-info-drawer-tab').nth(0);
- public commentsTab = this.getChild('.adf-info-drawer-tab').nth(1);
+ public infoDrawerTabs = this.getChild('.adf-info-drawer-tab');
+ public propertiesTab = this.infoDrawerTabs.nth(0);
+ public commentsTab = this.infoDrawerTabs.nth(1);
public commentInputField = this.getChild('mat-form-field');
public commentsHeader = this.getChild('#comment-header');
public addCommentButton = this.getChild('[data-automation-id="comments-input-add"]');
@@ -45,6 +46,10 @@ export class AdfInfoDrawerComponent extends BaseComponent {
public commentUsername = this.getChild('.adf-comment-user-name');
public commentTextContent = this.getChild('.adf-comment-message');
public commentTimestamp = this.getChild('.adf-comment-message-time');
+ public headerTitle = this.getChild('.adf-info-drawer-layout-header-title div');
+ public expandDetailsButton = this.getChild(`button[title='Expand panel']`);
+ public expandedDetailsTabs = this.page.locator('.aca-details-container .mat-tab-label-content');
+ public expandedDetailsPermissionsTab = this.expandedDetailsTabs.getByText("Permissions");
async checkCommentsHeaderCount(): Promise {
@@ -67,4 +72,12 @@ export class AdfInfoDrawerComponent extends BaseComponent {
await this.page.keyboard.type(commentText);
await this.addCommentButton.click();
}
+
+ async getHeaderTitle(): Promise {
+ return this.headerTitle.textContent();
+ }
+
+ async getTabsCount(): Promise {
+ return this.infoDrawerTabs.count();
+ }
}
diff --git a/projects/aca-playwright-shared/src/utils/timeouts.ts b/projects/aca-playwright-shared/src/utils/timeouts.ts
index 5c75925a7..e2b130f24 100644
--- a/projects/aca-playwright-shared/src/utils/timeouts.ts
+++ b/projects/aca-playwright-shared/src/utils/timeouts.ts
@@ -31,7 +31,7 @@ export const timeouts = {
big: 7500,
large: 10000,
extraLarge: 20 * 1000,
- globalTest: 45 * 1000,
+ globalTest: 85 * 1000,
extendedTest: 150 * 1000,
extendedLongTest: 200 * 1000,
webServer: 240 * 1000,