[ACS-6954] Refactored search playwright tests (#3700)

* Refactored search playwright tests
This commit is contained in:
Katarzyna Kita
2024-03-12 10:15:17 +01:00
committed by GitHub
parent a9780b352d
commit f63d5073f4
6 changed files with 67 additions and 101 deletions

View File

@@ -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');
});

View File

@@ -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();
});

View File

@@ -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();
});