/*! * @license * Copyright © 2005-2024 Hyland Software, Inc. and its affiliates. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { createApiService, LocalStorageUtil, LoginPage, StringUtil, UploadActions, UserModel, UsersActions } from '@alfresco/adf-testing'; import { SearchResultsPage } from '../pages/search-results.page'; import { SearchFiltersPage } from '../pages/search-filters.page'; import { SearchBarPage } from '../pages/search-bar.page'; import { NavigationBarPage } from '../../core/pages/navigation-bar.page'; import { SearchConfiguration } from '../search.config'; import { browser } from 'protractor'; import { NodesApi } from '@alfresco/js-api'; describe('Search Checklist Component', () => { const loginPage = new LoginPage(); const searchFiltersPage = new SearchFiltersPage(); const searchBarPage = new SearchBarPage(); const searchResults = new SearchResultsPage(); const navigationBarPage = new NavigationBarPage(); const acsUser = new UserModel(); const apiService = createApiService(); const uploadActions = new UploadActions(apiService); const usersActions = new UsersActions(apiService); const nodesApi = new NodesApi(apiService.getInstance()); const filterType = { folder: 'Folder', document: 'Document', custom: 'TEST_NAME' }; const randomName = StringUtil.generateRandomString(); const nodeNames = { document: `${randomName}.txt`, folder: `${randomName}Folder` }; let createdFile; let createdFolder; beforeAll(async () => { await apiService.loginWithProfile('admin'); await usersActions.createUser(acsUser); await apiService.login(acsUser.username, acsUser.password); createdFolder = await nodesApi.createNode('-my-', { name: nodeNames.folder, nodeType: 'cm:folder' }); createdFile = await nodesApi.createNode('-my-', { name: nodeNames.document, nodeType: 'cm:content' }); await browser.sleep(browser.params.testConfig.timeouts.index_search); await loginPage.login(acsUser.username, acsUser.password); }); beforeEach(async () => { await navigationBarPage.navigateToContentServices(); await searchBarPage.checkSearchIconIsVisible(); await searchBarPage.clickOnSearchIcon(); await searchBarPage.enterTextAndPressEnter(randomName); await searchResults.dataTable.waitTillContentLoaded(); }); afterAll(async () => { await apiService.login(browser.params.testConfig.users.admin.username, browser.params.testConfig.users.admin.password); await uploadActions.deleteFileOrFolder(createdFile.entry.id); await uploadActions.deleteFileOrFolder(createdFolder.entry.id); await navigationBarPage.clickLogoutButton(); }); it('[C276991] Should be able to click between options and Clear All button', async () => { await searchFiltersPage.checkCheckListFilterIsDisplayed(); await searchFiltersPage.checkCheckListFilterIsCollapsed(); await searchFiltersPage.clickCheckListFilter(); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsDisplayed(filterType.folder); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsDisplayed(filterType.document); await searchFiltersPage.checkListFiltersPage().checkClearAllButtonIsDisplayed(); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsNotSelected(filterType.folder); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsNotSelected(filterType.document); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.folder); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsSelected(filterType.folder); await searchResults.dataTable.waitTillContentLoaded(); await searchResults.checkContentIsDisplayed(nodeNames.folder); await searchResults.checkContentIsNotDisplayed(nodeNames.document); await searchFiltersPage.checkListFiltersPage().clickClearAllButton(); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsNotSelected(filterType.folder); await searchResults.dataTable.waitTillContentLoaded(); await searchResults.checkContentIsDisplayed(nodeNames.folder); await searchResults.checkContentIsDisplayed(nodeNames.document); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.folder); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.document); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsSelected(filterType.folder); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsSelected(filterType.document); await searchResults.dataTable.waitTillContentLoaded(); await searchResults.checkContentIsDisplayed(nodeNames.folder); await searchResults.checkContentIsDisplayed(nodeNames.document); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.folder); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsSelected(filterType.document); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsNotSelected(filterType.folder); await searchResults.dataTable.waitTillContentLoaded(); await searchResults.checkContentIsDisplayed(nodeNames.document); await searchResults.checkContentIsNotDisplayed(nodeNames.folder); }); describe('configuration change', () => { let jsonFile; beforeEach(() => { jsonFile = SearchConfiguration.getConfiguration(); }); it('[C277143] Should be able to click show more/less button with pageSize set as default', async () => { await navigationBarPage.navigateToContentServices(); for (let numberOfOptions = 0; numberOfOptions < 8; numberOfOptions++) { jsonFile.categories[1].component.settings.options.push({ name: 'Folder', value: `TYPE:'cm:folder'` }); } await LocalStorageUtil.setConfigField('search', JSON.stringify(jsonFile)); await searchBarPage.clickOnSearchIcon(); await searchBarPage.checkSearchBarIsVisible(); await searchBarPage.enterTextAndPressEnter(randomName); await searchResults.dataTable.waitTillContentLoaded(); await searchFiltersPage.clickCheckListFilter(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(5); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsDisplayed(); await searchFiltersPage.checkListFiltersPage().checkShowLessButtonIsNotDisplayed(); await searchFiltersPage.checkListFiltersPage().clickShowMoreButton(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(10); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsNotDisplayed(); await searchFiltersPage.checkListFiltersPage().checkShowLessButtonIsDisplayed(); await searchFiltersPage.checkListFiltersPage().clickShowLessButton(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(5); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsDisplayed(); await searchFiltersPage.checkListFiltersPage().checkShowLessButtonIsNotDisplayed(); }); it('[C277144] Should be able to click show more/less button with pageSize set with a custom value', async () => { await navigationBarPage.navigateToContentServices(); jsonFile.categories[1].component.settings.pageSize = 10; for (let numberOfOptions = 0; numberOfOptions < 8; numberOfOptions++) { jsonFile.categories[1].component.settings.options.push({ name: 'Folder', value: `TYPE:'cm:folder'` }); } await LocalStorageUtil.setConfigField('search', JSON.stringify(jsonFile)); await searchBarPage.clickOnSearchIcon(); await searchBarPage.checkSearchBarIsVisible(); await searchBarPage.enterTextAndPressEnter(randomName); await searchResults.dataTable.waitTillContentLoaded(); await searchFiltersPage.clickCheckListFilter(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(10); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsNotDisplayed(); await navigationBarPage.navigateToContentServices(); jsonFile.categories[1].component.settings.pageSize = 11; await LocalStorageUtil.setConfigField('search', JSON.stringify(jsonFile)); await searchBarPage.clickOnSearchIcon(); await searchBarPage.checkSearchBarIsVisible(); await searchBarPage.enterTextAndPressEnter(randomName); await searchResults.dataTable.waitTillContentLoaded(); await searchFiltersPage.clickCheckListFilter(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(10); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsNotDisplayed(); await navigationBarPage.navigateToContentServices(); jsonFile.categories[1].component.settings.pageSize = 9; await LocalStorageUtil.setConfigField('search', JSON.stringify(jsonFile)); await searchBarPage.clickOnSearchIcon(); await searchBarPage.checkSearchBarIsVisible(); await searchBarPage.enterTextAndPressEnter(randomName); await searchFiltersPage.clickCheckListFilter(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(9); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsDisplayed(); }); it('[C277145] Should be able to click show more/less button with pageSize set to zero', async () => { await navigationBarPage.navigateToContentServices(); jsonFile.categories[1].component.settings.pageSize = 0; for (let numberOfOptions = 0; numberOfOptions < 8; numberOfOptions++) { jsonFile.categories[1].component.settings.options.push({ name: 'Folder', value: `TYPE:'cm:folder'` }); } await LocalStorageUtil.setConfigField('search', JSON.stringify(jsonFile)); await searchBarPage.clickOnSearchIcon(); await searchBarPage.checkSearchBarIsVisible(); await searchBarPage.enterTextAndPressEnter(randomName); await searchResults.dataTable.waitTillContentLoaded(); await searchResults.dataTable.waitTillContentLoaded(); await searchFiltersPage.clickCheckListFilter(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(5); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsDisplayed(); await searchFiltersPage.checkListFiltersPage().checkShowLessButtonIsNotDisplayed(); await searchFiltersPage.checkListFiltersPage().clickShowMoreButton(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(10); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsNotDisplayed(); await searchFiltersPage.checkListFiltersPage().checkShowLessButtonIsDisplayed(); await navigationBarPage.navigateToContentServices(); delete jsonFile.categories[1].component.settings.pageSize; await LocalStorageUtil.setConfigField('search', JSON.stringify(jsonFile)); await searchBarPage.clickOnSearchIcon(); await searchBarPage.checkSearchBarIsVisible(); await searchBarPage.enterTextAndPressEnter(randomName); await searchResults.dataTable.waitTillContentLoaded(); await searchFiltersPage.clickCheckListFilter(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(5); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsDisplayed(); await searchFiltersPage.checkListFiltersPage().checkShowLessButtonIsNotDisplayed(); await searchFiltersPage.checkListFiltersPage().clickShowMoreButton(); expect(await searchFiltersPage.checkListFiltersPage().getCheckListOptionsNumberOnPage()).toBe(10); await searchFiltersPage.checkListFiltersPage().checkShowMoreButtonIsNotDisplayed(); await searchFiltersPage.checkListFiltersPage().checkShowLessButtonIsDisplayed(); }); }); describe('Properties', () => { let jsonFile; beforeEach(async () => { jsonFile = SearchConfiguration.getConfiguration(); await navigationBarPage.navigateToContentServices(); }); it('[C277018] Should be able to change the operator', async () => { jsonFile.categories[1].component.settings.operator = 'AND'; await LocalStorageUtil.setConfigField('search', JSON.stringify(jsonFile)); await searchBarPage.clickOnSearchIcon(); await searchBarPage.checkSearchBarIsVisible(); await searchBarPage.enterTextAndPressEnter(randomName); await searchResults.dataTable.waitTillContentLoaded(); await searchFiltersPage.clickCheckListFilter(); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.folder); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsSelected(filterType.folder); await searchResults.dataTable.waitTillContentLoaded(); await searchResults.checkContentIsDisplayed(nodeNames.folder); await searchResults.checkContentIsNotDisplayed(nodeNames.document); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.document); await searchResults.checkContentIsNotDisplayed(nodeNames.folder); await searchResults.checkContentIsNotDisplayed(nodeNames.document); }); it('[C277019] Should be able to add new properties with different types', async () => { jsonFile.categories[1].component.settings.options.push({ name: filterType.custom, value: `TYPE:'cm:auditable'` }); await LocalStorageUtil.setConfigField('search', JSON.stringify(jsonFile)); await searchBarPage.clickOnSearchIcon(); await searchBarPage.checkSearchBarIsVisible(); await searchBarPage.enterTextAndPressEnter(randomName); await searchResults.dataTable.waitTillContentLoaded(); await searchFiltersPage.clickCheckListFilter(); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsDisplayed(filterType.folder); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsDisplayed(filterType.document); await searchFiltersPage.checkListFiltersPage().checkCheckListOptionIsDisplayed(filterType.custom); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.custom); await searchResults.checkContentIsNotDisplayed(nodeNames.folder); await searchResults.checkContentIsNotDisplayed(nodeNames.document); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.document); await searchFiltersPage.checkListFiltersPage().clickCheckListOption(filterType.folder); await searchResults.dataTable.waitTillContentLoaded(); await searchResults.checkContentIsDisplayed(nodeNames.folder); await searchResults.checkContentIsDisplayed(nodeNames.document); }); }); });