[ACS-7765] playwright Migration for upload new action e2e test (#3866)

* [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>
This commit is contained in:
Akash Rathod 2024-06-04 15:27:48 +02:00 committed by GitHub
parent e35b12d53f
commit 157451841c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
10 changed files with 232 additions and 895 deletions

View File

@ -29,10 +29,3 @@ runs:
sleep 90 sleep 90
npx nx run ${{ inputs.options }}-e2e:e2e 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/

View File

@ -101,8 +101,6 @@ jobs:
fail-fast: false fail-fast: false
matrix: matrix:
e2e-suites: e2e-suites:
- name: "search"
id: 2
- name: "deleteActions" - name: "deleteActions"
id: 7 id: 7
- name: "editActions,favoriteActions" - name: "editActions,favoriteActions"

View File

@ -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);
});
});
});

View File

@ -179,7 +179,7 @@ test.describe('viewer action file', () => {
await expect(favoritePage.viewerDialog.shareDialogTitle, 'Share dialog should be open').toBeHidden(); 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.dataTable.performClickFolderOrFileToOpen(filePersonalFiles);
await personalFiles.viewer.waitForViewerToOpen(); await personalFiles.viewer.waitForViewerToOpen();

View File

@ -1,881 +0,0 @@
/*!
* 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 {
AdminActions,
LoginPage,
BrowsingPage,
SearchResultsPage,
FILES,
RepoClient,
Utils,
UploadNewVersionDialog,
UserActions
} from '@alfresco/aca-testing-shared';
describe('Upload new version', () => {
const username = `user-${Utils.random()}`;
const file1 = `file1-${Utils.random()}.docx`;
let file1Id: string;
const file2 = `file2-${Utils.random()}.docx`;
let file2Id: string;
const file3 = `file3-${Utils.random()}.docx`;
let file3Id: string;
const file4 = `file4-${Utils.random()}.docx`;
let file4Id: 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 fileSearch1 = `search-${searchRandom}-file1.docx`;
let fileSearch1Id: string;
const fileSearch2 = `search-${searchRandom}-file2.docx`;
let fileSearch2Id: string;
const fileSearch3 = `search-${searchRandom}-file3.docx`;
let fileSearch3Id: string;
const fileSearch4 = `search-${searchRandom}-file4.docx`;
let fileSearch4Id: string;
const fileLockedSearch1 = `search-${searchRandom}-file-locked1.docx`;
let fileLockedSearch1Id: string;
const fileLockedSearch2 = `search-${searchRandom}-file-locked2.docx`;
let fileLockedSearch2Id: string;
const parentPF = `parentPersonal-${Utils.random()}`;
let parentPFId: string;
const parentSF = `parentShared-${Utils.random()}`;
let parentSFId: string;
const parentRF = `parentRecent-${Utils.random()}`;
let parentRFId: string;
const parentFav = `parentFav-${Utils.random()}`;
let parentFavId: string;
const parentSearch = `parentSearch-${Utils.random()}`;
let parentSearchId: string;
const nameConflictMessage = 'New version not uploaded, another file with the same name already exists';
const file = FILES.pdfFile;
let fileId: string;
const fileToUpload1 = FILES.docxFile;
const fileToUpload2 = FILES.xlsxFile;
const fileToUpload3 = FILES.pdfFile;
const fileToUpload4 = FILES.docxFile2;
const fileToUpload5 = FILES.xlsxFile2;
const apis = {
user: new RepoClient(username, username)
};
const loginPage = new LoginPage();
const page = new BrowsingPage();
const searchResultsPage = new SearchResultsPage();
const { dataTable, toolbar } = page;
const uploadNewVersionDialog = new UploadNewVersionDialog();
const { searchInput } = page.pageLayoutHeader;
const adminActions = new AdminActions();
const userActions = new UserActions();
beforeAll(async () => {
await adminActions.createUser({ username });
await userActions.login(username, username);
parentPFId = await apis.user.createFolder(parentPF);
parentSFId = await apis.user.createFolder(parentSF);
parentRFId = await apis.user.createFolder(parentRF);
parentFavId = await apis.user.createFolder(parentFav);
parentSearchId = await apis.user.createFolder(parentSearch);
});
afterAll(async () => {
await userActions.login(username, username);
await apis.user.nodes.deleteNodesById([parentPFId, parentSFId, parentRFId, parentFavId, parentSearchId]);
});
describe('on Search Results', () => {
beforeAll(async () => {
fileId = (await apis.user.upload.uploadFile(file, parentSearchId)).entry.id;
fileSearch1Id = await apis.user.createFile(fileSearch1, parentSearchId);
fileSearch2Id = await apis.user.createFile(fileSearch2, parentSearchId);
fileSearch3Id = await apis.user.createFile(fileSearch3, parentSearchId);
fileSearch4Id = await apis.user.createFile(fileSearch4, parentSearchId);
fileLockedSearch1Id = await apis.user.createFile(fileLockedSearch1, parentSearchId);
fileLockedSearch2Id = await apis.user.createFile(fileLockedSearch2, parentSearchId);
await userActions.lockNodes([fileLockedSearch1Id, fileLockedSearch2Id]);
await apis.user.search.waitForNodes(searchRandom, { expect: 6 });
await loginPage.loginWith(username);
});
afterEach(async () => {
await Utils.pressEscape();
await page.header.expandSideNav();
await page.clickPersonalFilesAndWait();
});
it('[C307003] dialog UI defaults', async () => {
await toolbar.clickSearchIconButton();
await searchInput.clickSearchButton();
await searchInput.checkFilesAndFolders();
await searchInput.searchFor(file);
await searchResultsPage.waitForResults();
await dataTable.selectItem(file, parentSearch);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
expect(await uploadNewVersionDialog.getDialogTitle()).toEqual('Upload New Version');
expect(await uploadNewVersionDialog.description.isDisplayed()).toBe(true, 'Description not displayed');
expect(await uploadNewVersionDialog.minorOption.isDisplayed()).toBe(true, 'Minor option not displayed');
expect(await uploadNewVersionDialog.majorOption.isDisplayed()).toBe(true, 'Major option not displayed');
expect(await uploadNewVersionDialog.isCancelButtonEnabled()).toBe(true, 'Cancel button not enabled');
expect(await uploadNewVersionDialog.isUploadButtonEnabled()).toBe(true, 'Update button not enabled');
});
it('[C307004] file is updated after uploading a new version - major', async () => {
await toolbar.clickSearchIconButton();
await searchInput.clickSearchButton();
await searchInput.checkFilesAndFolders();
await searchInput.searchFor(fileSearch1);
await dataTable.waitForBody();
await dataTable.selectItem(fileSearch1, parentSearch);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
await uploadNewVersionDialog.majorOption.click();
await uploadNewVersionDialog.enterDescription('new major version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
// TODO: enable when ACA-2329 is fixed
// expect(await dataTable.isItemPresent(fileToUpload1, parentSearch)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(fileSearch1Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileSearch1Id)).toEqual('2.0', 'File has incorrect version label');
});
it('[C307005] file is updated after uploading a new version - minor', async () => {
await toolbar.clickSearchIconButton();
await searchInput.clickSearchButton();
await searchInput.checkFilesAndFolders();
await searchInput.searchFor(fileSearch2);
await dataTable.waitForBody();
await dataTable.selectItem(fileSearch2, parentSearch);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload2);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new minor version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
// TODO: enable when ACA-2329 is fixed
// expect(await dataTable.isItemPresent(fileToUpload2, parentSearch)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(fileSearch2Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileSearch2Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C307006] file is not updated when clicking Cancel', async () => {
await toolbar.clickSearchIconButton();
await searchInput.clickSearchButton();
await searchInput.checkFilesAndFolders();
await searchInput.searchFor(fileSearch3);
await dataTable.waitForBody();
await dataTable.selectItem(fileSearch3, parentSearch);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload3);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(fileSearch3, parentSearch)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(fileSearch3Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileSearch3Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C307007] upload new version fails when new file name already exists', async () => {
await toolbar.clickSearchIconButton();
await searchInput.clickSearchButton();
await searchInput.checkFilesAndFolders();
await searchInput.searchFor(fileSearch4);
await dataTable.waitForBody();
await dataTable.selectItem(fileSearch4, parentSearch);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(file);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
const message = await page.getSnackBarMessage();
expect(message).toContain(nameConflictMessage);
expect(await dataTable.isItemPresent(fileSearch4, parentSearch)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(fileSearch4Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileSearch4Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C307008] file is unlocked after uploading a new version', async () => {
await toolbar.clickSearchIconButton();
await searchInput.clickSearchButton();
await searchInput.checkFilesAndFolders();
await searchInput.searchFor(fileLockedSearch1);
await dataTable.waitForBody();
await dataTable.selectItem(fileLockedSearch1, parentSearch);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload4);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
// TODO: enable when ACA-2329 is fixed
// expect(await dataTable.isItemPresent(fileToUpload4, parentSearch)).toBe(true, 'File name was not changed');
expect(await apis.user.nodes.isFileLockedWrite(fileLockedSearch1Id)).toBe(false, `${fileLockedSearch1} is still locked`);
expect(await apis.user.nodes.getFileVersionType(fileLockedSearch1Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileLockedSearch1Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C307009] file remains locked after canceling of uploading a new version', async () => {
await toolbar.clickSearchIconButton();
await searchInput.clickSearchButton();
await searchInput.checkFilesAndFolders();
await searchInput.searchFor(fileLockedSearch2);
await dataTable.waitForBody();
await dataTable.selectItem(fileLockedSearch2, parentSearch);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload5);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(fileToUpload5, parentSearch)).toBe(false, 'File was updated');
expect(await dataTable.isItemPresent(fileLockedSearch2, parentSearch)).toBe(true, 'File not displayed');
expect(await apis.user.nodes.isFileLockedWrite(fileLockedSearch2Id)).toBe(true, `${fileLockedSearch2} was unlocked`);
});
});
describe('on Personal Files', () => {
beforeAll(async () => {
fileId = (await apis.user.upload.uploadFile(file, parentPFId)).entry.id;
file1Id = (await apis.user.nodes.createFile(file1, parentPFId)).entry.id;
file2Id = (await apis.user.nodes.createFile(file2, parentPFId)).entry.id;
file3Id = (await apis.user.nodes.createFile(file3, parentPFId)).entry.id;
file4Id = (await apis.user.nodes.createFile(file4, parentPFId)).entry.id;
fileLocked1Id = (await apis.user.nodes.createFile(fileLocked1, parentPFId)).entry.id;
fileLocked2Id = (await apis.user.nodes.createFile(fileLocked2, parentPFId)).entry.id;
await userActions.lockNodes([fileLocked1Id, fileLocked2Id]);
await loginPage.loginWith(username);
});
beforeEach(async () => {
await page.clickPersonalFilesAndWait();
await dataTable.doubleClickOnRowByName(parentPF);
});
afterEach(async () => {
await Utils.pressEscape();
await page.refresh();
});
it('[C297544] dialog UI defaults', async () => {
await dataTable.selectItem(file);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
expect(await uploadNewVersionDialog.getDialogTitle()).toEqual('Upload New Version');
expect(await uploadNewVersionDialog.description.isDisplayed()).toBe(true, 'Description not displayed');
expect(await uploadNewVersionDialog.minorOption.isDisplayed()).toBe(true, 'Minor option not displayed');
expect(await uploadNewVersionDialog.majorOption.isDisplayed()).toBe(true, 'Major option not displayed');
expect(await uploadNewVersionDialog.isCancelButtonEnabled()).toBe(true, 'Cancel button not enabled');
expect(await uploadNewVersionDialog.isUploadButtonEnabled()).toBe(true, 'Update button not enabled');
});
it('[C297545] file is updated after uploading a new version - major', async () => {
await dataTable.selectItem(file1);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
await uploadNewVersionDialog.majorOption.click();
await uploadNewVersionDialog.enterDescription('new major version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload1)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(file1Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file1Id)).toEqual('2.0', 'File has incorrect version label');
});
it('[C297546] file is updated after uploading a new version - minor', async () => {
await dataTable.selectItem(file2);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload2);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new minor version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload2)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(file2Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file2Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C297547] file is not updated when clicking Cancel', async () => {
await dataTable.selectItem(file3);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload3);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(file3)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(file3Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file3Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C297548] upload new version fails when new file name already exists', async () => {
await dataTable.selectItem(file4);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(file);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
const message = await page.getSnackBarMessage();
expect(message).toContain(nameConflictMessage);
expect(await dataTable.isItemPresent(file4)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(file4Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file4Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C297549] file is unlocked after uploading a new version', async () => {
await dataTable.selectItem(fileLocked1);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload4);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload4)).toBe(true, 'File name was not changed');
expect(await apis.user.nodes.isFileLockedWrite(fileLocked1Id)).toBe(false, `${fileLocked1} is still locked`);
expect(await apis.user.nodes.getFileVersionType(fileLocked1Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileLocked1Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C297550] file remains locked after canceling of uploading a new version', async () => {
await dataTable.selectItem(fileLocked2);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload5);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(fileToUpload5)).toBe(false, 'File was updated');
expect(await dataTable.isItemPresent(fileLocked2)).toBe(true, 'File not displayed');
expect(await apis.user.nodes.isFileLockedWrite(fileLocked2Id)).toBe(true, `${fileLocked2} was unlocked`);
});
});
describe('on Shared Files', () => {
beforeAll(async () => {
fileId = (await apis.user.upload.uploadFile(file, parentSFId)).entry.id;
file1Id = await apis.user.createFile(file1, parentSFId);
file2Id = await apis.user.createFile(file2, parentSFId);
file3Id = await apis.user.createFile(file3, parentSFId);
file4Id = await apis.user.createFile(file4, parentSFId);
fileLocked1Id = await apis.user.createFile(fileLocked1, parentSFId);
fileLocked2Id = await apis.user.createFile(fileLocked2, parentSFId);
await userActions.lockNodes([fileLocked1Id, fileLocked2Id]);
await apis.user.shared.shareFilesByIds([fileId, file1Id, file2Id, file3Id, file4Id, fileLocked1Id, fileLocked2Id]);
await apis.user.shared.waitForFilesToBeShared([fileId, file1Id, file2Id, file3Id, file4Id, fileLocked1Id, fileLocked2Id]);
await loginPage.loginWith(username);
});
beforeEach(async () => {
await page.clickSharedFilesAndWait();
});
afterEach(async () => {
await page.refresh();
});
it('[C297551] dialog UI defaults', async () => {
await dataTable.selectItem(file);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
expect(await uploadNewVersionDialog.getDialogTitle()).toEqual('Upload New Version');
expect(await uploadNewVersionDialog.description.isDisplayed()).toBe(true, 'Description not displayed');
expect(await uploadNewVersionDialog.minorOption.isDisplayed()).toBe(true, 'Minor option not displayed');
expect(await uploadNewVersionDialog.majorOption.isDisplayed()).toBe(true, 'Major option not displayed');
expect(await uploadNewVersionDialog.isCancelButtonEnabled()).toBe(true, 'Cancel button not enabled');
expect(await uploadNewVersionDialog.isUploadButtonEnabled()).toBe(true, 'Update button not enabled');
});
it('[C297552] file is updated after uploading a new version - major', async () => {
await dataTable.selectItem(file1);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
await uploadNewVersionDialog.majorOption.click();
await uploadNewVersionDialog.enterDescription('new major version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload1)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(file1Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file1Id)).toEqual('2.0', 'File has incorrect version label');
});
it('[C297553] file is updated after uploading a new version - minor', async () => {
await dataTable.selectItem(file2);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload2);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new minor version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload2)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(file2Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file2Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C297554] file is not updated when clicking Cancel', async () => {
await dataTable.selectItem(file3);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload3);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(file3)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(file3Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file3Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C297555] upload new version fails when new file name already exists', async () => {
await dataTable.selectItem(file4);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(file);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
const message = await page.getSnackBarMessage();
expect(message).toContain(nameConflictMessage);
expect(await dataTable.isItemPresent(file4)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(file4Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file4Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C297556] file is unlocked after uploading a new version', async () => {
await dataTable.selectItem(fileLocked1);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload4);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload4)).toBe(true, 'File name was not changed');
expect(await apis.user.nodes.isFileLockedWrite(fileLocked1Id)).toBe(false, `${fileLocked1} is still locked`);
expect(await apis.user.nodes.getFileVersionType(fileLocked1Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileLocked1Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C297557] file remains locked after canceling of uploading a new version', async () => {
await dataTable.selectItem(fileLocked2);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload5);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(fileToUpload5)).toBe(false, 'File was updated');
expect(await dataTable.isItemPresent(fileLocked2)).toBe(true, 'File not displayed');
expect(await apis.user.nodes.isFileLockedWrite(fileLocked2Id)).toBe(true, `${fileLocked2} was unlocked`);
});
});
describe('on Recent Files', () => {
beforeAll(async () => {
const initialRecentTotalItems = await apis.user.search.getTotalItems(username);
fileId = (await apis.user.upload.uploadFile(file, parentRFId)).entry.id;
file1Id = await apis.user.createFile(file1, parentRFId);
file2Id = await apis.user.createFile(file2, parentRFId);
file3Id = await apis.user.createFile(file3, parentRFId);
file4Id = await apis.user.createFile(file4, parentRFId);
fileLocked1Id = await apis.user.createFile(fileLocked1, parentRFId);
fileLocked2Id = await apis.user.createFile(fileLocked2, parentRFId);
await userActions.lockNodes([fileLocked1Id, fileLocked2Id]);
await apis.user.search.waitForApi(username, { expect: initialRecentTotalItems + 7 });
await loginPage.loginWith(username);
});
beforeEach(async () => {
await page.clickRecentFilesAndWait();
});
afterEach(async () => {
await page.refresh();
});
it('[C297558] dialog UI defaults', async () => {
await dataTable.selectItem(file, parentRF);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
expect(await uploadNewVersionDialog.getDialogTitle()).toEqual('Upload New Version');
expect(await uploadNewVersionDialog.description.isDisplayed()).toBe(true, 'Description not displayed');
expect(await uploadNewVersionDialog.minorOption.isDisplayed()).toBe(true, 'Minor option not displayed');
expect(await uploadNewVersionDialog.majorOption.isDisplayed()).toBe(true, 'Major option not displayed');
expect(await uploadNewVersionDialog.isCancelButtonEnabled()).toBe(true, 'Cancel button not enabled');
expect(await uploadNewVersionDialog.isUploadButtonEnabled()).toBe(true, 'Update button not enabled');
});
it('[C297559] file is updated after uploading a new version - major', async () => {
await dataTable.selectItem(file1, parentRF);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
await uploadNewVersionDialog.majorOption.click();
await uploadNewVersionDialog.enterDescription('new major version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload1, parentRF)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(file1Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file1Id)).toEqual('2.0', 'File has incorrect version label');
});
it('[C297560] file is updated after uploading a new version - minor', async () => {
await dataTable.selectItem(file2, parentRF);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload2);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new minor version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload2, parentRF)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(file2Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file2Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C297561] file is not updated when clicking Cancel', async () => {
await dataTable.selectItem(file3, parentRF);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload3);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(file3, parentRF)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(file3Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file3Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C297562] upload new version fails when new file name already exists', async () => {
await dataTable.selectItem(file4, parentRF);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(file);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
const message = await page.getSnackBarMessage();
expect(message).toContain(nameConflictMessage);
expect(await dataTable.isItemPresent(file4, parentRF)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(file4Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file4Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C297563] file is unlocked after uploading a new version', async () => {
await dataTable.selectItem(fileLocked1, parentRF);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload4);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload4, parentRF)).toBe(true, 'File name was not changed');
expect(await apis.user.nodes.isFileLockedWrite(fileLocked1Id)).toBe(false, `${fileLocked1} is still locked`);
expect(await apis.user.nodes.getFileVersionType(fileLocked1Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileLocked1Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C297564] file remains locked after canceling of uploading a new version', async () => {
await dataTable.selectItem(fileLocked2, parentRF);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload5);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(fileToUpload5, parentRF)).toBe(false, 'File was updated');
expect(await dataTable.isItemPresent(fileLocked2, parentRF)).toBe(true, 'File not displayed');
expect(await apis.user.nodes.isFileLockedWrite(fileLocked2Id)).toBe(true, `${fileLocked2} was unlocked`);
});
});
describe('on Favorite Files', () => {
beforeAll(async () => {
const initialFavoritesTotalItems = await apis.user.favorites.getFavoritesTotalItems();
fileId = (await apis.user.upload.uploadFile(file, parentFavId)).entry.id;
file1Id = await apis.user.createFile(file1, parentFavId);
file2Id = await apis.user.createFile(file2, parentFavId);
file3Id = await apis.user.createFile(file3, parentFavId);
file4Id = await apis.user.createFile(file4, parentFavId);
fileLocked1Id = await apis.user.createFile(fileLocked1, parentFavId);
fileLocked2Id = await apis.user.createFile(fileLocked2, parentFavId);
await userActions.lockNodes([fileLocked1Id, fileLocked2Id]);
await apis.user.favorites.addFavoritesByIds('file', [fileId, file1Id, file2Id, file3Id, file4Id, fileLocked1Id, fileLocked2Id]);
await apis.user.favorites.waitForApi({ expect: initialFavoritesTotalItems + 7 });
await loginPage.loginWith(username);
});
beforeEach(async () => {
await page.clickFavoritesAndWait();
});
afterEach(async () => {
await page.refresh();
});
it('[C297565] dialog UI defaults', async () => {
await dataTable.selectItem(file);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
expect(await uploadNewVersionDialog.getDialogTitle()).toEqual('Upload New Version');
expect(await uploadNewVersionDialog.description.isDisplayed()).toBe(true, 'Description not displayed');
expect(await uploadNewVersionDialog.minorOption.isDisplayed()).toBe(true, 'Minor option not displayed');
expect(await uploadNewVersionDialog.majorOption.isDisplayed()).toBe(true, 'Major option not displayed');
expect(await uploadNewVersionDialog.isCancelButtonEnabled()).toBe(true, 'Cancel button not enabled');
expect(await uploadNewVersionDialog.isUploadButtonEnabled()).toBe(true, 'Update button not enabled');
});
it('[C297566] file is updated after uploading a new version - major', async () => {
await dataTable.selectItem(file1);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload1);
await page.waitForDialog();
await uploadNewVersionDialog.majorOption.click();
await uploadNewVersionDialog.enterDescription('new major version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload1)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(file1Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file1Id)).toEqual('2.0', 'File has incorrect version label');
});
it('[C297567] file is updated after uploading a new version - minor', async () => {
await dataTable.selectItem(file2);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload2);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new minor version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload2)).toBe(true, 'File not updated');
expect(await apis.user.nodes.getFileVersionType(file2Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file2Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C297568] file is not updated when clicking Cancel', async () => {
await dataTable.selectItem(file3);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload3);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(file3)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(file3Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file3Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C297569] upload new version fails when new file name already exists', async () => {
await dataTable.selectItem(file4);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(file);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
const message = await page.getSnackBarMessage();
expect(message).toContain(nameConflictMessage);
expect(await dataTable.isItemPresent(file4)).toBe(true, 'File was updated');
expect(await apis.user.nodes.getFileVersionType(file4Id)).toEqual('MAJOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(file4Id)).toEqual('1.0', 'File has incorrect version label');
});
it('[C297570] file is unlocked after uploading a new version', async () => {
await dataTable.selectItem(fileLocked1);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload4);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.uploadButton.click();
await uploadNewVersionDialog.waitForDialogToClose();
expect(await dataTable.isItemPresent(fileToUpload4)).toBe(true, 'File name was not changed');
expect(await apis.user.nodes.isFileLockedWrite(fileLocked1Id)).toBe(false, `${fileLocked1} is still locked`);
expect(await apis.user.nodes.getFileVersionType(fileLocked1Id)).toEqual('MINOR', 'File has incorrect version type');
expect(await apis.user.nodes.getFileVersionLabel(fileLocked1Id)).toEqual('1.1', 'File has incorrect version label');
});
it('[C297571] file remains locked after canceling of uploading a new version', async () => {
await dataTable.selectItem(fileLocked2);
await toolbar.clickMoreActionsUploadNewVersion();
await Utils.uploadFileNewVersion(fileToUpload5);
await page.waitForDialog();
await uploadNewVersionDialog.minorOption.click();
await uploadNewVersionDialog.enterDescription('new version description');
await uploadNewVersionDialog.clickCancel();
expect(await dataTable.isItemPresent(fileToUpload5)).toBe(false, 'File was updated');
expect(await dataTable.isItemPresent(fileLocked2)).toBe(true, 'File not displayed');
expect(await apis.user.nodes.isFileLockedWrite(fileLocked2Id)).toBe(true, `${fileLocked2} was unlocked`);
});
});
});

View File

@ -42,6 +42,7 @@ export class AcaHeader extends BaseComponent {
public uploadButton = this.getChild('button[id="app.toolbar.upload"]'); public uploadButton = this.getChild('button[id="app.toolbar.upload"]');
public uploadFileButton = this.page.locator('button[id="app.create.uploadFile"]'); public uploadFileButton = this.page.locator('button[id="app.create.uploadFile"]');
public uploadInput = this.page.locator('input[id="app-upload-files"]'); public uploadInput = this.page.locator('input[id="app-upload-files"]');
public uploadNewVersionButton = this.page.locator('#app-upload-file-version');
public permanentlyDeleteButton = this.getChild('button[id="app.toolbar.purgeDeletedNodes"]'); public permanentlyDeleteButton = this.getChild('button[id="app.toolbar.purgeDeletedNodes"]');
public restoreButton = this.getChild('button[id="app.toolbar.restoreDeletedNodes"]'); public restoreButton = this.getChild('button[id="app.toolbar.restoreDeletedNodes"]');

View File

@ -31,7 +31,9 @@ export class UploadNewVersionDialog extends BaseComponent {
public cancelButton = this.getChild('#adf-new-version-cancel'); public cancelButton = this.getChild('#adf-new-version-cancel');
public uploadButton = this.getChild('[data-automation-id="adf-new-version-file-upload"]'); public uploadButton = this.getChild('[data-automation-id="adf-new-version-file-upload"]');
public majorOption = this.getChild('#adf-new-version-major'); public majorOption = this.getChild('#adf-new-version-major');
public minorOption = this.getChild('#adf-new-version-minor');
public description = this.getChild('#adf-new-version-text-area'); public description = this.getChild('#adf-new-version-text-area');
public title = this.getChild(' .mat-dialog-title');
constructor(page: Page) { constructor(page: Page) {
super(page, UploadNewVersionDialog.rootElement); super(page, UploadNewVersionDialog.rootElement);

View File

@ -37,6 +37,7 @@ export class ViewerComponent extends BaseComponent {
public shareButton = this.getChild('button[id="share-action-button"]'); public shareButton = this.getChild('button[id="share-action-button"]');
public downloadButton = this.getChild('button[id="app.viewer.download"]'); public downloadButton = this.getChild('button[id="app.viewer.download"]');
public allButtons = this.getChild('button'); public allButtons = this.getChild('button');
public unknownFormat = this.getChild(`adf-viewer-unknown-format .adf-viewer__unknown-format-view`);
toolbar = new AcaHeader(this.page); toolbar = new AcaHeader(this.page);
@ -51,8 +52,8 @@ export class ViewerComponent extends BaseComponent {
async waitForViewerToOpen(waitForViewerContent?: 'wait for viewer content'): Promise<void> { async waitForViewerToOpen(waitForViewerContent?: 'wait for viewer content'): Promise<void> {
await this.viewerLocator.waitFor({ state: 'visible', timeout: timeouts.medium }); await this.viewerLocator.waitFor({ state: 'visible', timeout: timeouts.medium });
if(waitForViewerContent) { if (waitForViewerContent) {
await this.spinnerWaitForReload(); await this.spinnerWaitForReload();
} }
} }
@ -99,4 +100,12 @@ export class ViewerComponent extends BaseComponent {
expect(actualPrimaryActions.includes(action), `Expected to contain ${action}`).toBe(true); expect(actualPrimaryActions.includes(action), `Expected to contain ${action}`).toBe(true);
} }
} }
async checkUnknownFormatIsDisplayed(): Promise<void> {
await this.unknownFormat.waitFor({ state: 'visible', timeout: timeouts.normal });
}
async getUnknownFormatMessage(): Promise<string> {
return this.unknownFormat.locator(`.adf-viewer__unknown-label`).innerText();
}
} }

View File

@ -41,7 +41,7 @@ import {
SearchFiltersProperties SearchFiltersProperties
} from '../components'; } from '../components';
import { AcaHeader } from '../components/aca-header.component'; import { AcaHeader } from '../components/aca-header.component';
import { AdfConfirmDialogComponent, AdfFolderDialogComponent, ManageVersionsDialog } from '../components/dialogs'; import { AdfConfirmDialogComponent, AdfFolderDialogComponent, UploadNewVersionDialog, ManageVersionsDialog } from '../components/dialogs';
export type SearchType = 'files' | 'folders' | 'filesAndFolders' | 'libraries'; export type SearchType = 'files' | 'folders' | 'filesAndFolders' | 'libraries';
@ -69,6 +69,7 @@ export class SearchPage extends BasePage {
public searchFiltersLogic = new SearchFiltersLogic(this.page); public searchFiltersLogic = new SearchFiltersLogic(this.page);
public sidenav = new SidenavComponent(this.page); public sidenav = new SidenavComponent(this.page);
public confirmDialogComponent = new AdfConfirmDialogComponent(this.page); public confirmDialogComponent = new AdfConfirmDialogComponent(this.page);
public uploadNewVersionDialog = new UploadNewVersionDialog(this.page);
public manageVersionsDialog = new ManageVersionsDialog(this.page); public manageVersionsDialog = new ManageVersionsDialog(this.page);
async searchWithin(searchText: string, searchType: SearchType): Promise<void> { async searchWithin(searchText: string, searchType: SearchType): Promise<void> {

View File

@ -38,11 +38,12 @@ export const TEST_FILES = {
PDF: { PDF: {
path: resolve(__dirname, 'file-pdf.pdf'), path: resolve(__dirname, 'file-pdf.pdf'),
name: 'file-pdf', name: 'file-pdf',
extension: 'pdf',
data: 'Lorem ipsum dolor sit amet' data: 'Lorem ipsum dolor sit amet'
}, },
FILE_UNSUPPORTED: { FILE_UNSUPPORTED: {
path: resolve(__dirname, 'file_unsupported.3DS'), path: resolve(__dirname, 'file_unsupported.3DS'),
name: 'file-3DS', name: 'file_unsupported.3DS',
data: 'Lorem ipsum dolor sit amet' data: 'Lorem ipsum dolor sit amet'
}, },
PDF_PROTECTED: { PDF_PROTECTED: {