Skip to content

Commit

Permalink
[ACS-6235] Migrated E2Es in favorites.ts file to Playwright (#3539)
Browse files Browse the repository at this point in the history
* [ACS-6235] migrated e2es to playwright

* [ACS-6235] migrated e2es to playwright

* [ACS-6235] addressed review comments
  • Loading branch information
SheenaMalhotra182 authored Nov 28, 2023
1 parent fef55a3 commit 509ab55
Show file tree
Hide file tree
Showing 7 changed files with 133 additions and 141 deletions.
105 changes: 105 additions & 0 deletions e2e/playwright/pagination/src/tests/favorites.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,105 @@
/*!
* 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 <http://www.gnu.org/licenses/>.
*/

import { test } from '@alfresco/playwright-shared';
import { expect } from '@playwright/test';

export function favoritesTests(username: string) {
test.describe('Pagination controls : ', () => {
test.beforeEach(async ({ loginPage, favoritePage }) => {
await loginPage.navigate();
await loginPage.loginUser({ username: username, password: username });

await favoritePage.navigate();
await favoritePage.waitForPageLoad();
});

test('[C280113] Pagination control default values', async ({ favoritePage }) => {
expect(await favoritePage.pagination.getRange()).toContain('1-25 of 51');
expect(await favoritePage.pagination.getMaxItems()).toContain('25');
expect(await favoritePage.pagination.getCurrentPage()).toContain('Page 1');
expect(await favoritePage.pagination.getTotalPages()).toContain('of 3');
expect(await favoritePage.pagination.isPreviousEnabled()).toBe(false);
expect(await favoritePage.pagination.isNextEnabled()).toBe(true);
});

test('[C280114] Items per page values', async ({ favoritePage }) => {
await favoritePage.pagination.openMaxItemsMenu();
expect(await (await favoritePage.pagination.getNthItem(1)).innerText()).toBe('25');
expect(await (await favoritePage.pagination.getNthItem(2)).innerText()).toBe('50');
expect(await (await favoritePage.pagination.getNthItem(3)).innerText()).toBe('100');
await favoritePage.pagination.closeMenu();
});

test('[C280115] current page menu items', async ({ favoritePage }) => {
await favoritePage.pagination.openMaxItemsMenu();
await favoritePage.pagination.clickMenuItem('25');
expect(await favoritePage.pagination.getMaxItems()).toContain('25');
expect(await favoritePage.pagination.getTotalPages()).toContain('of 3');
expect(await favoritePage.pagination.getItemsCount()).toBe(3);
await favoritePage.pagination.closeMenu();

await favoritePage.pagination.openMaxItemsMenu();
await favoritePage.pagination.clickMenuItem('50');
expect(await favoritePage.pagination.getMaxItems()).toContain('50');
expect(await favoritePage.pagination.getTotalPages()).toContain('of 2');

await favoritePage.pagination.closeMenu();

await favoritePage.pagination.openMaxItemsMenu();
await favoritePage.pagination.clickMenuItem('100');
expect(await favoritePage.pagination.getMaxItems()).toContain('100');
expect(await favoritePage.pagination.getTotalPages()).toContain('of 1');

await favoritePage.pagination.resetToDefaultPageSize();
});

test('[C280116] change the current page from menu', async ({ favoritePage }) => {
await favoritePage.pagination.clickOnNextPage();
expect(await favoritePage.pagination.getRange()).toContain('Showing 26-50 of 51');
expect(await favoritePage.pagination.getCurrentPage()).toContain('Page 2');
expect(await favoritePage.pagination.isPreviousEnabled()).toBe(true);
expect(await favoritePage.pagination.isNextEnabled()).toBe(true);
await favoritePage.pagination.resetToDefaultPageSize();
});

test('[C280119] navigate to next and previous pages', async ({ favoritePage }) => {
await favoritePage.pagination.openMaxItemsMenu();
await favoritePage.pagination.clickMenuItem('25');
expect(await favoritePage.pagination.getMaxItems()).toContain('25');
await favoritePage.pagination.clickOnNextPage();
expect(await favoritePage.pagination.getRange()).toContain('Showing 26-50 of 51');

await favoritePage.pagination.clickOnPreviousPage();
expect(await favoritePage.pagination.getRange()).toContain('Showing 1-25 of 51');
});

test('[C280118] Next button is disabled on last page', async ({ favoritePage }) => {
await favoritePage.pagination.openMaxItemsMenu();
await favoritePage.pagination.clickNthItem(3);
expect(await favoritePage.pagination.getCurrentPage()).toContain('Page 1');
expect(await favoritePage.pagination.isNextEnabled()).toBe(false);
});
});
}
19 changes: 17 additions & 2 deletions e2e/playwright/pagination/src/tests/multiple-pages-files.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,29 +22,36 @@
* from Hyland Software. If not, see <http://www.gnu.org/licenses/>.
*/

import { ApiClientFactory, NodesApi, test, Utils } from '@alfresco/playwright-shared';
import { ApiClientFactory, FavoritesPageApi, NodesApi, test, timeouts, Utils } from '@alfresco/playwright-shared';
import { personalFilesTests } from './personal-files';
import { favoritesTests } from './favorites';

test.describe('Pagination on multiple pages : ', () => {
const random = Utils.random();
const username = `user-${random}`;

const parent = `parent-${random}`;
let parentId: string;
let initialFavoritesTotalItems: number;

const apiClientFactory = new ApiClientFactory();

test.beforeAll(async () => {
test.setTimeout(timeouts.extendedTest);
await apiClientFactory.setUpAcaBackend('admin');
await apiClientFactory.createUser({ username });
const nodesApi = await NodesApi.initialize(username, username);
const favoritesApi = await FavoritesPageApi.initialize(username, username);

const files = Array(51)
.fill('my-file')
.map((name, index): string => `${name}-${index + 1}-${random}.txt`);

parentId = (await nodesApi.createFolder(parent)).entry.id;
(await nodesApi.createFiles(files, parent)).list.entries.map((entries) => entries.entry.id);
const filesIds = (await nodesApi.createFiles(files, parent)).list.entries.map((entries) => entries.entry.id);
initialFavoritesTotalItems = await favoritesApi.getFavoritesTotalItems(username);

await favoritesApi.addFavoritesByIds('file', filesIds);
});

test.afterAll(async () => {
Expand All @@ -54,4 +61,12 @@ test.describe('Pagination on multiple pages : ', () => {
test.describe('on Personal Files', () => {
personalFilesTests(username, parent);
});

test.describe('on Favorites', () => {
test.beforeAll(async () => {
const favoritesApi = await FavoritesPageApi.initialize(username, username);
await favoritesApi.waitForApi(username, { expect: initialFavoritesTotalItems + 51 });
});
favoritesTests(username);
});
});
127 changes: 0 additions & 127 deletions e2e/protractor/suites/pagination/favorites.ts

This file was deleted.

10 changes: 0 additions & 10 deletions e2e/protractor/suites/pagination/multiple-pages-files.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ import { Utils, AdminActions, RepoClient } from '@alfresco/aca-testing-shared';
import { recentFilesTests } from './recent-files';
import { searchResultsTests } from './search-results';
import { sharedFilesTests } from './shared-files';
import { favoritesTests } from './favorites';

describe('Pagination on multiple pages : ', () => {
const random = Utils.random();
Expand All @@ -43,7 +42,6 @@ describe('Pagination on multiple pages : ', () => {
const userApi = new RepoClient(username, username);
const adminApiActions = new AdminActions();

let initialFavoritesTotalItems: number;
let initialSearchTotalItems: number;

beforeAll(async () => {
Expand All @@ -54,7 +52,6 @@ describe('Pagination on multiple pages : ', () => {
parentId = (await userApi.nodes.createFolder(parent)).entry.id;
filesIds = (await userApi.nodes.createFiles(files, parent)).list.entries.map((entries: any) => entries.entry.id);

initialFavoritesTotalItems = await userApi.favorites.getFavoritesTotalItems();
await userApi.shared.shareFilesByIds(filesIds);
await userApi.favorites.addFavoritesByIds('file', filesIds);
});
Expand Down Expand Up @@ -83,11 +80,4 @@ describe('Pagination on multiple pages : ', () => {
});
sharedFilesTests(username);
});

describe('on Favorites', () => {
beforeAll(async () => {
await userApi.favorites.waitForApi({ expect: initialFavoritesTotalItems + 51 });
});
favoritesTests(username);
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -162,4 +162,8 @@ export class PaginationComponent extends BaseComponent {
throw new Error(`Click nth menu item catch: ${e}`);
}
}

async closeMenu(): Promise<void> {
await this.page.keyboard.press('Escape');
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@

import { Page } from '@playwright/test';
import { BasePage } from './base.page';
import { DataTableComponent, MatMenuComponent, ViewerComponent, SidenavComponent } from '../components';
import { DataTableComponent, MatMenuComponent, ViewerComponent, SidenavComponent, PaginationComponent } from '../components';
import { AcaHeader } from '../components/aca-header.component';
import { AdfFolderDialogComponent, ViewerOverlayDialogComponent } from '../components/dialogs';

Expand All @@ -42,4 +42,9 @@ export class FavoritesPage extends BasePage {
public viewer = new ViewerComponent(this.page);
public viewerDialog = new ViewerOverlayDialogComponent(this.page);
public sidenav = new SidenavComponent(this.page);
public pagination = new PaginationComponent(this.page);

async waitForPageLoad() {
await this.page.waitForURL(`**/${FavoritesPage.pageUrl}`);
}
}
2 changes: 1 addition & 1 deletion projects/aca-playwright-shared/src/utils/timeouts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ export const timeouts = {
large: 10000,
extraLarge: 20 * 1000,
globalTest: 45 * 1000,
extendedTest: 120 * 1000,
extendedTest: 150 * 1000,
webServer: 240 * 1000,
globalSpec: 60 * 10 * 1000
};

0 comments on commit 509ab55

Please sign in to comment.