diff --git a/cypress/e2e/consortia/bulk-edit/in-app/bulk-edit-in-app-holdings-electronic-access-replace-with-action-in-central-tenant.cy.js b/cypress/e2e/consortia/bulk-edit/in-app/bulk-edit-in-app-holdings-electronic-access-replace-with-action-in-central-tenant.cy.js new file mode 100644 index 0000000000..6cc8eadfb7 --- /dev/null +++ b/cypress/e2e/consortia/bulk-edit/in-app/bulk-edit-in-app-holdings-electronic-access-replace-with-action-in-central-tenant.cy.js @@ -0,0 +1,486 @@ +import permissions from '../../../../support/dictionary/permissions'; +import BulkEditActions from '../../../../support/fragments/bulk-edit/bulk-edit-actions'; +import BulkEditSearchPane from '../../../../support/fragments/bulk-edit/bulk-edit-search-pane'; +import BulkEditFiles from '../../../../support/fragments/bulk-edit/bulk-edit-files'; +import InventoryInstances from '../../../../support/fragments/inventory/inventoryInstances'; +import TopMenu from '../../../../support/fragments/topMenu'; +import Users from '../../../../support/fragments/users/users'; +import FileManager from '../../../../support/utils/fileManager'; +import getRandomPostfix from '../../../../support/utils/stringTools'; +import ExportFile from '../../../../support/fragments/data-export/exportFile'; +import InventorySearchAndFilter from '../../../../support/fragments/inventory/inventorySearchAndFilter'; +import InventoryHoldings from '../../../../support/fragments/inventory/holdings/inventoryHoldings'; +import InventoryInstance from '../../../../support/fragments/inventory/inventoryInstance'; +import HoldingsRecordView from '../../../../support/fragments/inventory/holdingsRecordView'; +import UrlRelationship from '../../../../support/fragments/settings/inventory/instance-holdings-item/urlRelationship'; +import UrlRelationshipConsortiumManager from '../../../../support/fragments/consortium-manager/inventory/instances-holdings-items/urlRelationshipConsortiumManager'; +import ConsortiumManager from '../../../../support/fragments/settings/consortium-manager/consortium-manager'; +import Affiliations, { tenantNames } from '../../../../support/dictionary/affiliations'; +import { APPLICATION_NAMES, BULK_EDIT_TABLE_COLUMN_HEADERS } from '../../../../support/constants'; +import TopMenuNavigation from '../../../../support/fragments/topMenuNavigation'; + +let user; +let instanceTypeId; +let locationId; +let sourceId; +let sharedUrlRelationshipData; +const collegeHoldingIds = []; +const collegeHoldingHrids = []; +const universityHoldingIds = []; +const universityHoldingHrids = []; +const folioInstance = { + title: `C494359 folio instance testBulkEdit_${getRandomPostfix()}`, +}; +const marcInstance = { + title: `C494359 marc instance testBulkEdit_${getRandomPostfix()}`, +}; +const sharedUrlRelationship = { + payload: { + name: `C494359 shared urlRelationship ${getRandomPostfix()}`, + }, +}; +const localUrlRelationship = { + name: `C494359 local urlRelationship ${getRandomPostfix()}`, +}; +const localUrlRelationshipNameWithAffiliation = `${localUrlRelationship.name} (${Affiliations.College})`; +const newUri = 'https://www.NewUri.org'; +const newLinkText = 'New Link text'; +const newMaterialSpecified = 'New Materials specified'; +const newUrlPublicNote = 'New URL public note'; +const instances = [folioInstance, marcInstance]; +const electronicAccessTableHeaders = 'RelationshipURILink textMaterials specifiedPublic note'; +const electronicAccessTableHeadersInFile = + 'URL relationship;URI;Link text;Materials specified;URL public note\n'; +const holdingUUIDsFileName = `holdingUUIdsFileName_${getRandomPostfix()}.csv`; +const matchedRecordsFileName = `*-Matched-Records-${holdingUUIDsFileName}`; +const previewFileName = `*-Updates-Preview-${holdingUUIDsFileName}`; +const changedRecordsFileName = `*-Changed-Records-${holdingUUIDsFileName}`; +const errorsFromCommittingFileName = `*-Committing-changes-Errors-${holdingUUIDsFileName}`; +const getReasonForError = (holdingId) => { + return `${holdingId} cannot be updated because the record is associated with ${Affiliations.University} and URL relationship is not associated with this tenant.`; +}; +const getRowsInCsvFileMatchingHrids = (csvFileData, hrids) => { + return csvFileData.filter((row) => { + return hrids.some((hrid) => { + return row[BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.HOLDINGS_HRID].includes(hrid); + }); + }); +}; + +describe('Bulk-edit', () => { + describe('In-app approach', () => { + describe('Consortia', () => { + before('create test data', () => { + cy.clearLocalStorage(); + cy.getAdminToken(); + cy.createTempUser([ + permissions.bulkEditEdit.gui, + permissions.uiInventoryViewCreateEditHoldings.gui, + ]).then((userProperties) => { + user = userProperties; + + cy.assignAffiliationToUser(Affiliations.College, user.userId); + cy.setTenant(Affiliations.College); + cy.assignPermissionsToExistingUser(user.userId, [ + permissions.bulkEditEdit.gui, + permissions.uiInventoryViewCreateEditHoldings.gui, + ]); + + cy.resetTenant(); + cy.assignAffiliationToUser(Affiliations.University, user.userId); + cy.setTenant(Affiliations.University); + cy.assignPermissionsToExistingUser(user.userId, [ + permissions.bulkEditEdit.gui, + permissions.uiInventoryViewCreateEditHoldings.gui, + ]); + + cy.resetTenant(); + cy.getInstanceTypes({ limit: 1 }).then((instanceTypeData) => { + instanceTypeId = instanceTypeData[0].id; + }); + cy.getLocations({ query: 'name="DCB"' }).then((res) => { + locationId = res.id; + }); + InventoryHoldings.getHoldingsFolioSource().then((folioSource) => { + sourceId = folioSource.id; + }); + UrlRelationshipConsortiumManager.createViaApi(sharedUrlRelationship) + .then((newUrlRelationship) => { + sharedUrlRelationshipData = newUrlRelationship; + }) + .then(() => { + // create shared folio instance + InventoryInstances.createFolioInstanceViaApi({ + instance: { + instanceTypeId, + title: folioInstance.title, + }, + }).then((createdInstanceData) => { + folioInstance.id = createdInstanceData.instanceId; + }); + }) + .then(() => { + // create shared marc instance + cy.createSimpleMarcBibViaAPI(marcInstance.title).then((instanceId) => { + marcInstance.id = instanceId; + }); + }) + .then(() => { + cy.setTenant(Affiliations.College); + // create local url relationship in College + UrlRelationship.createViaApi({ + name: localUrlRelationship.name, + source: 'local', + }).then((response) => { + localUrlRelationship.id = response.id; + }); + // create holdings in College tenant + instances.forEach((instance) => { + InventoryHoldings.createHoldingRecordViaApi({ + instanceId: instance.id, + permanentLocationId: locationId, + electronicAccess: [ + { + linkText: 'College link text', + materialsSpecification: 'College materials specified', + publicNote: 'College url public note', + uri: 'https://college-uri.com', + relationshipId: sharedUrlRelationship.settingId, + }, + ], + sourceId, + }).then((holding) => { + collegeHoldingIds.push(holding.id); + collegeHoldingHrids.push(holding.hrid); + }); + cy.wait(1000); + }); + }) + .then(() => { + // create holdings in University tenant + cy.setTenant(Affiliations.University); + + instances.forEach((instance) => { + InventoryHoldings.createHoldingRecordViaApi({ + instanceId: instance.id, + permanentLocationId: locationId, + electronicAccess: [ + { + linkText: 'University link text', + materialsSpecification: 'University materials specified', + publicNote: 'University url public note', + uri: 'https://university-uri.com', + relationshipId: sharedUrlRelationship.settingId, + }, + ], + sourceId, + }).then((holding) => { + universityHoldingIds.push(holding.id); + universityHoldingHrids.push(holding.hrid); + }); + cy.wait(1000); + }); + }) + .then(() => { + FileManager.createFile( + `cypress/fixtures/${holdingUUIDsFileName}`, + `${collegeHoldingIds.join('\n')}\n${universityHoldingIds.join('\n')}`, + ); + }); + + cy.login(user.username, user.password, { + path: TopMenu.bulkEditPath, + waiter: BulkEditSearchPane.waitLoading, + }); + ConsortiumManager.checkCurrentTenantInTopMenu(tenantNames.central); + }); + }); + + after('delete test data', () => { + cy.resetTenant(); + cy.getAdminToken(); + cy.setTenant(Affiliations.College); + UrlRelationship.deleteViaApi(localUrlRelationship.id); + + collegeHoldingIds.forEach((collegeHoldingId) => { + cy.deleteHoldingRecordViaApi(collegeHoldingId); + }); + + cy.setTenant(Affiliations.University); + + universityHoldingIds.forEach((universityHoldingId) => { + cy.deleteHoldingRecordViaApi(universityHoldingId); + }); + + cy.resetTenant(); + cy.getAdminToken(); + + instances.forEach((instance) => { + InventoryInstance.deleteInstanceViaApi(instance.id); + }); + + UrlRelationshipConsortiumManager.deleteViaApi(sharedUrlRelationshipData); + Users.deleteViaApi(user.userId); + FileManager.deleteFile(`cypress/fixtures/${holdingUUIDsFileName}`); + FileManager.deleteFileFromDownloadsByMask( + matchedRecordsFileName, + previewFileName, + changedRecordsFileName, + errorsFromCommittingFileName, + ); + }); + + it( + 'C494359 Verify "Replace with" action for Holdings electronic access in Central tenant (consortia) (firebird)', + { tags: ['smokeECS', 'firebird', 'C494359'] }, + () => { + BulkEditSearchPane.verifyDragNDropRecordTypeIdentifierArea('Holdings', 'Holdings UUIDs'); + BulkEditSearchPane.uploadFile(holdingUUIDsFileName); + BulkEditSearchPane.verifyPaneTitleFileName(holdingUUIDsFileName); + BulkEditSearchPane.verifyPaneRecordsCount(4); + BulkEditSearchPane.verifyFileNameHeadLine(holdingUUIDsFileName); + + const holdingHrids = [...collegeHoldingHrids, ...universityHoldingHrids]; + + holdingHrids.forEach((holdingHrid) => { + BulkEditSearchPane.verifyExactChangesUnderColumnsByIdentifierInResultsAccordion( + holdingHrid, + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.HOLDINGS_HRID, + holdingHrid, + ); + }); + + BulkEditSearchPane.verifyPreviousPaginationButtonDisabled(); + BulkEditSearchPane.verifyNextPaginationButtonDisabled(); + BulkEditActions.openActions(); + BulkEditSearchPane.changeShowColumnCheckbox( + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + ); + BulkEditSearchPane.verifyCheckboxesInActionsDropdownMenuChecked( + true, + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + ); + + const collegeHoldingsElectronicAccess = `${electronicAccessTableHeaders}${sharedUrlRelationship.payload.name}https://college-uri.comCollege link textCollege materials specifiedCollege url public note`; + const universityHoldingsElectronicAccess = `${electronicAccessTableHeaders}${sharedUrlRelationship.payload.name}https://university-uri.comUniversity link textUniversity materials specifiedUniversity url public note`; + + collegeHoldingHrids.forEach((holdingHrid) => { + BulkEditSearchPane.verifyExactChangesUnderColumnsByIdentifierInResultsAccordion( + holdingHrid, + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + collegeHoldingsElectronicAccess, + ); + }); + universityHoldingHrids.forEach((holdingHrid) => { + BulkEditSearchPane.verifyExactChangesUnderColumnsByIdentifierInResultsAccordion( + holdingHrid, + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + universityHoldingsElectronicAccess, + ); + }); + + BulkEditSearchPane.changeShowColumnCheckbox( + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + ); + BulkEditSearchPane.verifyCheckboxesInActionsDropdownMenuChecked( + false, + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + ); + BulkEditSearchPane.verifyResultColumnTitlesDoNotIncludeTitles( + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + ); + BulkEditActions.openActions(); + BulkEditActions.downloadMatchedResults(); + + const collegeHoldingsElectronicAccessInFile = `${electronicAccessTableHeadersInFile}${sharedUrlRelationship.payload.name};https://college-uri.com;College link text;College materials specified;College url public note`; + const universityHoldingsElectronicAccessInFile = `${electronicAccessTableHeadersInFile}${sharedUrlRelationship.payload.name};https://university-uri.com;University link text;University materials specified;University url public note`; + + FileManager.convertCsvToJson(matchedRecordsFileName).then((csvFileData) => { + const collegeHoldingRows = getRowsInCsvFileMatchingHrids( + csvFileData, + collegeHoldingHrids, + ); + const universityHoldingRows = getRowsInCsvFileMatchingHrids( + csvFileData, + universityHoldingHrids, + ); + + collegeHoldingRows.forEach((collegeRow) => { + cy.expect( + collegeRow[BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS], + ).to.equal(collegeHoldingsElectronicAccessInFile); + }); + universityHoldingRows.forEach((universityRow) => { + cy.expect( + universityRow[BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS], + ).to.equal(universityHoldingsElectronicAccessInFile); + }); + }); + + BulkEditActions.openInAppStartBulkEditFrom(); + BulkEditSearchPane.verifyBulkEditsAccordionExists(); + BulkEditActions.verifyOptionsDropdown(); + BulkEditActions.verifyRowIcons(); + BulkEditActions.verifyCancelButtonDisabled(false); + BulkEditSearchPane.isConfirmButtonDisabled(true); + BulkEditActions.selectOption('URL Relationship'); + BulkEditActions.selectSecondAction('Replace with'); + BulkEditActions.verifySecondActionSelected('Replace with'); + BulkEditActions.selectFromUnchangedSelect(localUrlRelationshipNameWithAffiliation); + BulkEditSearchPane.isConfirmButtonDisabled(false); + BulkEditActions.addNewBulkEditFilterString(); + BulkEditActions.verifyNewBulkEditRow(1); + BulkEditActions.replaceWithAction('URI', newUri, 1); + BulkEditSearchPane.isConfirmButtonDisabled(false); + BulkEditActions.addNewBulkEditFilterString(); + BulkEditActions.verifyNewBulkEditRow(2); + BulkEditActions.replaceWithAction('Link text', newLinkText, 2); + BulkEditSearchPane.isConfirmButtonDisabled(false); + BulkEditActions.addNewBulkEditFilterString(); + BulkEditActions.verifyNewBulkEditRow(3); + BulkEditActions.replaceWithAction('Materials specified', newMaterialSpecified, 3); + BulkEditSearchPane.isConfirmButtonDisabled(false); + BulkEditActions.addNewBulkEditFilterString(); + BulkEditActions.verifyNewBulkEditRow(4); + BulkEditActions.replaceWithAction('URL public note', newUrlPublicNote, 4); + BulkEditSearchPane.isConfirmButtonDisabled(false); + BulkEditActions.confirmChanges(); + BulkEditActions.verifyMessageBannerInAreYouSureForm(4); + + const updatedHoldingsElectronicAccess = `${electronicAccessTableHeaders}${localUrlRelationship.name}${newUri}${newLinkText}${newMaterialSpecified}${newUrlPublicNote}`; + const updatedHoldingsUniversityElectronicAccess = `${electronicAccessTableHeaders}${sharedUrlRelationship.payload.name}${newUri}${newLinkText}${newMaterialSpecified}${newUrlPublicNote}`; + const updatedHoldingsElectronicAccessInFile = `${electronicAccessTableHeadersInFile}${localUrlRelationship.name};${newUri};${newLinkText};${newMaterialSpecified};${newUrlPublicNote}`; + const updatedHoldingsUniversutyElectronicAccessInFile = `${electronicAccessTableHeadersInFile}${sharedUrlRelationship.payload.name};${newUri};${newLinkText};${newMaterialSpecified};${newUrlPublicNote}`; + + holdingHrids.forEach((holdingHrid) => { + BulkEditSearchPane.verifyExactChangesUnderColumnsByIdentifier( + holdingHrid, + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + updatedHoldingsElectronicAccess, + ); + }); + + BulkEditActions.verifyAreYouSureForm(4); + BulkEditSearchPane.verifyPreviousPaginationButtonInAreYouSureFormDisabled(); + BulkEditSearchPane.verifyNextPaginationButtonInAreYouSureFormDisabled(); + BulkEditActions.downloadPreview(); + + FileManager.convertCsvToJson(previewFileName).then((csvFileData) => { + csvFileData.forEach((row) => { + cy.expect(row).to.have.property( + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + updatedHoldingsElectronicAccessInFile, + ); + }); + }); + + BulkEditActions.commitChanges(); + BulkEditActions.verifySuccessBanner(4); + + collegeHoldingHrids.forEach((holdingHrid) => { + BulkEditSearchPane.verifyExactChangesUnderColumnsByIdentifierInChangesAccordion( + holdingHrid, + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + updatedHoldingsElectronicAccess, + ); + }); + universityHoldingHrids.forEach((holdingHrid) => { + BulkEditSearchPane.verifyExactChangesUnderColumnsByIdentifierInChangesAccordion( + holdingHrid, + BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS, + updatedHoldingsUniversityElectronicAccess, + ); + }); + + BulkEditSearchPane.verifyErrorLabelInErrorAccordion(holdingUUIDsFileName, 4, 4, 2); + BulkEditSearchPane.verifyNonMatchedResults(); + + universityHoldingIds.forEach((universityHoldingId) => { + BulkEditSearchPane.verifyErrorByIdentifier( + universityHoldingId, + getReasonForError(universityHoldingId), + ); + }); + + BulkEditActions.openActions(); + BulkEditActions.downloadChangedCSV(); + + FileManager.convertCsvToJson(changedRecordsFileName).then((csvFileData) => { + const collegeHoldingRows = getRowsInCsvFileMatchingHrids( + csvFileData, + collegeHoldingHrids, + ); + const universityHoldingRows = getRowsInCsvFileMatchingHrids( + csvFileData, + universityHoldingHrids, + ); + + collegeHoldingRows.forEach((collegeRow) => { + cy.expect( + collegeRow[BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS], + ).to.equal(updatedHoldingsElectronicAccessInFile); + }); + universityHoldingRows.forEach((universityRow) => { + cy.expect( + universityRow[BULK_EDIT_TABLE_COLUMN_HEADERS.INVENTORY_HOLDINGS.ELECTRONIC_ACCESS], + ).to.equal(updatedHoldingsUniversutyElectronicAccessInFile); + }); + }); + + BulkEditActions.downloadErrors(); + + universityHoldingIds.forEach((universityHoldingId) => { + ExportFile.verifyFileIncludes(errorsFromCommittingFileName, [ + `${universityHoldingId},${getReasonForError(universityHoldingId)}`, + ]); + }); + + BulkEditFiles.verifyCSVFileRecordsNumber(errorsFromCommittingFileName, 2); + ConsortiumManager.switchActiveAffiliation(tenantNames.central, tenantNames.college); + + collegeHoldingHrids.forEach((collegeHoldingHrid) => { + TopMenuNavigation.navigateToApp(APPLICATION_NAMES.INVENTORY); + InventorySearchAndFilter.switchToHoldings(); + InventorySearchAndFilter.searchHoldingsByHRID(collegeHoldingHrid); + InventorySearchAndFilter.selectViewHoldings(); + HoldingsRecordView.waitLoading(); + + const electronicAccessFieldsToValidateInCollege = [ + localUrlRelationship.name, + newUri, + newLinkText, + newMaterialSpecified, + newUrlPublicNote, + ]; + + electronicAccessFieldsToValidateInCollege.forEach((field, ind) => { + HoldingsRecordView.verifyElectronicAccessByElementIndex(ind, field); + }); + }); + + ConsortiumManager.switchActiveAffiliation(tenantNames.college, tenantNames.university); + + universityHoldingHrids.forEach((universityHoldingHrid) => { + TopMenuNavigation.navigateToApp(APPLICATION_NAMES.INVENTORY); + InventorySearchAndFilter.switchToHoldings(); + InventorySearchAndFilter.searchHoldingsByHRID(universityHoldingHrid); + InventorySearchAndFilter.selectViewHoldings(); + HoldingsRecordView.waitLoading(); + + const electronicAccessFieldsToValidateInUniversity = [ + sharedUrlRelationship.payload.name, + newUri, + newLinkText, + newMaterialSpecified, + newUrlPublicNote, + ]; + + electronicAccessFieldsToValidateInUniversity.forEach((field, ind) => { + HoldingsRecordView.verifyElectronicAccessByElementIndex(ind, field); + }); + }); + }, + ); + }); + }); +}); diff --git a/cypress/e2e/consortia/bulk-edit/in-app/bulk-edit-in-app-holdings-verify-add-note-in-central.cy.js b/cypress/e2e/consortia/bulk-edit/in-app/bulk-edit-in-app-holdings-verify-add-note-in-central.cy.js index b420cfadf0..fe124b055e 100644 --- a/cypress/e2e/consortia/bulk-edit/in-app/bulk-edit-in-app-holdings-verify-add-note-in-central.cy.js +++ b/cypress/e2e/consortia/bulk-edit/in-app/bulk-edit-in-app-holdings-verify-add-note-in-central.cy.js @@ -32,8 +32,6 @@ let centralSharedNoteTypeData; const callNumberStarts = `${randomFourDigitNumber()}`; const folioInstance = { title: `C477646 folio instance testBulkEdit_${getRandomPostfix()}`, - barcodeInCollege: `Item_College${getRandomPostfix()}`, - barcodeInUniversity: `Item_University${getRandomPostfix()}`, holdingCallNumberInCollege: `${callNumberStarts}${randomFourDigitNumber()}`, holdingCallNumberInUniversity: `${callNumberStarts}${randomFourDigitNumber()}`, holdingIds: [], @@ -41,8 +39,6 @@ const folioInstance = { }; const marcInstance = { title: `C477646 marc instance testBulkEdit_${getRandomPostfix()}`, - barcodeInCollege: `Item_College${getRandomPostfix()}`, - barcodeInUniversity: `Item_University${getRandomPostfix()}`, holdingCallNumberInCollege: `${callNumberStarts}${randomFourDigitNumber()}`, holdingCallNumberInUniversity: `${callNumberStarts}${randomFourDigitNumber()}`, holdingIds: [], diff --git a/cypress/support/fragments/bulk-edit/bulk-edit-actions.js b/cypress/support/fragments/bulk-edit/bulk-edit-actions.js index 0e91bbe1ac..f7d53fdaa9 100644 --- a/cypress/support/fragments/bulk-edit/bulk-edit-actions.js +++ b/cypress/support/fragments/bulk-edit/bulk-edit-actions.js @@ -787,6 +787,14 @@ export default { ]); }, + replaceWithAction(option, newValue, rowIndex = 0) { + this.selectOption(option, rowIndex); + this.selectSecondAction('Replace with', rowIndex); + this.verifySecondActionSelected('Replace with', rowIndex); + this.fillInSecondTextArea(newValue, rowIndex); + this.verifyValueInSecondTextArea(newValue, rowIndex); + }, + noteReplaceWith(noteType, oldNote, newNote, rowIndex = 0) { this.findValue(noteType, rowIndex); this.fillInFirstTextArea(oldNote, rowIndex); diff --git a/cypress/support/fragments/consortium-manager/inventory/instances-holdings-items/urlRelationshipConsortiumManager.js b/cypress/support/fragments/consortium-manager/inventory/instances-holdings-items/urlRelationshipConsortiumManager.js new file mode 100644 index 0000000000..7375c5c5da --- /dev/null +++ b/cypress/support/fragments/consortium-manager/inventory/instances-holdings-items/urlRelationshipConsortiumManager.js @@ -0,0 +1,37 @@ +import uuid from 'uuid'; +import { REQUEST_METHOD } from '../../../../constants'; + +const id = uuid(); + +export default { + createViaApi(type) { + return cy.getConsortiaId().then((consortiaId) => { + cy.okapiRequest({ + method: REQUEST_METHOD.POST, + path: `consortia/${consortiaId}/sharing/settings`, + body: { + url: '/electronic-access-relationships', + settingId: id, + payload: { + id, + name: type.payload.name, + }, + }, + }).then(() => { + type.url = '/electronic-access-relationships'; + type.settingId = id; + return type; + }); + }); + }, + + deleteViaApi(type) { + cy.getConsortiaId().then((consortiaId) => { + cy.okapiRequest({ + method: REQUEST_METHOD.DELETE, + path: `consortia/${consortiaId}/sharing/settings/${type.settingId}`, + body: type, + }); + }); + }, +}; diff --git a/cypress/support/fragments/settings/inventory/instance-holdings-item/urlRelationship.js b/cypress/support/fragments/settings/inventory/instance-holdings-item/urlRelationship.js index 43904fdc20..10a0b3e1c4 100644 --- a/cypress/support/fragments/settings/inventory/instance-holdings-item/urlRelationship.js +++ b/cypress/support/fragments/settings/inventory/instance-holdings-item/urlRelationship.js @@ -38,6 +38,28 @@ function getListOfURLRelationship() { export default { getListOfURLRelationship, + createViaApi(type) { + return cy + .okapiRequest({ + method: 'POST', + path: 'electronic-access-relationships', + body: type, + isDefaultSearchParamsRequired: false, + }) + .then((response) => { + return response.body; + }); + }, + + deleteViaApi(id) { + return cy.okapiRequest({ + method: 'DELETE', + path: `electronic-access-relationships/${id}`, + isDefaultSearchParamsRequired: false, + failOnStatusCode: false, + }); + }, + openTabFromInventorySettingsList() { cy.do(NavListItem('Inventory').click()); cy.do(NavListItem('URL relationship').click());