mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-07-24 17:31:52 +00:00
[ACS-6954] Refactored search playwright tests (#3700)
* Refactored search playwright tests
This commit is contained in:
@@ -56,11 +56,7 @@ test.describe('Search results - files and folders', () => {
|
||||
const fileRussian = `любимый-сайт-${random}`;
|
||||
|
||||
await nodesApi.createFile(fileRussian);
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkFilesAndFolders();
|
||||
await searchPage.searchInput.searchFor(fileRussian);
|
||||
await searchPage.dataTable.progressBarWaitForReload();
|
||||
await searchPage.searchWithin(fileRussian, 'filesAndFolders');
|
||||
await expect(searchPage.dataTable.getRowByName(fileRussian)).toBeVisible();
|
||||
});
|
||||
|
||||
@@ -70,11 +66,7 @@ test.describe('Search results - files and folders', () => {
|
||||
const fileDescription = 'file description';
|
||||
|
||||
await nodesApi.createFile(file, '-my-', fileTitle, fileDescription);
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkFilesAndFolders();
|
||||
await searchPage.searchInput.searchFor(file);
|
||||
await searchPage.dataTable.progressBarWaitForReload();
|
||||
await searchPage.searchWithin(file, 'files');
|
||||
await searchPage.dataTable.clickItemLocation(file);
|
||||
expect((await personalFiles.breadcrumb.items.textContent()).trim()).toEqual('Personal Files');
|
||||
});
|
||||
|
@@ -58,15 +58,11 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test.afterAll(async () => {
|
||||
await Utils.deleteNodesSitesEmptyTrashcan(nodesApi, trashcanApi, 'afterAll failed');
|
||||
await Utils.deleteNodesSitesEmptyTrashcan(nodesApi, trashcanApi, 'afterAll failed', sitesApi, [site]);
|
||||
});
|
||||
|
||||
test('[C290005] Only files are returned when Files option is the only one checked', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkOnlyFiles();
|
||||
await searchPage.searchInput.searchFor(`*${random}`);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(`*${random}`, 'files');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(file)).toBeTruthy();
|
||||
expect(await searchPage.dataTable.isItemPresent(folder)).toBeFalsy();
|
||||
@@ -74,11 +70,7 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290006] Only folders are returned when Folders option is the only one checked', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkOnlyFolders();
|
||||
await searchPage.searchInput.searchFor(`*${random}`);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(`*${random}`, 'folders');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(file)).toBeFalsy();
|
||||
expect(await searchPage.dataTable.isItemPresent(folder)).toBeTruthy();
|
||||
@@ -86,11 +78,7 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290007] Files and folders are returned when both Files and Folders options are checked', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkFilesAndFolders();
|
||||
await searchPage.searchInput.searchFor(`*${random}`);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(`*${random}`, 'filesAndFolders');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(file)).toBeTruthy();
|
||||
expect(await searchPage.dataTable.isItemPresent(folder)).toBeTruthy();
|
||||
@@ -98,11 +86,7 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290008] Only libraries are returned when Libraries option is checked', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(`*${random}`);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(`*${random}`, 'libraries');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(file)).toBeFalsy();
|
||||
expect(await searchPage.dataTable.isItemPresent(folder)).toBeFalsy();
|
||||
@@ -110,28 +94,21 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C279162] Results are updated automatically when changing the search term', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.searchFor(file);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(file, 'filesAndFolders');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(file)).toBeTruthy();
|
||||
expect(await searchPage.dataTable.isItemPresent(folder)).toBeFalsy();
|
||||
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.searchFor(folder);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.dataTable.progressBarWaitForReload();
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(file)).toBeFalsy();
|
||||
expect(await searchPage.dataTable.isItemPresent(folder)).toBeTruthy();
|
||||
});
|
||||
|
||||
test('[C279178] Results are returned when accessing an URL containing a search query', async ({ searchPage, personalFiles }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(site);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(site, 'libraries');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(site)).toBeTruthy();
|
||||
|
||||
@@ -139,7 +116,7 @@ test.describe('Search Results - General', () => {
|
||||
|
||||
await personalFiles.navigate();
|
||||
await personalFiles.page.goto(url);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.dataTable.progressBarWaitForReload();
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(site)).toBeTruthy();
|
||||
});
|
||||
|
@@ -85,7 +85,21 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test.afterAll(async () => {
|
||||
await Utils.deleteNodesSitesEmptyTrashcan(nodesApi, trashcanApi, 'afterAll failed');
|
||||
await Utils.deleteNodesSitesEmptyTrashcan(nodesApi, trashcanApi, 'afterAll failed', sitesApi, [
|
||||
site1.id,
|
||||
site2.id,
|
||||
site3.id,
|
||||
site4.id,
|
||||
userSiteModerated,
|
||||
userSitePrivate,
|
||||
userSitePublic,
|
||||
adminSite1,
|
||||
adminSite2,
|
||||
adminSite3,
|
||||
adminSite4,
|
||||
adminPrivate,
|
||||
siteRussian.id
|
||||
]);
|
||||
});
|
||||
|
||||
test.beforeAll(async () => {
|
||||
@@ -126,11 +140,7 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290012] Search library - full name match', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(site1.name);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(site1.name, 'libraries');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(site1.name)).toBeTruthy();
|
||||
expect(await searchPage.dataTable.isItemPresent(site2.name)).toBeFalsy();
|
||||
@@ -140,11 +150,7 @@ test.describe('Search Results - General', () => {
|
||||
|
||||
test('[C290013] Search library - partial name match', async ({ searchPage }) => {
|
||||
await fileActionsApi.waitForNodes(site3.id, { expect: 1 });
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(`lib-${random}`);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(`lib-${random}`, 'libraries');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(site1.name)).toBeTruthy();
|
||||
expect(await searchPage.dataTable.isItemPresent(site2.name)).toBeFalsy();
|
||||
@@ -153,11 +159,7 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290014] Search library - description match', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(site4.description);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(site4.description, 'libraries');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(site1.name)).toBeFalsy();
|
||||
expect(await searchPage.dataTable.isItemPresent(site2.name)).toBeFalsy();
|
||||
@@ -166,11 +168,7 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290016] Results page columns', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(site1.name);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(site1.name, 'libraries');
|
||||
|
||||
const expectedColumns = ['Name', 'Description', 'My Role', 'Visibility'];
|
||||
const actualColumns = await searchPage.dataTable.getColumnHeaders();
|
||||
@@ -179,11 +177,7 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290017] Library visibility is correctly displayed', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(`user-site-${random}`);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(`user-site-${random}`, 'libraries');
|
||||
|
||||
const expectedSitesVisibility = {
|
||||
[userSitePrivate]: SITE_VISIBILITY.PRIVATE,
|
||||
@@ -197,11 +191,7 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290018] User role is correctly displayed', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(`admin-${random}-site`);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(`admin-${random}-site`, 'libraries');
|
||||
|
||||
const expectedSitesRoles = {
|
||||
[adminSite1]: SITE_ROLES.SITE_CONSUMER.LABEL,
|
||||
@@ -216,21 +206,13 @@ test.describe('Search Results - General', () => {
|
||||
});
|
||||
|
||||
test('[C290019] Private sites are not displayed when user is not a member', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(`admin-${random}-site`);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(`admin-${random}-site`, 'libraries');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(adminPrivate)).toBeFalsy();
|
||||
});
|
||||
|
||||
test('[C290028] Search libraries with special characters', async ({ searchPage }) => {
|
||||
await searchPage.acaHeader.searchButton.click();
|
||||
await searchPage.searchInput.searchButton.click();
|
||||
await searchPage.searchInput.checkLibraries();
|
||||
await searchPage.searchInput.searchFor(siteRussian.name);
|
||||
await searchPage.dataTable.waitForTable();
|
||||
await searchPage.searchWithin(siteRussian.name, 'libraries');
|
||||
|
||||
expect(await searchPage.dataTable.isItemPresent(siteRussian.name)).toBeTruthy();
|
||||
});
|
||||
|
Reference in New Issue
Block a user