Skip to content

Commit

Permalink
[ACS-7765] playwright Migration for upload new action e2e test (#3866)
Browse files Browse the repository at this point in the history
* [ACS-7764] Migrated e2e tests Actions - upload

* [ACS-7764] Protractor2Playwright - Actions - Upload

* [ACS-7764] upload file fix

* [ACS-7765] playwright upload new action e2e test

* [ACS-7765] fix locator

* [ACS-7765] added fix and new test

* suggested fix for locator text

Co-authored-by: MichalKinas <113341662+MichalKinas@users.noreply.github.com>

* Update viewer.component.ts

---------

Co-authored-by: Katarzyna Kita <katarzyna.kita@hyland.com>
Co-authored-by: MichalKinas <113341662+MichalKinas@users.noreply.github.com>
  • Loading branch information
3 people committed Jun 4, 2024
1 parent e35b12d commit 1574518
Show file tree
Hide file tree
Showing 10 changed files with 232 additions and 895 deletions.
7 changes: 0 additions & 7 deletions .github/actions/run-e2e-playwright/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -29,10 +29,3 @@ runs:
sleep 90
npx nx run ${{ inputs.options }}-e2e:e2e
- name: Upload E2Es results
if: always()
uses: actions/upload-artifact@v4
with:
name: ${{ inputs.artifact-name }}
path: |
test-results/
2 changes: 0 additions & 2 deletions .github/workflows/pull-request.yml
Original file line number Diff line number Diff line change
Expand Up @@ -101,8 +101,6 @@ jobs:
fail-fast: false
matrix:
e2e-suites:
- name: "search"
id: 2
- name: "deleteActions"
id: 7
- name: "editActions,favoriteActions"
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,213 @@
/*!
* 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,
Utils,
test,
TrashcanApi,
NodesApi,
TEST_FILES,
FileActionsApi,
PersonalFilesPage,
SearchPage
} from '@alfresco/playwright-shared';

test.describe('Upload new version', () => {
const username = `user-${Utils.random()}`;

const file1 = `file1-${Utils.random()}.docx`;
let file1Id: string;
const fileLocked1 = `file-locked1-${Utils.random()}.docx`;
let fileLocked1Id: string;
const fileLocked2 = `file-locked2-${Utils.random()}.docx`;
let fileLocked2Id: string;

const searchRandom = Utils.random();
const fileSearch2 = `search-${searchRandom}-file2.docx`;
let fileSearch2Id: string;
const fileSearch3 = `search-${searchRandom}-file3.docx`;
let fileSearch3Id: string;

const parentPF = `parentPersonal-${Utils.random()}`;
let parentPFId: string;
const parentSearch = `parentSearch-${Utils.random()}`;
let parentSearchId: string;
const parentUnsupported = `parentUnsupported-${Utils.random()}`;
let parentUnsupportedId: string;
let filePdfID: string;
let fileJpgID: string;

const file = TEST_FILES.PDF.name;
const fileToUpload1 = TEST_FILES.DOCX2.name;
const fileToUpload2 = TEST_FILES.XLSX;

let trashcanApi: TrashcanApi;
let nodesApi: NodesApi;
let fileActionAPI: FileActionsApi;

async function uploadNewVersion(page: PersonalFilesPage | SearchPage, filename: string, location: string) {
await page.dataTable.selectItem(filename);
await page.acaHeader.clickMoreActions();
await page.acaHeader.matMenu.clickMenuItem('Upload New Version');
await page.acaHeader.uploadNewVersionButton.setInputFiles(location);
}

async function previewUnsupportedFile(page: PersonalFilesPage, unsupportedFileName: string): Promise<void> {
await page.dataTable.performClickFolderOrFileToOpen(unsupportedFileName);
await page.viewer.checkUnknownFormatIsDisplayed();
expect(await page.viewer.getUnknownFormatMessage()).toBe(`Couldn't load preview. Unknown format.`);
await page.viewer.closeButtonLocator.click();
}

test.beforeAll(async () => {
const apiClientFactory = new ApiClientFactory();
await apiClientFactory.setUpAcaBackend('admin');
await apiClientFactory.createUser({ username });
trashcanApi = await TrashcanApi.initialize(username, username);
nodesApi = await NodesApi.initialize(username, username);
fileActionAPI = await FileActionsApi.initialize(username, username);
parentPFId = (await nodesApi.createFolder(parentPF)).entry.id;
parentSearchId = (await nodesApi.createFolder(parentSearch)).entry.id;
parentUnsupportedId = (await nodesApi.createFolder(parentUnsupported)).entry.id;
});

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

test.describe('on Search Results', () => {
test.beforeAll(async () => {
await fileActionAPI.uploadFile(TEST_FILES.PDF.path, file, parentSearchId);
fileSearch2Id = (await nodesApi.createFile(fileSearch2, parentSearchId)).entry.id;
fileSearch3Id = (await nodesApi.createFile(fileSearch3, parentSearchId)).entry.id;
await fileActionAPI.waitForNodes(file, { expect: 1 });
});

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

test('[C307005] file is updated after uploading a new version - minor', async ({ searchPage }) => {
await searchPage.searchWithin(fileSearch2, 'files');
await uploadNewVersion(searchPage, fileSearch2, fileToUpload2.path);

await searchPage.uploadNewVersionDialog.description.fill('new minor version description');
await searchPage.uploadNewVersionDialog.uploadButton.click();
await searchPage.uploadNewVersionDialog.cancelButton.waitFor({ state: 'detached' });

expect(await nodesApi.getNodeProperty(fileSearch2Id, 'cm:versionLabel'), 'File has incorrect version label').toEqual('1.1');
expect(await nodesApi.getNodeProperty(fileSearch2Id, 'cm:versionType'), 'File has incorrect version type').toEqual('MINOR');
});

test('[C307006] file is not updated when clicking Cancel', async ({ searchPage }) => {
await searchPage.searchWithin(fileSearch3, 'files');
await uploadNewVersion(searchPage, fileSearch3, fileSearch3);

await searchPage.uploadNewVersionDialog.description.fill('new version description');
await searchPage.uploadNewVersionDialog.cancelButton.click();

expect(await searchPage.dataTable.isItemPresent(fileSearch3)).toBe(true);
expect(await nodesApi.getNodeProperty(fileSearch3Id, 'cm:versionLabel'), 'File has incorrect version label').toEqual('1.0');
expect(await nodesApi.getNodeProperty(fileSearch3Id, 'cm:versionType'), 'File has incorrect version type').toEqual('MAJOR');
});
});

test.describe('on Personal Files', () => {
test.beforeAll(async () => {
await fileActionAPI.uploadFile(TEST_FILES.PDF.path, `${TEST_FILES.PDF.name}.${TEST_FILES.PDF.extension}`, parentPFId);
file1Id = (await nodesApi.createFile(file1, parentPFId)).entry.id;
fileLocked1Id = (await nodesApi.createFile(fileToUpload1, parentPFId)).entry.id;
fileLocked2Id = (await nodesApi.createFile(fileLocked2, parentPFId)).entry.id;

await nodesApi.lockNodes([fileLocked1Id, fileLocked2Id]);
});

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

test('[C297548] upload new version fails when new file name already exists', async ({ personalFiles }) => {
await uploadNewVersion(personalFiles, file1, TEST_FILES.PDF.path);

await expect(personalFiles.uploadNewVersionDialog.title).toHaveText('Upload New Version');
await personalFiles.uploadNewVersionDialog.description.fill('new version description');
await personalFiles.uploadNewVersionDialog.uploadButton.click();

const message = await personalFiles.snackBar.message.innerText();
expect(message).toContain('New version not uploaded, another file with the same name already exists');
expect(await personalFiles.dataTable.isItemPresent(file1)).toBe(true);
expect(await nodesApi.getNodeProperty(file1Id, 'cm:versionLabel')).toEqual('1.0');
expect(await nodesApi.getNodeProperty(file1Id, 'cm:versionType')).toEqual('MAJOR');
});

test('[C297549] file is unlocked after uploading a new version', async ({ personalFiles }) => {
await uploadNewVersion(personalFiles, fileToUpload1, TEST_FILES.DOCX2.path);

await personalFiles.uploadNewVersionDialog.description.fill('new version description');
await personalFiles.uploadNewVersionDialog.uploadButton.click();

expect(await personalFiles.dataTable.isItemPresent(fileToUpload1), 'File was not updated').toBe(true);
expect(await nodesApi.getNodeProperty(fileLocked1Id, 'cm:lockType'), `${fileLocked1} is still locked`).not.toEqual('WRITE_LOCK');
expect(await nodesApi.getNodeProperty(fileLocked1Id, 'cm:versionType'), 'File has incorrect version type').toEqual('MINOR');
expect(await nodesApi.getNodeProperty(fileLocked1Id, 'cm:versionLabel'), 'File has incorrect version label').toEqual('1.1');
});

test('[C297550] file remains locked after canceling of uploading a new version', async ({ personalFiles }) => {
await uploadNewVersion(personalFiles, fileLocked2, TEST_FILES.DOCX2.path);
await personalFiles.uploadNewVersionDialog.cancelButton.click();

expect(await personalFiles.dataTable.isItemPresent(fileLocked2), 'File not displayed').toBe(true);
expect(await nodesApi.getNodeProperty(fileLocked2Id, 'cm:lockType'), `${fileLocked2} was unlocked`).toEqual('WRITE_LOCK');
});
});

test.describe('Viewer - version update with unsupported file', () => {
test.beforeAll(async () => {
filePdfID = (await fileActionAPI.uploadFile(TEST_FILES.PDF.path, TEST_FILES.PDF.name, parentUnsupportedId)).entry.id;
fileJpgID = (await fileActionAPI.uploadFile(TEST_FILES.JPG_FILE.path, TEST_FILES.JPG_FILE.name, parentUnsupportedId)).entry.id;
});

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

test('[C587084] Should display unknown format the preview for an unsupported file', async ({ personalFiles }) => {
await uploadNewVersion(personalFiles, TEST_FILES.JPG_FILE.name, TEST_FILES.FILE_UNSUPPORTED.path);
await personalFiles.uploadNewVersionDialog.uploadButton.click();
await previewUnsupportedFile(personalFiles, TEST_FILES.FILE_UNSUPPORTED.name);
await nodesApi.deleteNodes([fileJpgID], true);

await personalFiles.page.reload({ waitUntil: 'load' });

await uploadNewVersion(personalFiles, TEST_FILES.PDF.name, TEST_FILES.FILE_UNSUPPORTED.path);
await personalFiles.uploadNewVersionDialog.uploadButton.click();
await previewUnsupportedFile(personalFiles, TEST_FILES.FILE_UNSUPPORTED.name);
await nodesApi.deleteNodes([filePdfID], true);
});
});
});
2 changes: 1 addition & 1 deletion e2e/playwright/viewer/src/tests/viewer-action.e2e.ts
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@ test.describe('viewer action file', () => {
await expect(favoritePage.viewerDialog.shareDialogTitle, 'Share dialog should be open').toBeHidden();
});

test('[C297586] Upload new version action', async ({ personalFiles, nodesApiAction }) => {
test('[C297586] [C307004] Upload new version action - major', async ({ personalFiles, nodesApiAction }) => {
await personalFiles.dataTable.performClickFolderOrFileToOpen(filePersonalFiles);
await personalFiles.viewer.waitForViewerToOpen();

Expand Down
Loading

0 comments on commit 1574518

Please sign in to comment.