Files
alfresco-ng2-components/e2e/pages/adf/content-services/documentListPage.ts
gmandakini 4376d357ac [ADF-3962] sso download directive automated (#4452)
* sso download directive automated

* temp changes

* temp changes

* moving of services under lib testing and ADF-3962 automated

* removed the browser sleep

* cspell and linting fixes.

* codacy improvements

* export public-api update

* remove circular dep

* remove circular dep

* fixes

* fix user info test

* fix datatable

* random commit

* move other string

* fix lint

* fix lint

* fix prolem type

* fix failing test

* fix tag test

* fix problems after rebase

* fix lint

* remove space

* remove visibility method duplicated
2019-03-27 09:57:26 +00:00

92 lines
3.0 KiB
TypeScript

/*!
* @license
* Copyright 2019 Alfresco Software, Ltd.
*
* 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 { by, element, ElementFinder, browser } from 'protractor';
import { DataTableComponentPage } from '../dataTableComponentPage';
import { BrowserVisibility } from '@alfresco/adf-testing';
export class DocumentListPage {
rootElement: ElementFinder;
actionMenu = element(by.css('div[role="menu"]'));
optionButton = by.css('button[data-automation-id*="action_menu_"]');
tableBody;
dataTable;
constructor(rootElement: ElementFinder = element.all(by.css('adf-document-list')).first()) {
this.rootElement = rootElement;
this.dataTable = new DataTableComponentPage(this.rootElement);
this.tableBody = rootElement.all(by.css('div[class="adf-datatable-body"]')).first();
}
checkLockedIcon(content) {
const row = this.dataTable.getRow('Display name', content);
const lockIcon = row.element(by.cssContainingText('div[title="Lock"] mat-icon', 'lock'));
BrowserVisibility.waitUntilElementIsVisible(lockIcon);
return this;
}
checkUnlockedIcon(content) {
const row = this.dataTable.getRow('Display name', content);
const lockIcon = row.element(by.cssContainingText('div[title="Lock"] mat-icon', 'lock_open'));
BrowserVisibility.waitUntilElementIsVisible(lockIcon);
return this;
}
waitForTableBody() {
return BrowserVisibility.waitUntilElementIsVisible(this.tableBody);
}
getTooltip(nodeName) {
return this.dataTable.getTooltip('Display name', nodeName);
}
selectRow(nodeName) {
return this.dataTable.selectRow('Display name', nodeName);
}
rightClickOnRow(nodeName) {
return this.dataTable.rightClickOnRow('Display name', nodeName);
}
clickOnActionMenu(content) {
const row = this.dataTable.getRow('Display name', content);
row.element(this.optionButton).click();
BrowserVisibility.waitUntilElementIsVisible(this.actionMenu);
browser.sleep(500);
return this;
}
checkActionMenuIsNotDisplayed() {
BrowserVisibility.waitUntilElementIsNotVisible(this.actionMenu);
return this;
}
dataTablePage() {
return new DataTableComponentPage(this.rootElement);
}
getAllRowsColumnValues(column) {
return this.dataTable.getAllRowsColumnValues(column);
}
doubleClickRow(nodeName) {
this.dataTable.doubleClickRow('Display name', nodeName);
return this;
}
}