Skip to content

Commit

Permalink
[ACS-8845] [E2E] Added e2e tests for verifying file types in viewer
Browse files Browse the repository at this point in the history
  • Loading branch information
datguychen committed Oct 1, 2024
1 parent 2c347ea commit cdad1c4
Show file tree
Hide file tree
Showing 11 changed files with 193 additions and 1 deletion.
7 changes: 6 additions & 1 deletion e2e/playwright/viewer/exclude.tests.json
Original file line number Diff line number Diff line change
@@ -1 +1,6 @@
{}
{
"XAT-17181": "https://hyland.atlassian.net/browse/ACS-8865",
"XAT-17182": "https://hyland.atlassian.net/browse/ACS-8865",
"XAT-17184": "https://hyland.atlassian.net/browse/ACS-8865",
"XAT-17185": "https://hyland.atlassian.net/browse/ACS-8865"
}
156 changes: 156 additions & 0 deletions e2e/playwright/viewer/src/tests/viewer-file-types.e2e.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,156 @@
/*!
* Copyright © 2005-2024 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 { ApiClientFactory, FileActionsApi, NodesApi, test, TEST_FILES, Utils, TrashcanApi, PersonalFilesPage } from '@alfresco/aca-playwright-shared';

test.describe('viewer file types', () => {
const randomString = Utils.random();
const username = `user-${randomString}`;
const randomDocxName = `${TEST_FILES.DOCX.name}-${randomString}`;
const randomJpgName = `${TEST_FILES.JPG_FILE.name}-${randomString}`;
const randomPngName = `${TEST_FILES.PNG_FILE.name}-${randomString}`;
const randomGifName = `${TEST_FILES.GIF_FILE.name}-${randomString}`;
const randomPdfName = `${TEST_FILES.PDF.name}-${randomString}`;
const randomPptxName = `${TEST_FILES.PPTX_FILE.name}-${randomString}`;
const randomMp3Name = `${TEST_FILES.MP3_FILE.name}-${randomString}`;
const randomMp4Name = `${TEST_FILES.MP4_FILE.name}-${randomString}`;
const randomWebmName = `${TEST_FILES.WEBM_FILE.name}-${randomString}`;
let nodesApi: NodesApi;
let trashcanApi: TrashcanApi;
let fileActionApi: FileActionsApi;

test.beforeAll(async () => {
const apiClientFactory = new ApiClientFactory();
await apiClientFactory.setUpAcaBackend('admin');
await apiClientFactory.createUser({ username });
nodesApi = await NodesApi.initialize(username, username);
fileActionApi = await FileActionsApi.initialize(username, username);
trashcanApi = await TrashcanApi.initialize(username, username);

const filesToUpload = [
{ path: TEST_FILES.DOCX.path, name: randomDocxName },
{ path: TEST_FILES.JPG_FILE.path, name: randomJpgName },
{ path: TEST_FILES.PNG_FILE.path, name: randomPngName },
{ path: TEST_FILES.GIF_FILE.path, name: randomGifName },
{ path: TEST_FILES.PDF.path, name: randomPdfName },
{ path: TEST_FILES.PPTX_FILE.path, name: randomPptxName },
{ path: TEST_FILES.MP3_FILE.path, name: randomMp3Name },
{ path: TEST_FILES.MP4_FILE.path, name: randomMp4Name },
{ path: TEST_FILES.WEBM_FILE.path, name: randomWebmName }
];

for (const file of filesToUpload) {
await fileActionApi.uploadFile(file.path, file.name, '-my-');
}

await fileActionApi.waitForNodes(randomWebmName, { expect: 1 });
});

test.beforeEach(async ({ loginPage }) => {
await Utils.tryLoginUser(loginPage, username, username, 'beforeEach failed');
});

test.afterAll(async () => {
await Utils.deleteNodesSitesEmptyTrashcan(nodesApi, trashcanApi, 'afterAll failed');
});

async function checkViewerDisplay(
page: PersonalFilesPage,
fileName: string,
fileType: 'viewerImage' | 'viewerDocument' | 'viewerMedia' = 'viewerImage'
) {
await page.dataTable.performClickFolderOrFileToOpen(fileName);
expect(await page.viewer.isViewerOpened(), 'Viewer is not opened').toBe(true);
await expect(page.viewer.unknownFormat).toBeHidden();

const viewerElements = {
viewerImage: page.viewer.viewerImage,
viewerDocument: page.viewer.viewerDocument,
viewerMedia: page.viewer.viewerMedia
};

const viewerElement = viewerElements[fileType];
if (!viewerElement) {
throw new Error(`Wrong viewer file type: ${fileType}`);
}

await expect(viewerElement).toBeVisible();
}

test('[XAT-17177] Image files are properly displayed in the viewer - JPG', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomJpgName, 'viewerImage');
});

test('[XAT-17178] Image files are properly displayed in the viewer - PNG', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomPngName, 'viewerImage');
});

test('[XAT-17179] Image files are properly displayed in the viewer - GIF', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomGifName, 'viewerImage');
});

test('[XAT-17180] Document files are properly displayed in the viewer - PDF', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomPdfName, 'viewerDocument');
});

test('[XAT-17181] Document files are properly displayed in the viewer - DOCX', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomDocxName, 'viewerDocument');
});

test('[XAT-17182] Document files are properly displayed in the viewer - PPTX', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomPptxName, 'viewerDocument');
});

test('[XAT-17183] Audio files are properly displayed in the viewer - MP3', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomMp3Name, 'viewerMedia');
});

test('[XAT-17184] Video files are properly displayed in the viewer - MP4', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomMp4Name, 'viewerMedia');
});

test('[XAT-17185] Video files are properly displayed in the viewer - WEBM', async ({ personalFiles }) => {
await checkViewerDisplay(personalFiles, randomWebmName, 'viewerMedia');
});

test('[XAT-5485] User can select a document page through the thumbnail pane', async ({ personalFiles }) => {
await personalFiles.dataTable.performClickFolderOrFileToOpen(randomPdfName);
expect(await personalFiles.viewer.isViewerOpened(), 'Viewer is not opened').toBe(true);
await personalFiles.viewer.documentThumbnailButton.click();
await expect(personalFiles.viewer.thumbnailsPages.first()).toBeVisible();
await expect(personalFiles.viewer.viewerPage).toHaveValue('1');
await personalFiles.viewer.thumbnailsPages.nth(1).click();
await expect(personalFiles.viewer.viewerPage).toHaveValue('2');
});

test('[XAT-5486] User can close the thumbnail pane', async ({ personalFiles }) => {
await personalFiles.dataTable.performClickFolderOrFileToOpen(randomPdfName);
expect(await personalFiles.viewer.isViewerOpened(), 'Viewer is not opened').toBe(true);
await personalFiles.viewer.documentThumbnailButton.click();
await expect(personalFiles.viewer.thumbnailsPages.first()).toBeVisible();
await personalFiles.viewer.thumbnailsCloseButton.click();
await expect(personalFiles.viewer.thumbnailsPages.first()).toBeHidden();
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,13 @@ export class ViewerComponent extends BaseComponent {
public downloadButton = this.getChild('button[id="app.viewer.download"]');
public allButtons = this.getChild('button');
public unknownFormat = this.getChild(`adf-viewer-unknown-format .adf-viewer__unknown-format-view`);
public viewerImage = this.viewerLocator.locator('.cropper-canvas img');
public viewerDocument = this.viewerLocator.locator('.adf-pdf-viewer__content [role="document"]');
public documentThumbnailButton = this.getChild('[data-automation-id="adf-thumbnails-button"]');
public thumbnailsPages = this.getChild('[data-automation-id="adf-thumbnails-content"] adf-pdf-thumb');
public thumbnailsCloseButton = this.getChild('[data-automation-id="adf-thumbnails-close"]');
public viewerPage = this.getChild('[data-automation-id="adf-page-selector"]');
public viewerMedia = this.getChild('adf-media-player');

toolbar = new AcaHeader(this.page);

Expand Down
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Binary file not shown.
24 changes: 24 additions & 0 deletions projects/aca-playwright-shared/src/resources/test-files/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,30 @@ export const TEST_FILES = {
path: resolve(__dirname, 'file-jpg-1mb.jpg'),
name: 'file-jpg-1mb'
},
PNG_FILE: {
path: resolve(__dirname, 'file-png.png'),
name: 'file-png'
},
GIF_FILE: {
path: resolve(__dirname, 'file-gif.gif'),
name: 'file-gif'
},
PPTX_FILE: {
path: resolve(__dirname, 'file-pptx.pptx'),
name: 'file-pptx'
},
MP3_FILE: {
path: resolve(__dirname, 'file-mp3.mp3'),
name: 'file-mp3'
},
MP4_FILE: {
path: resolve(__dirname, 'file-mp4.mp4'),
name: 'file-mp4'
},
WEBM_FILE: {
path: resolve(__dirname, 'file-webm.webm'),
name: 'file-webm'
},
PDF_PROTECTED2: {
path: resolve(__dirname, 'protected.pdf'),
name: 'file-protected',
Expand Down

0 comments on commit cdad1c4

Please sign in to comment.