mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-06-30 18:14:45 +00:00
parent
4536c43c9f
commit
3bf9cc1fb2
@ -33,14 +33,16 @@ export class ConfirmDialog extends Component {
|
||||
|
||||
title: '.mat-dialog-title',
|
||||
content: '.mat-dialog-content',
|
||||
delete: 'adf-confirm-accept',
|
||||
keep: 'adf-confirm-cancel'
|
||||
accept: 'adf-confirm-accept',
|
||||
cancel: 'adf-confirm-cancel',
|
||||
actionButton: 'adf-confirm'
|
||||
};
|
||||
|
||||
title: ElementFinder = this.component.element(by.css(ConfirmDialog.selectors.title));
|
||||
content: ElementFinder = this.component.element(by.css(ConfirmDialog.selectors.content));
|
||||
deleteButton: ElementFinder = this.component.element(by.id(ConfirmDialog.selectors.delete));
|
||||
keepButton: ElementFinder = this.component.element(by.id(ConfirmDialog.selectors.keep));
|
||||
acceptButton: ElementFinder = this.component.element(by.id(ConfirmDialog.selectors.accept));
|
||||
cancelButton: ElementFinder = this.component.element(by.id(ConfirmDialog.selectors.cancel));
|
||||
actionButton: ElementFinder = this.component.element(by.id(ConfirmDialog.selectors.actionButton));
|
||||
|
||||
constructor(ancestor?: ElementFinder) {
|
||||
super(ConfirmDialog.selectors.root, ancestor);
|
||||
@ -50,6 +52,14 @@ export class ConfirmDialog extends Component {
|
||||
await browser.wait(EC.stalenessOf(this.title), BROWSER_WAIT_TIMEOUT);
|
||||
}
|
||||
|
||||
async waitForDialogToOpen() {
|
||||
await browser.wait(EC.presenceOf(this.title), BROWSER_WAIT_TIMEOUT);
|
||||
}
|
||||
|
||||
async isDialogOpen() {
|
||||
return await browser.isElementPresent(by.css(ConfirmDialog.selectors.root));
|
||||
}
|
||||
|
||||
async getTitle() {
|
||||
return await this.title.getText();
|
||||
}
|
||||
@ -58,12 +68,17 @@ export class ConfirmDialog extends Component {
|
||||
return await this.content.getText();
|
||||
}
|
||||
|
||||
async clickDelete() {
|
||||
await this.deleteButton.click();
|
||||
getButtonByName(name: string) {
|
||||
return this.component.element(by.buttonText(name));
|
||||
}
|
||||
|
||||
async clickKeep() {
|
||||
await this.keepButton.click();
|
||||
await this.waitForDialogToClose();
|
||||
async clickButton(name: string) {
|
||||
const button = this.getButtonByName(name);
|
||||
await button.click();
|
||||
}
|
||||
|
||||
async isButtonEnabled(name: string) {
|
||||
const button = this.getButtonByName(name);
|
||||
return await button.isEnabled();
|
||||
}
|
||||
}
|
||||
|
@ -111,11 +111,16 @@ export class ShareDialog extends Component {
|
||||
return this.expireInput;
|
||||
}
|
||||
|
||||
async isShareToggleEnabled() {
|
||||
async isShareToggleChecked() {
|
||||
const toggleClass = await this.getShareToggle().getAttribute('class');
|
||||
return toggleClass.includes('checked');
|
||||
}
|
||||
|
||||
async isShareToggleEnabled() {
|
||||
const toggleClass = await this.getShareToggle().getAttribute('class');
|
||||
return toggleClass.includes('mat-disabled');
|
||||
}
|
||||
|
||||
async isExpireToggleEnabled() {
|
||||
const toggleClass = await this.getExpireToggle().getAttribute('class');
|
||||
return toggleClass.includes('checked');
|
||||
@ -143,4 +148,7 @@ export class ShareDialog extends Component {
|
||||
await this.expireToggle.click();
|
||||
}
|
||||
|
||||
async clickShareToggle() {
|
||||
await this.shareToggle.click();
|
||||
}
|
||||
}
|
||||
|
@ -105,7 +105,7 @@ export abstract class Page {
|
||||
}
|
||||
|
||||
async getSnackBarMessage() {
|
||||
// await this.waitForSnackBarToAppear();
|
||||
await this.waitForSnackBarToAppear();
|
||||
return await this.snackBar.getAttribute('innerText');
|
||||
}
|
||||
|
||||
|
@ -23,7 +23,6 @@
|
||||
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
import { browser, protractor } from 'protractor';
|
||||
import { LoginPage, LogoutPage, BrowsingPage } from '../../pages/pages';
|
||||
import { ConfirmDialog } from './../../components/components';
|
||||
import { SIDEBAR_LABELS } from '../../configs';
|
||||
@ -83,8 +82,9 @@ describe('Permanently delete from Trash', () => {
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.getButtonByTitleAttribute('Permanently delete').click();
|
||||
await trashPage.waitForDialog();
|
||||
await trashPage.getDialogActionByLabel('Delete').click();
|
||||
await trashPage.waitForDialogToClose();
|
||||
// await trashPage.getDialogActionByLabel('Delete').click();
|
||||
// await trashPage.waitForDialogToClose();
|
||||
await confirmDialog.clickButton('Delete');
|
||||
const text = await trashPage.getSnackBarMessage();
|
||||
|
||||
expect(text).toEqual(`${file1} deleted`);
|
||||
@ -95,8 +95,9 @@ describe('Permanently delete from Trash', () => {
|
||||
await dataTable.selectItem(folder1);
|
||||
await toolbar.getButtonByTitleAttribute('Permanently delete').click();
|
||||
await trashPage.waitForDialog();
|
||||
await trashPage.getDialogActionByLabel('Delete').click();
|
||||
await trashPage.waitForDialogToClose();
|
||||
// await trashPage.getDialogActionByLabel('Delete').click();
|
||||
// await trashPage.waitForDialogToClose();
|
||||
await confirmDialog.clickButton('Delete');
|
||||
const text = await trashPage.getSnackBarMessage();
|
||||
|
||||
expect(text).toEqual(`${folder1} deleted`);
|
||||
@ -107,8 +108,9 @@ describe('Permanently delete from Trash', () => {
|
||||
await dataTable.selectMultipleItems([ file2, folder2 ]);
|
||||
await toolbar.getButtonByTitleAttribute('Permanently delete').click();
|
||||
await trashPage.waitForDialog();
|
||||
await trashPage.getDialogActionByLabel('Delete').click();
|
||||
await trashPage.waitForDialogToClose();
|
||||
// await trashPage.getDialogActionByLabel('Delete').click();
|
||||
// await trashPage.waitForDialogToClose();
|
||||
await confirmDialog.clickButton('Delete');
|
||||
const text = await trashPage.getSnackBarMessage();
|
||||
|
||||
expect(text).toEqual(`2 items deleted`);
|
||||
@ -121,22 +123,23 @@ describe('Permanently delete from Trash', () => {
|
||||
await toolbar.getButtonByTitleAttribute('Permanently delete').click();
|
||||
await trashPage.waitForDialog();
|
||||
|
||||
expect(await confirmDialog.isDialogOpen()).toBe(true, 'Confirm delete dialog not open');
|
||||
expect(await confirmDialog.getTitle()).toContain('Delete from trash');
|
||||
expect(await confirmDialog.getText()).toContain('This will permanently remove the selected item(s)');
|
||||
expect(await confirmDialog.deleteButton.isEnabled()).toBe(true, 'DELETE button is not enabled');
|
||||
expect(await confirmDialog.keepButton.isEnabled()).toBe(true, 'KEEP button is not enabled');
|
||||
expect(await confirmDialog.isButtonEnabled('Delete')).toBe(true, 'DELETE button is not enabled');
|
||||
expect(await confirmDialog.isButtonEnabled('Keep')).toBe(true, 'KEEP button is not enabled');
|
||||
|
||||
await browser.actions().sendKeys(protractor.Key.ESCAPE).perform();
|
||||
await Utils.pressEscape();
|
||||
await dataTable.clearSelection();
|
||||
});
|
||||
|
||||
it('"Keep" action cancels the deletion - [C269115]', async () => {
|
||||
it('Keep action cancels the deletion - [C269115]', async () => {
|
||||
await dataTable.selectItem(file3);
|
||||
await toolbar.getButtonByTitleAttribute('Permanently delete').click();
|
||||
await trashPage.waitForDialog();
|
||||
|
||||
expect(await confirmDialog.keepButton.isEnabled()).toBe(true, 'KEEP button is not enabled');
|
||||
await confirmDialog.clickKeep();
|
||||
expect(await confirmDialog.isButtonEnabled('Keep')).toBe(true, 'KEEP button is not enabled');
|
||||
await confirmDialog.clickButton('Keep');
|
||||
expect(await dataTable.getRowByName(file3).isPresent()).toBe(true, 'Item was deleted');
|
||||
});
|
||||
});
|
||||
|
@ -70,15 +70,15 @@ describe('Share a file', () => {
|
||||
|
||||
describe('from Personal Files', () => {
|
||||
|
||||
const file1 = `file1PF-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2PF-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3PF-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4PF-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file5PF-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file6PF-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file7PF-${Utils.random()}.txt`; let file7Id;
|
||||
const file8 = `file8PF-${Utils.random()}.txt`; let file8Id;
|
||||
const file9 = `file9PF-${Utils.random()}.txt`; let file9Id;
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file5-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file6-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file7-${Utils.random()}.txt`; let file7Id;
|
||||
const file8 = `file8-${Utils.random()}.txt`; let file8Id;
|
||||
const file9 = `file9-${Utils.random()}.txt`; let file9Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentId)).entry.id;
|
||||
@ -134,7 +134,7 @@ describe('Share a file', () => {
|
||||
expect(await shareDialog.getLabels().get(0).getText()).toEqual('Link to share');
|
||||
expect(await shareDialog.getLinkUrl()).toContain('/preview/s/');
|
||||
expect(await shareDialog.isUrlReadOnly()).toBe('true', 'url is not readonly');
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.getLabels().get(1).getText()).toEqual('Expires on');
|
||||
expect(await shareDialog.isExpireToggleEnabled()).toBe(false, 'Expire toggle is checked');
|
||||
expect(await shareDialog.closeButton.isEnabled()).toBe(true, 'Close button is not enabled');
|
||||
@ -160,12 +160,10 @@ describe('Share a file', () => {
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await Utils.pressEscape();
|
||||
const sharedId = await apis.user.nodes.getNodeProperty(file3Id, 'qshare:sharedId');
|
||||
|
||||
expect(sharedId).not.toBe(undefined, `${file3} is not shared`);
|
||||
expect(await apis.user.nodes.isFileShared(file3Id)).toBe(true, `${file3} is not shared`);
|
||||
expect(url).toContain(sharedId);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await apis.user.shared.waitForApi({ expect: 5 });
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file3).isPresent()).toBe(true, `${file3} is not in the Shared files list`);
|
||||
});
|
||||
@ -266,28 +264,26 @@ describe('Share a file', () => {
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await Utils.pressEscape();
|
||||
const sharedId = await apis.user.nodes.getNodeProperty(file9Id, 'qshare:sharedId');
|
||||
|
||||
expect(sharedId).not.toBe(undefined, `${file9} is not shared`);
|
||||
expect(await apis.user.nodes.isFileShared(file9Id)).toBe(true, `${file9} is not shared`);
|
||||
expect(url).toContain(sharedId);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await apis.user.shared.waitForApi({ expect: 5 });
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file3).isPresent()).toBe(true, `${file3} is not in the Shared files list`);
|
||||
// expect(await dataTable.getRowByName(file9).isPresent()).toBe(true, `${file9} is not in the Shared files list`);
|
||||
});
|
||||
});
|
||||
|
||||
describe('from File Libraries', () => {
|
||||
|
||||
const file1 = `file1PF-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2PF-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file2PF-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file2PF-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file2PF-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file2PF-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file2PF-${Utils.random()}.txt`; let file7Id;
|
||||
const file8 = `file2PF-${Utils.random()}.txt`; let file8Id;
|
||||
const file9 = `file2PF-${Utils.random()}.txt`; let file9Id;
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file5-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file6-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file7-${Utils.random()}.txt`; let file7Id;
|
||||
const file8 = `file8-${Utils.random()}.txt`; let file8Id;
|
||||
const file9 = `file9-${Utils.random()}.txt`; let file9Id;
|
||||
|
||||
const siteName = `site-${Utils.random()}`;
|
||||
const parentInSite = `parent-site-${Utils.random()}`; let parentInSiteId;
|
||||
@ -344,7 +340,7 @@ describe('Share a file', () => {
|
||||
expect(await shareDialog.getLabels().get(0).getText()).toEqual('Link to share');
|
||||
expect(await shareDialog.getLinkUrl()).toContain('/preview/s/');
|
||||
expect(await shareDialog.isUrlReadOnly()).toBe('true', 'url is not readonly');
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.getLabels().get(1).getText()).toEqual('Expires on');
|
||||
expect(await shareDialog.isExpireToggleEnabled()).toBe(false, 'Expire toggle is checked');
|
||||
expect(await shareDialog.closeButton.isEnabled()).toBe(true, 'Close button is not enabled');
|
||||
@ -370,12 +366,10 @@ describe('Share a file', () => {
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await Utils.pressEscape();
|
||||
const sharedId = await apis.user.nodes.getNodeProperty(file3Id, 'qshare:sharedId');
|
||||
|
||||
expect(sharedId).not.toBe(undefined, `${file3} is not shared`);
|
||||
expect(await apis.user.nodes.isFileShared(file3Id)).toBe(true, `${file3} is not shared`);
|
||||
expect(url).toContain(sharedId);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await apis.user.shared.waitForApi({ expect: 5 });
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file3).isPresent()).toBe(true, `${file3} is not in the Shared files list`);
|
||||
});
|
||||
@ -476,12 +470,10 @@ describe('Share a file', () => {
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await Utils.pressEscape();
|
||||
const sharedId = await apis.user.nodes.getNodeProperty(file9Id, 'qshare:sharedId');
|
||||
|
||||
expect(sharedId).not.toBe(undefined, `${file9} is not shared`);
|
||||
expect(await apis.user.nodes.isFileShared(file9Id)).toBe(true, `${file9} is not shared`);
|
||||
expect(url).toContain(sharedId);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await apis.user.shared.waitForApi({ expect: 5 });
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file9).isPresent()).toBe(true, `${file9} is not in the Shared files list`);
|
||||
});
|
||||
@ -489,15 +481,15 @@ describe('Share a file', () => {
|
||||
|
||||
describe('from Recent Files', () => {
|
||||
|
||||
const file1 = `file1PF-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2PF-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file2PF-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file2PF-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file2PF-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file2PF-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file2PF-${Utils.random()}.txt`; let file7Id;
|
||||
const file8 = `file2PF-${Utils.random()}.txt`; let file8Id;
|
||||
const file9 = `file2PF-${Utils.random()}.txt`; let file9Id;
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file5-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file6-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file7-${Utils.random()}.txt`; let file7Id;
|
||||
const file8 = `file8-${Utils.random()}.txt`; let file8Id;
|
||||
const file9 = `file9-${Utils.random()}.txt`; let file9Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentId)).entry.id;
|
||||
@ -552,7 +544,7 @@ describe('Share a file', () => {
|
||||
expect(await shareDialog.getLabels().get(0).getText()).toEqual('Link to share');
|
||||
expect(await shareDialog.getLinkUrl()).toContain('/preview/s/');
|
||||
expect(await shareDialog.isUrlReadOnly()).toBe('true', 'url is not readonly');
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.getLabels().get(1).getText()).toEqual('Expires on');
|
||||
expect(await shareDialog.isExpireToggleEnabled()).toBe(false, 'Expire toggle is checked');
|
||||
expect(await shareDialog.closeButton.isEnabled()).toBe(true, 'Close button is not enabled');
|
||||
@ -578,12 +570,10 @@ describe('Share a file', () => {
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await Utils.pressEscape();
|
||||
const sharedId = await apis.user.nodes.getNodeProperty(file3Id, 'qshare:sharedId');
|
||||
|
||||
expect(sharedId).not.toBe(undefined, `${file3} is not shared`);
|
||||
expect(await apis.user.nodes.isFileShared(file3Id)).toBe(true, `${file3} is not shared`);
|
||||
expect(url).toContain(sharedId);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await apis.user.shared.waitForApi({ expect: 5 });
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file3).isPresent()).toBe(true, `${file3} is not in the Shared files list`);
|
||||
});
|
||||
@ -684,12 +674,10 @@ describe('Share a file', () => {
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await Utils.pressEscape();
|
||||
const sharedId = await apis.user.nodes.getNodeProperty(file9Id, 'qshare:sharedId');
|
||||
|
||||
expect(sharedId).not.toBe(undefined, `${file9} is not shared`);
|
||||
expect(await apis.user.nodes.isFileShared(file9Id)).toBe(true, `${file9} is not shared`);
|
||||
expect(url).toContain(sharedId);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await apis.user.shared.waitForApi({ expect: 5 });
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file9).isPresent()).toBe(true, `${file9} is not in the Shared files list`);
|
||||
});
|
||||
@ -697,13 +685,13 @@ describe('Share a file', () => {
|
||||
|
||||
describe('from Shared Files', () => {
|
||||
|
||||
const file1 = `file1PF-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2PF-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file2PF-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file2PF-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file2PF-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file2PF-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file2PF-${Utils.random()}.txt`; let file7Id;
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file5-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file6-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file7-${Utils.random()}.txt`; let file7Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentId)).entry.id;
|
||||
@ -760,7 +748,7 @@ describe('Share a file', () => {
|
||||
expect(await shareDialog.getLabels().get(0).getText()).toEqual('Link to share');
|
||||
expect(await shareDialog.getLinkUrl()).toContain('/preview/s/');
|
||||
expect(await shareDialog.isUrlReadOnly()).toBe('true', 'url is not readonly');
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.getLabels().get(1).getText()).toEqual('Expires on');
|
||||
expect(await shareDialog.isExpireToggleEnabled()).toBe(false, 'Expire toggle is checked');
|
||||
expect(await shareDialog.closeButton.isEnabled()).toBe(true, 'Close button is not enabled');
|
||||
@ -853,7 +841,7 @@ describe('Share a file', () => {
|
||||
expect(await shareDialog.getLabels().get(0).getText()).toEqual('Link to share');
|
||||
expect(await shareDialog.getLinkUrl()).toContain('/preview/s/');
|
||||
expect(await shareDialog.isUrlReadOnly()).toBe('true', 'url is not readonly');
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.getLabels().get(1).getText()).toEqual('Expires on');
|
||||
expect(await shareDialog.isExpireToggleEnabled()).toBe(false, 'Expire toggle is checked');
|
||||
expect(await shareDialog.closeButton.isEnabled()).toBe(true, 'Close button is not enabled');
|
||||
@ -861,17 +849,17 @@ describe('Share a file', () => {
|
||||
});
|
||||
|
||||
// TODO: enable when ACA-1886 is done
|
||||
xdescribe('from Favorites', () => {
|
||||
describe('from Favorites', () => {
|
||||
|
||||
const file1 = `file1PF-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2PF-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file2PF-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file2PF-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file2PF-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file2PF-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file2PF-${Utils.random()}.txt`; let file7Id;
|
||||
const file8 = `file2PF-${Utils.random()}.txt`; let file8Id;
|
||||
const file9 = `file2PF-${Utils.random()}.txt`; let file9Id;
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
const file5 = `file5-${Utils.random()}.txt`; let file5Id;
|
||||
const file6 = `file6-${Utils.random()}.txt`; let file6Id;
|
||||
const file7 = `file7-${Utils.random()}.txt`; let file7Id;
|
||||
const file8 = `file8-${Utils.random()}.txt`; let file8Id;
|
||||
const file9 = `file9-${Utils.random()}.txt`; let file9Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentId)).entry.id;
|
||||
@ -926,7 +914,7 @@ describe('Share a file', () => {
|
||||
done();
|
||||
});
|
||||
|
||||
xit('Share dialog default values - [C286666]', async () => {
|
||||
it('Share dialog default values - [C286666]', async () => {
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
@ -937,13 +925,13 @@ describe('Share a file', () => {
|
||||
expect(await shareDialog.getLabels().get(0).getText()).toEqual('Link to share');
|
||||
expect(await shareDialog.getLinkUrl()).toContain('/preview/s/');
|
||||
expect(await shareDialog.isUrlReadOnly()).toBe('true', 'url is not readonly');
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
expect(await shareDialog.getLabels().get(1).getText()).toEqual('Expires on');
|
||||
expect(await shareDialog.isExpireToggleEnabled()).toBe(false, 'Expire toggle is checked');
|
||||
expect(await shareDialog.closeButton.isEnabled()).toBe(true, 'Close button is not enabled');
|
||||
});
|
||||
|
||||
xit('Close dialog - [C286667]', async () => {
|
||||
it('Close dialog - [C286667]', async () => {
|
||||
await dataTable.selectItem(file2);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
@ -954,7 +942,7 @@ describe('Share a file', () => {
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog is open');
|
||||
});
|
||||
|
||||
xit('Share a file - [C286668]', async () => {
|
||||
it('Share a file - [C286668]', async () => {
|
||||
await dataTable.selectItem(file3);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
@ -963,17 +951,15 @@ describe('Share a file', () => {
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await Utils.pressEscape();
|
||||
const sharedId = await apis.user.nodes.getNodeProperty(file3Id, 'qshare:sharedId');
|
||||
|
||||
expect(sharedId).not.toBe(undefined, `${file3} is not shared`);
|
||||
expect(await apis.user.nodes.isFileShared(file3Id)).toBe(true, `${file3} is not shared`);
|
||||
expect(url).toContain(sharedId);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await apis.user.shared.waitForApi({ expect: 5 });
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file3).isPresent()).toBe(true, `${file3} is not in the Shared files list`);
|
||||
});
|
||||
|
||||
xit('Copy shared file URL - [C286669]', async () => {
|
||||
it('Copy shared file URL - [C286669]', async () => {
|
||||
await dataTable.selectItem(file4);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
@ -991,7 +977,7 @@ describe('Share a file', () => {
|
||||
await page.load();
|
||||
});
|
||||
|
||||
xit('Share a file with expiration date - [C286670]', async () => {
|
||||
it('Share a file with expiration date - [C286670]', async () => {
|
||||
await dataTable.selectItem(file5);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
@ -1013,10 +999,10 @@ describe('Share a file', () => {
|
||||
expect(Utils.formatDate(expireDateProperty)).toEqual(Utils.formatDate(inputDate));
|
||||
});
|
||||
|
||||
xit('Expire date is displayed correctly - [C286671]', async () => {
|
||||
it('Expire date is displayed correctly - [C286671]', async () => {
|
||||
await dataTable.selectItem(file6);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
const expireProperty = await apis.user.nodes.getNodeProperty(file6Id, 'qshare:expiryDate');
|
||||
@ -1025,10 +1011,10 @@ describe('Share a file', () => {
|
||||
expect(Utils.formatDate(await shareDialog.getExpireDate())).toEqual(Utils.formatDate(expiryDate));
|
||||
});
|
||||
|
||||
xit('Disable the share link expiration - [C286672]', async () => {
|
||||
it('Disable the share link expiration - [C286672]', async () => {
|
||||
await dataTable.selectItem(file7);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isExpireToggleEnabled()).toBe(true, 'Expiration is not checked');
|
||||
@ -1042,7 +1028,7 @@ describe('Share a file', () => {
|
||||
expect(await apis.user.nodes.getNodeProperty(file7Id, 'qshare:expiryDate')).toBe(undefined, `${file7} link still has expiration`);
|
||||
});
|
||||
|
||||
xit('Shared file URL is not changed when Share dialog is closed and opened again - [C286673]', async () => {
|
||||
it('Shared file URL is not changed when Share dialog is closed and opened again - [C286673]', async () => {
|
||||
await dataTable.selectItem(file8);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
@ -1054,14 +1040,14 @@ describe('Share a file', () => {
|
||||
await page.dataTable.clearSelection();
|
||||
await dataTable.selectItem(file8);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
const url2 = await shareDialog.getLinkUrl();
|
||||
|
||||
expect(url1).toEqual(url2);
|
||||
});
|
||||
|
||||
xit('Share a file from the context menu - [C286674]', async () => {
|
||||
it('Share a file from the context menu - [C286674]', async () => {
|
||||
await dataTable.rightClickOnItem(file9);
|
||||
await contextMenu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
@ -1069,12 +1055,10 @@ describe('Share a file', () => {
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await Utils.pressEscape();
|
||||
const sharedId = await apis.user.nodes.getNodeProperty(file9Id, 'qshare:sharedId');
|
||||
|
||||
expect(sharedId).not.toBe(undefined, `${file9} is not shared`);
|
||||
expect(await apis.user.nodes.isFileShared(file9Id)).toBe(true, `${file9} is not shared`);
|
||||
expect(url).toContain(sharedId);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await apis.user.shared.waitForApi({ expect: 5 });
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file9).isPresent()).toBe(true, `${file9} is not in the Shared files list`);
|
||||
});
|
||||
|
816
e2e/suites/actions/unshare-file.test.ts
Executable file
816
e2e/suites/actions/unshare-file.test.ts
Executable file
@ -0,0 +1,816 @@
|
||||
/*!
|
||||
* @license
|
||||
* Alfresco Example Content Application
|
||||
*
|
||||
* Copyright (C) 2005 - 2018 Alfresco Software Limited
|
||||
*
|
||||
* 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
|
||||
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
import { browser } from 'protractor';
|
||||
import { LoginPage, LogoutPage, BrowsingPage } from '../../pages/pages';
|
||||
import { SIDEBAR_LABELS, SITE_VISIBILITY, SITE_ROLES } from '../../configs';
|
||||
import { RepoClient } from '../../utilities/repo-client/repo-client';
|
||||
import { ShareDialog } from '../../components/dialog/share-dialog';
|
||||
import { ConfirmDialog } from '../../components/dialog/confirm-dialog';
|
||||
import { Viewer } from '../../components/viewer/viewer';
|
||||
import { Utils } from '../../utilities/utils';
|
||||
|
||||
describe('Unshare a file', () => {
|
||||
const username = `user-${Utils.random()}`;
|
||||
|
||||
const parent = `parent-${Utils.random()}`; let parentId;
|
||||
|
||||
const apis = {
|
||||
admin: new RepoClient(),
|
||||
user: new RepoClient(username, username)
|
||||
};
|
||||
|
||||
const loginPage = new LoginPage();
|
||||
const logoutPage = new LogoutPage();
|
||||
const page = new BrowsingPage();
|
||||
const { dataTable, toolbar } = page;
|
||||
const shareDialog = new ShareDialog();
|
||||
const confirmDialog = new ConfirmDialog();
|
||||
const contextMenu = dataTable.menu;
|
||||
const viewer = new Viewer();
|
||||
|
||||
beforeAll(async (done) => {
|
||||
await apis.admin.people.createUser({ username });
|
||||
parentId = (await apis.user.nodes.createFolder(parent)).entry.id;
|
||||
await loginPage.loginWith(username);
|
||||
done();
|
||||
});
|
||||
|
||||
afterAll(async (done) => {
|
||||
await Promise.all([
|
||||
apis.user.nodes.deleteNodeById(parentId),
|
||||
logoutPage.load()
|
||||
]);
|
||||
done();
|
||||
});
|
||||
|
||||
describe('from Personal Files', () => {
|
||||
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentId)).entry.id;
|
||||
file2Id = (await apis.user.nodes.createFile(file2, parentId)).entry.id;
|
||||
file3Id = (await apis.user.nodes.createFile(file3, parentId)).entry.id;
|
||||
file4Id = (await apis.user.nodes.createFile(file4, parentId)).entry.id;
|
||||
await apis.user.shared.shareFileById(file1Id);
|
||||
await apis.user.shared.shareFileById(file2Id);
|
||||
await apis.user.shared.shareFileById(file3Id);
|
||||
await apis.user.shared.shareFileById(file4Id);
|
||||
await apis.user.shared.waitForApi({ expect: 4 });
|
||||
done();
|
||||
});
|
||||
|
||||
beforeEach(async (done) => {
|
||||
await page.refresh();
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.PERSONAL_FILES);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.doubleClickOnRowByName(parent);
|
||||
await dataTable.waitForHeader();
|
||||
done();
|
||||
});
|
||||
|
||||
afterEach(async (done) => {
|
||||
await Utils.pressEscape();
|
||||
done();
|
||||
});
|
||||
|
||||
afterAll(async (done) => {
|
||||
await apis.user.nodes.deleteNodeById(file1Id);
|
||||
await apis.user.nodes.deleteNodeById(file2Id);
|
||||
await apis.user.nodes.deleteNodeById(file3Id);
|
||||
await apis.user.nodes.deleteNodeById(file4Id);
|
||||
await apis.user.shared.waitForApi({ expect: 0 });
|
||||
done();
|
||||
});
|
||||
|
||||
it('Unshare dialog UI - [C286339]', async () => {
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
expect(await confirmDialog.isDialogOpen()).toBe(true, 'Unshare dialog is not open');
|
||||
expect(await confirmDialog.getTitle()).toContain('Remove this shared link');
|
||||
expect(await confirmDialog.getText()).toContain('This link will be deleted and a new link will be created next time this file is shared');
|
||||
expect(await confirmDialog.isButtonEnabled('Remove')).toBe(true, 'REMOVE button is not enabled');
|
||||
expect(await confirmDialog.isButtonEnabled('Cancel')).toBe(true, 'CANCEL button is not enabled');
|
||||
});
|
||||
|
||||
it('Unshare a file - [C286340]', async () => {
|
||||
await dataTable.selectItem(file2);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file2Id)).toBe(false, `${file2} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file2).isPresent()).toBe(false, `${file2} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file2);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
|
||||
it('Cancel the Unshare action - [C286341]', async () => {
|
||||
await dataTable.selectItem(file3);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
const urlBefore = await shareDialog.getLinkUrl();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
await confirmDialog.clickButton('Cancel');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(true, 'Share dialog not open');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle is off');
|
||||
|
||||
const urlAfter = await shareDialog.getLinkUrl();
|
||||
expect(urlBefore).toEqual(urlAfter);
|
||||
});
|
||||
|
||||
it('Unshare a file from the context menu - [C286359]', async () => {
|
||||
await dataTable.rightClickOnItem(file4);
|
||||
await contextMenu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file4Id)).toBe(false, `${file4} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file4).isPresent()).toBe(false, `${file4} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file4);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
});
|
||||
|
||||
describe('from File Libraries', () => {
|
||||
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
|
||||
const siteName = `site-${Utils.random()}`;
|
||||
const parentInSite = `parent-site-${Utils.random()}`; let parentInSiteId;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
await apis.user.sites.createSite(siteName, SITE_VISIBILITY.PUBLIC);
|
||||
const docLibId = await apis.user.sites.getDocLibId(siteName);
|
||||
parentInSiteId = (await apis.user.nodes.createFolder(parentInSite, docLibId)).entry.id;
|
||||
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentInSiteId)).entry.id;
|
||||
file2Id = (await apis.user.nodes.createFile(file2, parentInSiteId)).entry.id;
|
||||
file3Id = (await apis.user.nodes.createFile(file3, parentInSiteId)).entry.id;
|
||||
file4Id = (await apis.user.nodes.createFile(file4, parentInSiteId)).entry.id;
|
||||
await apis.user.shared.shareFileById(file1Id);
|
||||
await apis.user.shared.shareFileById(file2Id);
|
||||
await apis.user.shared.shareFileById(file3Id);
|
||||
await apis.user.shared.shareFileById(file4Id);
|
||||
await apis.user.shared.waitForApi({ expect: 4 });
|
||||
done();
|
||||
});
|
||||
|
||||
beforeEach(async (done) => {
|
||||
await page.refresh();
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.FILE_LIBRARIES);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.doubleClickOnRowByName(siteName);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.doubleClickOnRowByName(parentInSite);
|
||||
await dataTable.waitForHeader();
|
||||
done();
|
||||
});
|
||||
|
||||
afterEach(async (done) => {
|
||||
await Utils.pressEscape();
|
||||
done();
|
||||
});
|
||||
|
||||
afterAll(async (done) => {
|
||||
await apis.admin.sites.deleteSite(siteName);
|
||||
await apis.user.shared.waitForApi({ expect: 0 });
|
||||
done();
|
||||
});
|
||||
|
||||
it('Unshare dialog UI - [C286679]', async () => {
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
expect(await confirmDialog.isDialogOpen()).toBe(true, 'Unshare dialog is not open');
|
||||
expect(await confirmDialog.getTitle()).toContain('Remove this shared link');
|
||||
expect(await confirmDialog.getText()).toContain('This link will be deleted and a new link will be created next time this file is shared');
|
||||
expect(await confirmDialog.isButtonEnabled('Remove')).toBe(true, 'REMOVE button is not enabled');
|
||||
expect(await confirmDialog.isButtonEnabled('Cancel')).toBe(true, 'CANCEL button is not enabled');
|
||||
});
|
||||
|
||||
it('Unshare a file - [C286680]', async () => {
|
||||
await dataTable.selectItem(file2);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file2Id)).toBe(false, `${file2} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file2).isPresent()).toBe(false, `${file2} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file2);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
|
||||
it('Cancel the Unshare action - [C286681]', async () => {
|
||||
await dataTable.selectItem(file3);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
const urlBefore = await shareDialog.getLinkUrl();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
await confirmDialog.clickButton('Cancel');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(true, 'Share dialog not open');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle is off');
|
||||
|
||||
const urlAfter = await shareDialog.getLinkUrl();
|
||||
expect(urlBefore).toEqual(urlAfter);
|
||||
});
|
||||
|
||||
it('Unshare a file from the context menu - [C286683]', async () => {
|
||||
await dataTable.rightClickOnItem(file4);
|
||||
await contextMenu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file4Id)).toBe(false, `${file4} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file4).isPresent()).toBe(false, `${file4} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file4);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
});
|
||||
|
||||
describe('from Recent Files', () => {
|
||||
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentId)).entry.id;
|
||||
file2Id = (await apis.user.nodes.createFile(file2, parentId)).entry.id;
|
||||
file3Id = (await apis.user.nodes.createFile(file3, parentId)).entry.id;
|
||||
file4Id = (await apis.user.nodes.createFile(file4, parentId)).entry.id;
|
||||
await apis.user.shared.shareFileById(file1Id);
|
||||
await apis.user.shared.shareFileById(file2Id);
|
||||
await apis.user.shared.shareFileById(file3Id);
|
||||
await apis.user.shared.shareFileById(file4Id);
|
||||
await apis.user.shared.waitForApi({ expect: 4 });
|
||||
done();
|
||||
});
|
||||
|
||||
beforeEach(async (done) => {
|
||||
await page.refresh();
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.RECENT_FILES);
|
||||
await dataTable.waitForHeader();
|
||||
done();
|
||||
});
|
||||
|
||||
afterEach(async (done) => {
|
||||
await Utils.pressEscape();
|
||||
done();
|
||||
});
|
||||
|
||||
afterAll(async (done) => {
|
||||
await apis.user.nodes.deleteNodeById(file1Id);
|
||||
await apis.user.nodes.deleteNodeById(file2Id);
|
||||
await apis.user.nodes.deleteNodeById(file3Id);
|
||||
await apis.user.nodes.deleteNodeById(file4Id);
|
||||
await apis.user.shared.waitForApi({ expect: 0 });
|
||||
done();
|
||||
});
|
||||
|
||||
it('Unshare dialog UI - [C286689]', async () => {
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
expect(await confirmDialog.isDialogOpen()).toBe(true, 'Unshare dialog is not open');
|
||||
expect(await confirmDialog.getTitle()).toContain('Remove this shared link');
|
||||
expect(await confirmDialog.getText()).toContain('This link will be deleted and a new link will be created next time this file is shared');
|
||||
expect(await confirmDialog.isButtonEnabled('Remove')).toBe(true, 'REMOVE button is not enabled');
|
||||
expect(await confirmDialog.isButtonEnabled('Cancel')).toBe(true, 'CANCEL button is not enabled');
|
||||
});
|
||||
|
||||
it('Unshare a file - [C286690]', async () => {
|
||||
await dataTable.selectItem(file2);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file2Id)).toBe(false, `${file2} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file2).isPresent()).toBe(false, `${file2} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file2);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
|
||||
it('Cancel the Unshare action - [C286691]', async () => {
|
||||
await dataTable.selectItem(file3);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
const urlBefore = await shareDialog.getLinkUrl();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
await confirmDialog.clickButton('Cancel');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(true, 'Share dialog not open');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle is off');
|
||||
|
||||
const urlAfter = await shareDialog.getLinkUrl();
|
||||
expect(urlBefore).toEqual(urlAfter);
|
||||
});
|
||||
|
||||
it('Unshare a file from the context menu - [C286693]', async () => {
|
||||
await dataTable.rightClickOnItem(file4);
|
||||
await contextMenu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file4Id)).toBe(false, `${file4} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file4).isPresent()).toBe(false, `${file4} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file4);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
});
|
||||
|
||||
describe('from Shared Files', () => {
|
||||
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentId)).entry.id;
|
||||
file2Id = (await apis.user.nodes.createFile(file2, parentId)).entry.id;
|
||||
file3Id = (await apis.user.nodes.createFile(file3, parentId)).entry.id;
|
||||
file4Id = (await apis.user.nodes.createFile(file4, parentId)).entry.id;
|
||||
await apis.user.shared.shareFileById(file1Id);
|
||||
await apis.user.shared.shareFileById(file2Id);
|
||||
await apis.user.shared.shareFileById(file3Id);
|
||||
await apis.user.shared.shareFileById(file4Id);
|
||||
await apis.user.shared.waitForApi({ expect: 4 });
|
||||
done();
|
||||
});
|
||||
|
||||
beforeEach(async (done) => {
|
||||
await page.refresh();
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
await dataTable.waitForHeader();
|
||||
done();
|
||||
});
|
||||
|
||||
afterEach(async (done) => {
|
||||
await Utils.pressEscape();
|
||||
done();
|
||||
});
|
||||
|
||||
afterAll(async (done) => {
|
||||
await apis.user.nodes.deleteNodeById(file1Id);
|
||||
await apis.user.nodes.deleteNodeById(file2Id);
|
||||
await apis.user.nodes.deleteNodeById(file3Id);
|
||||
await apis.user.nodes.deleteNodeById(file4Id);
|
||||
await apis.user.shared.waitForApi({ expect: 0 });
|
||||
done();
|
||||
});
|
||||
|
||||
it('Unshare dialog UI - [C286684]', async () => {
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
expect(await confirmDialog.isDialogOpen()).toBe(true, 'Unshare dialog is not open');
|
||||
expect(await confirmDialog.getTitle()).toContain('Remove this shared link');
|
||||
expect(await confirmDialog.getText()).toContain('This link will be deleted and a new link will be created next time this file is shared');
|
||||
expect(await confirmDialog.isButtonEnabled('Remove')).toBe(true, 'REMOVE button is not enabled');
|
||||
expect(await confirmDialog.isButtonEnabled('Cancel')).toBe(true, 'CANCEL button is not enabled');
|
||||
});
|
||||
|
||||
it('Unshare a file - [C286685]', async () => {
|
||||
await dataTable.selectItem(file2);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file2Id)).toBe(false, `${file2} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// expect(await dataTable.getRowByName(file2).isPresent()).toBe(false, `${file2} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file2);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
|
||||
it('Cancel the Unshare action - [C286686]', async () => {
|
||||
await dataTable.selectItem(file3);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
const urlBefore = await shareDialog.getLinkUrl();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
await confirmDialog.clickButton('Cancel');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(true, 'Share dialog not open');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle is off');
|
||||
|
||||
const urlAfter = await shareDialog.getLinkUrl();
|
||||
expect(urlBefore).toEqual(urlAfter);
|
||||
});
|
||||
|
||||
it('Unshare a file from the context menu - [C286688]', async () => {
|
||||
await dataTable.rightClickOnItem(file4);
|
||||
await contextMenu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file4Id)).toBe(false, `${file4} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// expect(await dataTable.getRowByName(file4).isPresent()).toBe(false, `${file4} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file4);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
});
|
||||
|
||||
describe('from Favorites', () => {
|
||||
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
const file3 = `file3-${Utils.random()}.txt`; let file3Id;
|
||||
const file4 = `file4-${Utils.random()}.txt`; let file4Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
file1Id = (await apis.user.nodes.createFile(file1, parentId)).entry.id;
|
||||
file2Id = (await apis.user.nodes.createFile(file2, parentId)).entry.id;
|
||||
file3Id = (await apis.user.nodes.createFile(file3, parentId)).entry.id;
|
||||
file4Id = (await apis.user.nodes.createFile(file4, parentId)).entry.id;
|
||||
await apis.user.shared.shareFileById(file1Id);
|
||||
await apis.user.shared.shareFileById(file2Id);
|
||||
await apis.user.shared.shareFileById(file3Id);
|
||||
await apis.user.shared.shareFileById(file4Id);
|
||||
|
||||
await apis.user.favorites.addFavoriteById('file', file1Id);
|
||||
await apis.user.favorites.addFavoriteById('file', file2Id);
|
||||
await apis.user.favorites.addFavoriteById('file', file3Id);
|
||||
await apis.user.favorites.addFavoriteById('file', file4Id);
|
||||
|
||||
await apis.user.favorites.waitForApi({ expect: 4 });
|
||||
await apis.user.shared.waitForApi({ expect: 4 });
|
||||
done();
|
||||
});
|
||||
|
||||
beforeEach(async (done) => {
|
||||
await page.refresh();
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.FAVORITES);
|
||||
await dataTable.waitForHeader();
|
||||
done();
|
||||
});
|
||||
|
||||
afterEach(async (done) => {
|
||||
await Utils.pressEscape();
|
||||
done();
|
||||
});
|
||||
|
||||
afterAll(async (done) => {
|
||||
await apis.user.nodes.deleteNodeById(file1Id);
|
||||
await apis.user.nodes.deleteNodeById(file2Id);
|
||||
await apis.user.nodes.deleteNodeById(file3Id);
|
||||
await apis.user.nodes.deleteNodeById(file4Id);
|
||||
await apis.user.shared.waitForApi({ expect: 0 });
|
||||
done();
|
||||
});
|
||||
|
||||
it('Unshare dialog UI - [C286694]', async () => {
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle not checked');
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
expect(await confirmDialog.isDialogOpen()).toBe(true, 'Unshare dialog is not open');
|
||||
expect(await confirmDialog.getTitle()).toContain('Remove this shared link');
|
||||
expect(await confirmDialog.getText()).toContain('This link will be deleted and a new link will be created next time this file is shared');
|
||||
expect(await confirmDialog.isButtonEnabled('Remove')).toBe(true, 'REMOVE button is not enabled');
|
||||
expect(await confirmDialog.isButtonEnabled('Cancel')).toBe(true, 'CANCEL button is not enabled');
|
||||
});
|
||||
|
||||
it('Unshare a file - [C286695]', async () => {
|
||||
await dataTable.selectItem(file2);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file2Id)).toBe(false, `${file2} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file2).isPresent()).toBe(false, `${file2} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file2);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
|
||||
it('Cancel the Unshare action - [C286696]', async () => {
|
||||
await dataTable.selectItem(file3);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
const urlBefore = await shareDialog.getLinkUrl();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
await confirmDialog.clickButton('Cancel');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(true, 'Share dialog not open');
|
||||
expect(await shareDialog.isShareToggleChecked()).toBe(true, 'Share toggle is off');
|
||||
|
||||
const urlAfter = await shareDialog.getLinkUrl();
|
||||
expect(urlBefore).toEqual(urlAfter);
|
||||
});
|
||||
|
||||
it('Unshare a file from the context menu - [C286698]', async () => {
|
||||
await dataTable.rightClickOnItem(file4);
|
||||
await contextMenu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
await shareDialog.clickShareToggle();
|
||||
|
||||
const url = await shareDialog.getLinkUrl();
|
||||
await confirmDialog.clickButton('Remove');
|
||||
await confirmDialog.waitForDialogToClose();
|
||||
expect(await shareDialog.isDialogOpen()).toBe(false, 'Share dialog open');
|
||||
expect(await apis.user.nodes.isFileShared(file4Id)).toBe(false, `${file4} is shared`);
|
||||
|
||||
// TODO: disable check cause api is slow to update
|
||||
// await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
// expect(await dataTable.getRowByName(file4).isPresent()).toBe(false, `${file4} is in the Shared files list`);
|
||||
|
||||
await browser.get(url);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'viewer is not open');
|
||||
expect(await viewer.getFileTitle()).not.toEqual(file4);
|
||||
|
||||
await page.load();
|
||||
});
|
||||
});
|
||||
|
||||
describe('as Consumer', () => {
|
||||
|
||||
const sitePrivate = `site-private-${Utils.random()}`;
|
||||
|
||||
const file1 = `file1-${Utils.random()}.txt`; let file1Id;
|
||||
const file2 = `file2-${Utils.random()}.txt`; let file2Id;
|
||||
|
||||
beforeAll(async (done) => {
|
||||
await apis.admin.sites.createSite(sitePrivate, SITE_VISIBILITY.PRIVATE);
|
||||
const docLibId = await apis.admin.sites.getDocLibId(sitePrivate);
|
||||
|
||||
file1Id = (await apis.admin.nodes.createFile(file1, docLibId)).entry.id;
|
||||
file2Id = (await apis.admin.nodes.createFile(file2, docLibId)).entry.id;
|
||||
|
||||
await apis.admin.sites.addSiteMember(sitePrivate, username, SITE_ROLES.SITE_CONSUMER);
|
||||
|
||||
await apis.admin.shared.shareFileById(file1Id);
|
||||
await apis.user.shared.shareFileById(file2Id);
|
||||
await apis.user.shared.waitForApi({ expect: 2 });
|
||||
|
||||
await apis.user.favorites.addFavoriteById('file', file1Id);
|
||||
await apis.user.favorites.addFavoriteById('file', file2Id);
|
||||
await apis.user.favorites.waitForApi({ expect: 2 });
|
||||
|
||||
done();
|
||||
});
|
||||
|
||||
afterAll(async (done) => {
|
||||
await apis.admin.sites.deleteSite(sitePrivate);
|
||||
done();
|
||||
});
|
||||
|
||||
beforeEach(async (done) => {
|
||||
await page.refresh();
|
||||
done();
|
||||
});
|
||||
|
||||
afterEach(async (done) => {
|
||||
await Utils.pressEscape();
|
||||
done();
|
||||
});
|
||||
|
||||
// TODO: ACA-1911
|
||||
xit('on File Libraries - file shared by other user - [C286682]', async () => {
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.FILE_LIBRARIES);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.doubleClickOnRowByName(sitePrivate);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(false, 'Share toggle enabled for consumer');
|
||||
});
|
||||
|
||||
it('on File Libraries - file shared by the user - [C286701]', async () => {
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.FILE_LIBRARIES);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.doubleClickOnRowByName(sitePrivate);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.selectItem(file2);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle disabled for consumer');
|
||||
});
|
||||
|
||||
// TODO: ACA-1911
|
||||
xit('on Shared Files - file shared by other user - [C286687]', async () => {
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(false, 'Share toggle enabled for consumer');
|
||||
});
|
||||
|
||||
it('on Shared Files - file shared by the user - [C286702]', async () => {
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.SHARED_FILES);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Shared link settings');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle disabled for consumer');
|
||||
});
|
||||
|
||||
// TODO: ACA-1911
|
||||
xit('on Favorites - file shared by other user - [C286697]', async () => {
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.FAVORITES);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(false, 'Share toggle enabled for consumer');
|
||||
});
|
||||
|
||||
it('on Favorites - file shared by the user - [C286703]', async () => {
|
||||
await page.sidenav.navigateToLinkByLabel(SIDEBAR_LABELS.FAVORITES);
|
||||
await dataTable.waitForHeader();
|
||||
await dataTable.selectItem(file1);
|
||||
await toolbar.openMoreMenu();
|
||||
await toolbar.menu.clickMenuItem('Share');
|
||||
await shareDialog.waitForDialogToOpen();
|
||||
|
||||
expect(await shareDialog.isShareToggleEnabled()).toBe(true, 'Share toggle disabled for consumer');
|
||||
});
|
||||
});
|
||||
|
||||
xit('');
|
||||
});
|
@ -55,7 +55,15 @@ export class NodesApi extends RepoApi {
|
||||
}
|
||||
|
||||
async getNodeProperty(nodeId: string, property: string) {
|
||||
return (await this.getNodeById(nodeId)).entry.properties[property];
|
||||
const node = await this.getNodeById(nodeId);
|
||||
if (node.entry.properties) {
|
||||
return node.entry.properties[property];
|
||||
}
|
||||
return '';
|
||||
}
|
||||
|
||||
async isFileShared(nodeId: string) {
|
||||
return (await this.getNodeProperty(nodeId, 'qshare:sharedId')) !== '';
|
||||
}
|
||||
|
||||
async deleteNodeById(id: string, permanent: boolean = true) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user