mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-07-24 17:31:52 +00:00
[ACS-6066] viewer special permissions playwright (#3453)
* [ACS-5923] sidenav and singleclick test * [ACS-5923] remove protractor test and fix flaky test * [ACS-5923] test fix * [ACS-5639] fix exclude test in viewer * [ACS-5923] remove exclude test and fix test * [ACS-6066] viewer special permissions playwright test * [ACS-6066] viewer protractor test remove * [ACS-6066] viewer failed test fix * [ACS-5923] review changes added * [ACS-5923] fix error in script
This commit is contained in:
@@ -0,0 +1,26 @@
|
||||
{
|
||||
"extends": "../../../.eslintrc.json",
|
||||
"ignorePatterns": [
|
||||
"!**/*"
|
||||
],
|
||||
"overrides": [
|
||||
{
|
||||
"files": [
|
||||
"*.ts"
|
||||
],
|
||||
"parserOptions": {
|
||||
"project": [
|
||||
"e2e/playwright/special-permissions-actions-available/tsconfig.e2e.json"
|
||||
],
|
||||
"createDefaultProgram": true
|
||||
},
|
||||
"plugins": [
|
||||
"rxjs",
|
||||
"unicorn"
|
||||
],
|
||||
"rules": {
|
||||
"@typescript-eslint/no-floating-promises": "off"
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
@@ -0,0 +1 @@
|
||||
{}
|
@@ -0,0 +1,44 @@
|
||||
/*!
|
||||
* Copyright © 2005-2023 Hyland Software, Inc. and its affiliates. All rights reserved.
|
||||
*
|
||||
* Alfresco Example Content Application
|
||||
*
|
||||
* 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
|
||||
* from Hyland Software. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
import { PlaywrightTestConfig } from '@playwright/test';
|
||||
import { CustomConfig, getGlobalConfig, getExcludedTestsRegExpArray } from '@alfresco/playwright-shared';
|
||||
import EXCLUDED_JSON from './exclude.tests.json';
|
||||
|
||||
const config: PlaywrightTestConfig<CustomConfig> = {
|
||||
...getGlobalConfig,
|
||||
|
||||
grepInvert: getExcludedTestsRegExpArray(EXCLUDED_JSON, 'special-permissions'),
|
||||
projects: [
|
||||
{
|
||||
name: 'special-permissions',
|
||||
testDir: './src/tests',
|
||||
use: {
|
||||
users: ['hruser', 'admin']
|
||||
}
|
||||
}
|
||||
]
|
||||
};
|
||||
|
||||
export default config;
|
@@ -0,0 +1,24 @@
|
||||
{
|
||||
"$schema": "../../../node_modules/nx/schemas/project-schema.json",
|
||||
"name": "special-permissions-e2e",
|
||||
"sourceRoot": "e2e/playwright/special-permissions-actions-available/src",
|
||||
"projectType": "application",
|
||||
"targets": {
|
||||
"e2e": {
|
||||
"executor": "nx:run-commands",
|
||||
"options": {
|
||||
"commands": [
|
||||
"npx playwright test --config=e2e/playwright/special-permissions-actions-available/playwright.config.ts"
|
||||
]
|
||||
},
|
||||
"configurations": {
|
||||
"production": {
|
||||
"devServerTarget": "content-ce:serve:production"
|
||||
}
|
||||
}
|
||||
},
|
||||
"lint": {
|
||||
"executor": "@angular-eslint/builder:lint"
|
||||
}
|
||||
}
|
||||
}
|
@@ -0,0 +1,190 @@
|
||||
/*!
|
||||
* Copyright © 2005-2023 Hyland Software, Inc. and its affiliates. All rights reserved.
|
||||
*
|
||||
* Alfresco Example Content Application
|
||||
*
|
||||
* 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
|
||||
* from Hyland Software. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
import * as testData from '@alfresco/playwright-shared';
|
||||
import { viewerTests } from './viewer';
|
||||
import {
|
||||
ApiClientFactory,
|
||||
FavoritesPageApi,
|
||||
FileActionsApi,
|
||||
TEST_FILES,
|
||||
NodesApi,
|
||||
SitesApi,
|
||||
test,
|
||||
SharedLinksApi,
|
||||
SearchPageApi
|
||||
} from '@alfresco/playwright-shared';
|
||||
import { Site } from '@alfresco/js-api';
|
||||
|
||||
test.describe('Special permissions : ', () => {
|
||||
const apiClientFactory = new ApiClientFactory();
|
||||
const random = testData.random;
|
||||
let docLibId: string;
|
||||
|
||||
const sitePrivate = `site-private-${random}`;
|
||||
|
||||
const userManager = `manager-${random}`;
|
||||
const userConsumer = `consumer-${random}`;
|
||||
const userCollaborator = `collaborator-${random}`;
|
||||
const userDemoted = `demoted-${random}`;
|
||||
|
||||
let fileDocxFavId: string;
|
||||
let fileFavId: string;
|
||||
let fileDocxSharedId: string;
|
||||
let fileDocxSharedFavId: string;
|
||||
let fileSharedId: string;
|
||||
let fileSharedFavId: string;
|
||||
let fileLockedId: string;
|
||||
let fileFavLockedId: string;
|
||||
let fileSharedLockedId: string;
|
||||
let fileSharedFavLockedId: string;
|
||||
let fileGranularPermissionId: string;
|
||||
let fileLockedByUserId: string;
|
||||
let folderFavId: string;
|
||||
let folderFav2Id: string;
|
||||
|
||||
let managerNodeActions: NodesApi;
|
||||
let demotedUserActions: NodesApi;
|
||||
let consumerFavoritesActions: FavoritesPageApi;
|
||||
let managerFavoritesActions: FavoritesPageApi;
|
||||
let collaboratorFavoritesActions: FavoritesPageApi;
|
||||
let demotedUserFavoritesActions: FavoritesPageApi;
|
||||
let managerUserShareActions: SharedLinksApi;
|
||||
let demotedUserShareActions: SharedLinksApi;
|
||||
let consumerShareActions: SharedLinksApi;
|
||||
let managerSiteActions: SitesApi;
|
||||
let managerFileActions: FileActionsApi;
|
||||
let managerSearchActions: SearchPageApi;
|
||||
|
||||
test.beforeAll(async () => {
|
||||
test.setTimeout(120000);
|
||||
await apiClientFactory.setUpAcaBackend('admin');
|
||||
await apiClientFactory.createUser({ username: userManager });
|
||||
await apiClientFactory.createUser({ username: userConsumer });
|
||||
await apiClientFactory.createUser({ username: userCollaborator });
|
||||
await apiClientFactory.createUser({ username: userDemoted });
|
||||
|
||||
managerNodeActions = await NodesApi.initialize(userManager, userManager);
|
||||
demotedUserActions = await NodesApi.initialize(userDemoted, userDemoted);
|
||||
consumerFavoritesActions = await FavoritesPageApi.initialize(userConsumer, userConsumer);
|
||||
collaboratorFavoritesActions = await FavoritesPageApi.initialize(userCollaborator, userCollaborator);
|
||||
demotedUserFavoritesActions = await FavoritesPageApi.initialize(userDemoted, userDemoted);
|
||||
managerFavoritesActions = await FavoritesPageApi.initialize(userManager, userManager);
|
||||
managerSearchActions = await SearchPageApi.initialize(userManager, userManager);
|
||||
managerSiteActions = await SitesApi.initialize(userManager, userManager);
|
||||
managerFileActions = await FileActionsApi.initialize(userManager, userManager);
|
||||
managerUserShareActions = await SharedLinksApi.initialize(userManager, userManager);
|
||||
demotedUserShareActions = await SharedLinksApi.initialize(userDemoted, userDemoted);
|
||||
consumerShareActions = await SharedLinksApi.initialize(userConsumer, userConsumer);
|
||||
|
||||
const consumerFavoritesTotalItems = await consumerFavoritesActions.getFavoritesTotalItems(userConsumer);
|
||||
const managerSearchTotalItems = await managerSearchActions.getTotalItems(userManager);
|
||||
const collaboratorFavoritesTotalItems = await collaboratorFavoritesActions.getFavoritesTotalItems(userCollaborator);
|
||||
|
||||
await managerSiteActions.createSite(sitePrivate, Site.VisibilityEnum.PRIVATE);
|
||||
docLibId = await managerSiteActions.getDocLibId(sitePrivate);
|
||||
await managerSiteActions.addSiteMember(sitePrivate, userConsumer, Site.RoleEnum.SiteConsumer);
|
||||
await managerSiteActions.addSiteMember(sitePrivate, userCollaborator, Site.RoleEnum.SiteCollaborator);
|
||||
await managerSiteActions.addSiteMember(sitePrivate, userDemoted, Site.RoleEnum.SiteManager);
|
||||
|
||||
await managerFileActions.uploadFileWithRename(TEST_FILES.DOCX.path, docLibId, testData.fileDocx.name);
|
||||
fileDocxFavId = (await managerFileActions.uploadFileWithRename(TEST_FILES.DOCX.path, docLibId, testData.fileDocxFav.name)).entry.id;
|
||||
await managerNodeActions.createFile(testData.file.name, docLibId);
|
||||
fileFavId = (await managerNodeActions.createFile(testData.fileFav.name, docLibId)).entry.id;
|
||||
fileDocxSharedId = (await managerFileActions.uploadFileWithRename(TEST_FILES.DOCX.path, docLibId, testData.fileDocxShared.name)).entry.id;
|
||||
fileDocxSharedFavId = (await managerFileActions.uploadFileWithRename(TEST_FILES.DOCX.path, docLibId, testData.fileDocxSharedFav.name)).entry.id;
|
||||
fileSharedId = (await managerNodeActions.createFile(testData.fileShared.name, docLibId)).entry.id;
|
||||
fileSharedFavId = (await managerNodeActions.createFile(testData.fileSharedFav.name, docLibId)).entry.id;
|
||||
fileLockedId = (await managerNodeActions.createFile(testData.fileLocked.name, docLibId)).entry.id;
|
||||
fileFavLockedId = (await managerNodeActions.createFile(testData.fileFavLocked.name, docLibId)).entry.id;
|
||||
fileSharedLockedId = (await managerNodeActions.createFile(testData.fileSharedLocked.name, docLibId)).entry.id;
|
||||
fileSharedFavLockedId = (await managerNodeActions.createFile(testData.fileSharedFavLocked.name, docLibId)).entry.id;
|
||||
fileGranularPermissionId = (await managerNodeActions.createFile(testData.fileGranularPermission, docLibId)).entry.id;
|
||||
|
||||
fileLockedByUserId = (await managerNodeActions.createFile(testData.fileLockedByUser, docLibId)).entry.id;
|
||||
await demotedUserActions.lockNodes([fileLockedByUserId]);
|
||||
await demotedUserFavoritesActions.addFavoriteById('file', fileLockedByUserId);
|
||||
await demotedUserShareActions.shareFileById(fileLockedByUserId);
|
||||
await managerSiteActions.updateSiteMember(sitePrivate, userDemoted, Site.RoleEnum.SiteConsumer);
|
||||
|
||||
await managerNodeActions.createFolder(testData.folder.name, docLibId);
|
||||
folderFavId = (await managerNodeActions.createFolder(testData.folderFav.name, docLibId)).entry.id;
|
||||
folderFav2Id = (await managerNodeActions.createFolder(testData.folderFav2.name, docLibId)).entry.id;
|
||||
await consumerFavoritesActions.addFavoritesByIds('folder', [folderFavId, folderFav2Id]);
|
||||
|
||||
await consumerFavoritesActions.addFavoritesByIds('file', [
|
||||
fileDocxFavId,
|
||||
fileFavId,
|
||||
fileDocxSharedFavId,
|
||||
fileSharedFavId,
|
||||
fileFavLockedId,
|
||||
fileSharedFavLockedId,
|
||||
fileGranularPermissionId
|
||||
]);
|
||||
|
||||
await consumerShareActions.shareFilesByIds([
|
||||
fileDocxSharedId,
|
||||
fileDocxSharedFavId,
|
||||
fileSharedId,
|
||||
fileSharedFavId,
|
||||
fileSharedLockedId,
|
||||
fileSharedFavLockedId,
|
||||
fileGranularPermissionId
|
||||
]);
|
||||
|
||||
await collaboratorFavoritesActions.addFavoritesByIds('file', [fileDocxSharedFavId, fileSharedFavId]);
|
||||
|
||||
await managerNodeActions.lockNodes([fileLockedId, fileFavLockedId, fileSharedLockedId, fileSharedFavLockedId]);
|
||||
|
||||
await managerNodeActions.setGranularPermission(fileGranularPermissionId, false, userConsumer, Site.RoleEnum.SiteManager);
|
||||
|
||||
await managerFavoritesActions.addFavoriteById('file', fileLockedByUserId);
|
||||
|
||||
await Promise.all([
|
||||
consumerFavoritesActions.waitForApi(userConsumer, { expect: consumerFavoritesTotalItems + 9 }),
|
||||
managerUserShareActions.waitForFilesToBeShared([
|
||||
fileDocxSharedId,
|
||||
fileDocxSharedFavId,
|
||||
fileSharedId,
|
||||
fileSharedFavId,
|
||||
fileSharedLockedId,
|
||||
fileSharedFavLockedId,
|
||||
fileGranularPermissionId,
|
||||
fileLockedByUserId
|
||||
]),
|
||||
managerSearchActions.waitForApi(userManager, { expect: managerSearchTotalItems + 14 }),
|
||||
collaboratorFavoritesActions.waitForApi(userCollaborator, { expect: collaboratorFavoritesTotalItems + 2 })
|
||||
]);
|
||||
});
|
||||
|
||||
test.afterAll(async () => {
|
||||
await managerSiteActions.deleteSites([sitePrivate]);
|
||||
});
|
||||
|
||||
test.describe('Consumer', () => {
|
||||
test.describe('on Viewer', () => {
|
||||
viewerTests(userConsumer, sitePrivate);
|
||||
});
|
||||
});
|
||||
});
|
@@ -0,0 +1,456 @@
|
||||
/*!
|
||||
* Copyright © 2005-2023 Hyland Software, Inc. and its affiliates. All rights reserved.
|
||||
*
|
||||
* Alfresco Example Content Application
|
||||
*
|
||||
* 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
|
||||
* from Hyland Software. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
import { expect } from '@playwright/test';
|
||||
import { FavoritesPage, LoginPage, MyLibrariesPage, SearchPage, SharedPage, test } from '@alfresco/playwright-shared';
|
||||
import * as testData from '@alfresco/playwright-shared';
|
||||
|
||||
export function viewerTests(userConsumer: string, siteName: string) {
|
||||
test.describe('Consumer available actions : ', () => {
|
||||
test.describe('file opened from File Libraries', () => {
|
||||
async function checkViewerActions(
|
||||
loginPage: LoginPage,
|
||||
myLibrariesPage: MyLibrariesPage,
|
||||
item: string,
|
||||
expectedToolbarPrimary: string[],
|
||||
expectedToolbarMore: string[]
|
||||
): Promise<void> {
|
||||
await loginPage.navigate();
|
||||
await loginPage.loginUser({ username: userConsumer, password: userConsumer });
|
||||
await myLibrariesPage.navigate();
|
||||
await myLibrariesPage.dataTable.performClickFolderOrFileToOpen(siteName);
|
||||
await myLibrariesPage.dataTable.performClickFolderOrFileToOpen(item);
|
||||
expect(await myLibrariesPage.viewer.isViewerOpened(), 'Viewer is not opened').toBe(true);
|
||||
await myLibrariesPage.viewer.verifyViewerPrimaryActions(expectedToolbarPrimary);
|
||||
await myLibrariesPage.acaHeader.clickViewerMoreActions();
|
||||
await myLibrariesPage.matMenu.verifyActualMoreActions(expectedToolbarMore);
|
||||
}
|
||||
|
||||
test('File Office - [C326622]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileDocx.name,
|
||||
testData.fileDocx.viewerToolbarPrimary,
|
||||
testData.fileDocx.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File Office, favorite - [C326623]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileDocxFav.name,
|
||||
testData.fileDocxFav.viewerToolbarPrimary,
|
||||
testData.fileDocxFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File simple - [C326624]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(loginPage, myLibrariesPage, testData.file.name, testData.file.viewerToolbarPrimary, testData.file.viewerToolbarMore);
|
||||
});
|
||||
|
||||
test('File favorite - [C326625]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileFav.name,
|
||||
testData.fileFav.viewerToolbarPrimary,
|
||||
testData.fileFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File Office, shared - [C326637]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileDocxShared.name,
|
||||
testData.fileDocxShared.viewerToolbarPrimary,
|
||||
testData.fileDocxShared.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File Office, shared, favorite - [C326638]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileDocxSharedFav.name,
|
||||
testData.fileDocxSharedFav.viewerToolbarPrimary,
|
||||
testData.fileDocxSharedFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared - [C326648]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileShared.name,
|
||||
testData.fileShared.viewerToolbarPrimary,
|
||||
testData.fileShared.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, favorite - [C326649]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileSharedFav.name,
|
||||
testData.fileSharedFav.viewerToolbarPrimary,
|
||||
testData.fileSharedFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File locked - [C326630]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileLocked.name,
|
||||
testData.fileLocked.viewerToolbarPrimary,
|
||||
testData.fileLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File favorite, locked - [C326633]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileFavLocked.name,
|
||||
testData.fileFavLocked.viewerToolbarPrimary,
|
||||
testData.fileFavLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, locked - [C326650]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileSharedLocked.name,
|
||||
testData.fileSharedLocked.viewerToolbarPrimary,
|
||||
testData.fileSharedLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, favorite, locked - [C326651]', async ({ loginPage, myLibrariesPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
myLibrariesPage,
|
||||
testData.fileSharedFavLocked.name,
|
||||
testData.fileSharedFavLocked.viewerToolbarPrimary,
|
||||
testData.fileSharedFavLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
test.describe('file opened from Favorites', () => {
|
||||
async function checkViewerActions(
|
||||
loginPage: LoginPage,
|
||||
favoritePage: FavoritesPage,
|
||||
item: string,
|
||||
expectedToolbarPrimary: string[],
|
||||
expectedToolbarMore: string[]
|
||||
): Promise<void> {
|
||||
await loginPage.navigate();
|
||||
await loginPage.loginUser({ username: userConsumer, password: userConsumer });
|
||||
await favoritePage.navigate();
|
||||
await favoritePage.dataTable.performClickFolderOrFileToOpen(item);
|
||||
expect(await favoritePage.viewer.isViewerOpened(), 'Viewer is not opened').toBe(true);
|
||||
await favoritePage.viewer.verifyViewerPrimaryActions(expectedToolbarPrimary);
|
||||
await favoritePage.acaHeader.clickViewerMoreActions();
|
||||
await favoritePage.matMenu.verifyActualMoreActions(expectedToolbarMore);
|
||||
}
|
||||
|
||||
test('File Office, favorite - [C326652]', async ({ loginPage, favoritePage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
favoritePage,
|
||||
testData.fileDocxFav.name,
|
||||
testData.fileDocxFav.viewerToolbarPrimary,
|
||||
testData.fileDocxFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File favorite - [C326653]', async ({ loginPage, favoritePage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
favoritePage,
|
||||
testData.fileFav.name,
|
||||
testData.fileFav.viewerToolbarPrimary,
|
||||
testData.fileFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File Office, shared, favorite - [C326655]', async ({ loginPage, favoritePage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
favoritePage,
|
||||
testData.fileDocxSharedFav.name,
|
||||
testData.fileDocxSharedFav.viewerToolbarPrimary,
|
||||
testData.fileDocxSharedFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, favorite - [C326656]', async ({ loginPage, favoritePage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
favoritePage,
|
||||
testData.fileSharedFav.name,
|
||||
testData.fileSharedFav.viewerToolbarPrimary,
|
||||
testData.fileSharedFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File favorite, locked - [C326654]', async ({ loginPage, favoritePage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
favoritePage,
|
||||
testData.fileFavLocked.name,
|
||||
testData.fileFavLocked.viewerToolbarPrimary,
|
||||
testData.fileFavLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, favorite, locked - [C326657]', async ({ loginPage, favoritePage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
favoritePage,
|
||||
testData.fileSharedFavLocked.name,
|
||||
testData.fileSharedFavLocked.viewerToolbarPrimary,
|
||||
testData.fileSharedFavLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
test.describe('file opened from Shared Files', () => {
|
||||
async function checkViewerActions(
|
||||
loginPage: LoginPage,
|
||||
sharedPage: SharedPage,
|
||||
item: string,
|
||||
expectedToolbarPrimary: string[],
|
||||
expectedToolbarMore: string[]
|
||||
): Promise<void> {
|
||||
await loginPage.navigate();
|
||||
await loginPage.loginUser({ username: userConsumer, password: userConsumer });
|
||||
await sharedPage.navigate();
|
||||
await sharedPage.dataTable.performClickFolderOrFileToOpen(item);
|
||||
expect(await sharedPage.viewer.isViewerOpened(), 'Viewer is not opened').toBe(true);
|
||||
await sharedPage.viewer.verifyViewerPrimaryActions(expectedToolbarPrimary);
|
||||
await sharedPage.acaHeader.clickViewerMoreActions();
|
||||
await sharedPage.matMenu.verifyActualMoreActions(expectedToolbarMore);
|
||||
}
|
||||
|
||||
test('File Office, shared - [C326658]', async ({ loginPage, sharedPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
sharedPage,
|
||||
testData.fileDocxShared.name,
|
||||
testData.fileDocxShared.viewerToolbarPrimary,
|
||||
testData.fileDocxShared.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File Office, shared, favorite - [C326659]', async ({ loginPage, sharedPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
sharedPage,
|
||||
testData.fileDocxSharedFav.name,
|
||||
testData.fileDocxSharedFav.viewerToolbarPrimary,
|
||||
testData.fileDocxSharedFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared - [C326660]', async ({ loginPage, sharedPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
sharedPage,
|
||||
testData.fileShared.name,
|
||||
testData.fileShared.viewerToolbarPrimary,
|
||||
testData.fileShared.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, favorite - [C326661]', async ({ loginPage, sharedPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
sharedPage,
|
||||
testData.fileSharedFav.name,
|
||||
testData.fileSharedFav.viewerToolbarPrimary,
|
||||
testData.fileSharedFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, locked - [C326662]', async ({ loginPage, sharedPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
sharedPage,
|
||||
testData.fileSharedLocked.name,
|
||||
testData.fileSharedLocked.viewerToolbarPrimary,
|
||||
testData.fileSharedLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, favorite, locked - [C326663]', async ({ loginPage, sharedPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
sharedPage,
|
||||
testData.fileSharedFavLocked.name,
|
||||
testData.fileSharedFavLocked.viewerToolbarPrimary,
|
||||
testData.fileSharedFavLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
test.describe('file opened from Search Results', () => {
|
||||
async function checkViewerActions(
|
||||
loginPage: LoginPage,
|
||||
searchPage: SearchPage,
|
||||
item: string,
|
||||
expectedToolbarPrimary: string[],
|
||||
expectedToolbarMore: string[]
|
||||
): Promise<void> {
|
||||
await loginPage.navigate();
|
||||
await loginPage.loginUser({ username: userConsumer, password: userConsumer });
|
||||
await searchPage.navigate({ remoteUrl: `#/search;q=${item}` });
|
||||
await searchPage.searchInput.performDoubleClickFolderOrFileToOpen(item);
|
||||
expect(await searchPage.viewer.isViewerOpened(), 'Viewer is not opened').toBe(true);
|
||||
await searchPage.viewer.verifyViewerPrimaryActions(expectedToolbarPrimary);
|
||||
await searchPage.acaHeader.clickViewerMoreActions();
|
||||
await searchPage.matMenu.verifyActualMoreActions(expectedToolbarMore);
|
||||
}
|
||||
|
||||
test('File Office - [C326664]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileDocx.name,
|
||||
testData.fileDocx.viewerToolbarPrimary,
|
||||
testData.fileDocx.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File Office, favorite - [C326665]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileDocxFav.name,
|
||||
testData.fileDocxFav.viewerToolbarPrimary,
|
||||
testData.fileDocxFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File simple - [C326666]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(loginPage, searchPage, testData.file.name, testData.file.viewerToolbarPrimary, testData.file.viewerToolbarMore);
|
||||
});
|
||||
|
||||
test('File favorite - [C326667]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileFav.name,
|
||||
testData.fileFav.viewerToolbarPrimary,
|
||||
testData.fileFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File Office, shared - [C326670]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileDocxShared.name,
|
||||
testData.fileDocxShared.viewerToolbarPrimary,
|
||||
testData.fileDocxShared.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File Office, shared, favorite - [C326671]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileDocxSharedFav.name,
|
||||
testData.fileDocxSharedFav.viewerToolbarPrimary,
|
||||
testData.fileDocxSharedFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared - [C326672]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileShared.name,
|
||||
testData.fileShared.viewerToolbarPrimary,
|
||||
testData.fileShared.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, favorite - [C326673]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileSharedFav.name,
|
||||
testData.fileSharedFav.viewerToolbarPrimary,
|
||||
testData.fileSharedFav.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File locked - [C326668]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileLocked.name,
|
||||
testData.fileLocked.viewerToolbarPrimary,
|
||||
testData.fileLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File favorite, locked - [C326669]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileFavLocked.name,
|
||||
testData.fileFavLocked.viewerToolbarPrimary,
|
||||
testData.fileFavLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, locked - [C326674]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileSharedLocked.name,
|
||||
testData.fileSharedLocked.viewerToolbarPrimary,
|
||||
testData.fileSharedLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
|
||||
test('File shared, favorite, locked - [C326675]', async ({ loginPage, searchPage }) => {
|
||||
await checkViewerActions(
|
||||
loginPage,
|
||||
searchPage,
|
||||
testData.fileSharedFavLocked.name,
|
||||
testData.fileSharedFavLocked.viewerToolbarPrimary,
|
||||
testData.fileSharedFavLocked.viewerToolbarMore
|
||||
);
|
||||
});
|
||||
});
|
||||
});
|
||||
}
|
@@ -0,0 +1,15 @@
|
||||
{
|
||||
"extends": "../../../tsconfig.adf.json",
|
||||
"compilerOptions": {
|
||||
"outDir": "../../out-tsc/e2e",
|
||||
"baseUrl": "./",
|
||||
"module": "commonjs",
|
||||
"target": "es2017",
|
||||
"types": ["jasmine", "jasminewd2", "node"],
|
||||
"skipLibCheck": true,
|
||||
"paths": {
|
||||
"@alfresco/playwright-shared": ["../../../projects/aca-playwright-shared/src/index.ts"]
|
||||
}
|
||||
},
|
||||
"exclude": ["node_modules"]
|
||||
}
|
12
e2e/playwright/special-permissions-actions-available/tsconfig.e2e.json
Executable file
12
e2e/playwright/special-permissions-actions-available/tsconfig.e2e.json
Executable file
@@ -0,0 +1,12 @@
|
||||
{
|
||||
"extends": "../../../tsconfig.json",
|
||||
"compilerOptions": {
|
||||
"outDir": "../../out-tsc/e2e",
|
||||
"baseUrl": "./",
|
||||
"module": "commonjs",
|
||||
"target": "es2017",
|
||||
"types": ["jasmine", "jasminewd2", "node", "@playwright/test"],
|
||||
"skipLibCheck": true,
|
||||
},
|
||||
"exclude": ["node_modules"]
|
||||
}
|
@@ -27,7 +27,6 @@ import * as testData from './test-data-permissions';
|
||||
import { librariesTests } from './my-libraries';
|
||||
import { favoritesTests } from './favorites';
|
||||
import { searchResultsTests } from './search-results';
|
||||
import { viewerTests } from './viewer';
|
||||
import { sharedFilesTests } from './shared-files';
|
||||
import { collaboratorTests, filesLockedByCurrentUser, filesLockedByOtherUser } from './other-permissions';
|
||||
|
||||
@@ -181,10 +180,6 @@ describe('Special permissions : ', () => {
|
||||
searchResultsTests();
|
||||
});
|
||||
|
||||
describe('on Viewer', () => {
|
||||
viewerTests(sitePrivate);
|
||||
});
|
||||
|
||||
describe('on Shared Files', () => {
|
||||
sharedFilesTests();
|
||||
});
|
||||
|
@@ -112,13 +112,4 @@ describe('Viewer general', () => {
|
||||
expect(await viewer.isCloseButtonDisplayed()).toBe(true, 'Close button is not displayed');
|
||||
expect(await viewer.isFileTitleDisplayed()).toBe(true, 'File title is not displayed');
|
||||
});
|
||||
|
||||
it('[C284634] Viewer opens for a file from Favorites', async () => {
|
||||
await page.clickFavoritesAndWait();
|
||||
await dataTable.doubleClickOnRowByName(xlsxFile);
|
||||
expect(await viewer.isViewerOpened()).toBe(true, 'Viewer is not opened');
|
||||
expect(await viewer.isViewerToolbarDisplayed()).toBe(true, 'Toolbar not displayed');
|
||||
expect(await viewer.isCloseButtonDisplayed()).toBe(true, 'Close button is not displayed');
|
||||
expect(await viewer.isFileTitleDisplayed()).toBe(true, 'File title is not displayed');
|
||||
});
|
||||
});
|
||||
|
Reference in New Issue
Block a user