diff --git a/e2e/helpers/extensions.js b/e2e/helpers/extensions.js index 4a6f9d329..186e0dddd 100644 --- a/e2e/helpers/extensions.js +++ b/e2e/helpers/extensions.js @@ -315,6 +315,20 @@ let actions = { }) .then(done) .catch(done); + }, + + autocompleteSearch: function(autocompleteSelector, searchValue, done) { + this.wait(autocompleteSelector) + .waitToClick(`${autocompleteSelector} input`) + .type(`${autocompleteSelector} vn-drop-down input`, searchValue) + .waitToClick(`${autocompleteSelector} li.active`) + .wait((autocompleteSelector, searchValue) => { + return document.querySelector(`${autocompleteSelector} input`).value.toLowerCase().includes(searchValue.toLowerCase()); + }, autocompleteSelector, searchValue) + .then(done) + .catch(() => { + done(new Error(`.autocompleteSearch() for ${autocompleteSelector}, timed out`)); + }); } }; diff --git a/e2e/helpers/selectors.js b/e2e/helpers/selectors.js index 75135581a..b96ff7798 100644 --- a/e2e/helpers/selectors.js +++ b/e2e/helpers/selectors.js @@ -28,8 +28,7 @@ export default { socialName: `${components.vnTextfield}[name="socialName"]`, userName: `${components.vnTextfield}[name="userName"]`, email: `${components.vnTextfield}[name="email"]`, - salesPersonInput: `vn-autocomplete[field="$ctrl.client.salesPersonFk"] input`, - salesBruceBannerOption: `vn-autocomplete[field="$ctrl.client.salesPersonFk"] vn-drop-down ul > li:nth-child(1)`, + salesPersonAutocomplete: `vn-autocomplete[field="$ctrl.client.salesPersonFk"]`, createButton: `${components.vnSubmit}`, cancelButton: `vn-button[href="#!/client/index"]` }, @@ -41,11 +40,8 @@ export default { mobileInput: `${components.vnTextfield}[name="mobile"]`, faxInput: `${components.vnTextfield}[name="fax"]`, emailInput: `${components.vnTextfield}[name="email"]`, - salesPersonInput: `vn-autocomplete[field="$ctrl.client.salesPersonFk"] input`, - salesPersonOptionOne: `vn-autocomplete[field="$ctrl.client.salesPersonFk"] vn-drop-down ul > li:nth-child(1)`, - channelInput: `vn-autocomplete[field="$ctrl.client.contactChannelFk"] input`, - channelMetropolisOption: `vn-autocomplete[field="$ctrl.client.contactChannelFk"] vn-drop-down ul > li:nth-child(3)`, - channelRumorsOption: `vn-autocomplete[field="$ctrl.client.contactChannelFk"] vn-drop-down ul > li:nth-child(4)`, + salesPersonAutocomplete: `vn-autocomplete[field="$ctrl.client.salesPersonFk"]`, + channelAutocomplete: `vn-autocomplete[field="$ctrl.client.contactChannelFk"]`, saveButton: `${components.vnSubmit}` }, clientFiscalData: { @@ -57,10 +53,8 @@ export default { addressInput: `${components.vnTextfield}[name="street"]`, cityInput: `${components.vnTextfield}[name="city"]`, postcodeInput: `${components.vnTextfield}[name="postcode"]`, - provinceInput: `vn-autocomplete[field="$ctrl.client.provinceFk"] input`, - provinceFifthOption: `vn-autocomplete[field="$ctrl.client.provinceFk"] vn-drop-down ul > li:nth-child(5)`, - countryInput: `vn-autocomplete[field="$ctrl.client.countryFk"] input`, - countryThirdOption: `vn-autocomplete[field="$ctrl.client.countryFk"] vn-drop-down ul > li:nth-child(3)`, + provinceAutocomplete: `vn-autocomplete[field="$ctrl.client.provinceFk"]`, + countryAutocomplete: `vn-autocomplete[field="$ctrl.client.countryFk"]`, activeCheckboxLabel: `vn-check[label="Active"] > label`, activeCheckboxInput: `vn-check[label="Active"] input`, frozenCheckboxLabel: `vn-check[label="Frozen"] > label`, @@ -77,15 +71,13 @@ export default { }, clientPayMethod: { payMethodButton: `vn-left-menu a[ui-sref="client.card.billingData"]`, - payMethodInput: `vn-autocomplete[field="$ctrl.client.payMethodFk"] input`, - payMethodIBANOption: `vn-autocomplete[field="$ctrl.client.payMethodFk"] vn-drop-down ul > li:nth-child(5)`, - payMethodOptionOne: `vn-autocomplete[field="$ctrl.client.payMethodFk"] vn-drop-down ul > li:nth-child(2)`, + payMethodAutocomplete: `vn-autocomplete[field="$ctrl.client.payMethodFk"]`, IBANInput: `${components.vnTextfield}[name="iban"]`, dueDayInput: `${components.vnTextfield}[name="dueDay"]`, receivedCoreLCRCheckbox: `vn-check[label='Received LCR'] > label > input`, receivedCoreVNLCheckbox: `vn-check[label='Received core VNL'] > label > input`, receivedB2BVNLCheckbox: `vn-check[label='Received B2B VNL'] > label > input`, - swiftBicInput: 'vn-client-billing-data vn-autocomplete[field="$ctrl.client.bankEntityFk"] input', + swiftBicAutocomplete: 'vn-client-billing-data vn-autocomplete[field="$ctrl.client.bankEntityFk"]', firstSwiftBicOption: `vn-client-billing-data vn-autocomplete[field="$ctrl.client.bankEntityFk"] vn-drop-down ul > li:nth-child(1)`, clearswiftBicButton: `vn-client-billing-data vn-autocomplete[field="$ctrl.client.bankEntityFk"] > div > div > div > vn-icon > i`, newBankEntityButton: 'vn-client-billing-data vn-icon-button[vn-tooltip="New bank entity"] > button', @@ -102,10 +94,8 @@ export default { streetAddressInput: `${components.vnTextfield}[name="street"]`, postcodeInput: `${components.vnTextfield}[name="postalCode"]`, cityInput: `${components.vnTextfield}[name="city"]`, - provinceInput: `vn-autocomplete[field="$ctrl.address.provinceFk"] input`, - provinceSecondOption: `vn-autocomplete[field="$ctrl.address.provinceFk"] vn-drop-down ul > li:nth-child(2)`, - agencyInput: `vn-autocomplete[field="$ctrl.address.agencyModeFk"] input`, - agenctySecondOption: `vn-autocomplete[field="$ctrl.address.agencyModeFk"] vn-drop-down ul > li:nth-child(2)`, + provinceAutocomplete: `vn-autocomplete[field="$ctrl.address.provinceFk"]`, + agencyAutocomplete: `vn-autocomplete[field="$ctrl.address.agencyModeFk"]`, phoneInput: `${components.vnTextfield}[name="phone"]`, mobileInput: `${components.vnTextfield}[name="mobile"]`, defaultAddress: 'vn-client-address-index vn-horizontal:nth-child(2) div[name="street"]', @@ -114,15 +104,10 @@ export default { secondEditButton: `vn-client-address-index vn-horizontal:nth-child(3) vn-icon-button[icon='edit']`, activeCheckbox: `vn-check[label='Enabled'] > label > input`, equalizationTaxCheckboxLabel: `vn-client-address-edit vn-check[label='Is equalizated'] > label > input`, - firstObservationTypeSelect: `vn-client-address-edit [name=observations] :nth-child(1) [field="observation.observationTypeFk"] input`, - firstObservationTypeSelectOptionOne: `vn-client-address-edit [name=observations] :nth-child(1) [field="observation.observationTypeFk"] vn-drop-down ul > li:nth-child(1)`, + firstObservationTypeAutocomplete: `vn-client-address-edit [name=observations] :nth-child(1) [field="observation.observationTypeFk"]`, firstObservationDescriptionInput: `vn-client-address-edit [name=observations] :nth-child(1) [model="observation.description"] input`, - secondObservationTypeSelect: `vn-client-address-edit [name=observations] :nth-child(2) [field="observation.observationTypeFk"] input`, - secondObservationTypeSelectOptionTwo: `vn-client-address-edit [name=observations] :nth-child(2) [field="observation.observationTypeFk"] vn-drop-down ul > li:nth-child(2)`, + secondObservationTypeAutocomplete: `vn-client-address-edit [name=observations] :nth-child(2) [field="observation.observationTypeFk"]`, secondObservationDescriptionInput: `vn-client-address-edit [name=observations] :nth-child(2) [model="observation.description"] input`, - thirdObservationTypeSelect: `vn-client-address-edit [name=observations] :nth-child(3) [field="observation.observationTypeFk"] input`, - thirdObservationTypeSelectOptionThree: `vn-client-address-edit [name=observations] :nth-child(3) [field="observation.observationTypeFk"] vn-drop-down ul > li:nth-child(3)`, - thirdObservationDescriptionInput: `vn-client-address-edit [name=observations] :nth-child(3) [model="observation.description"] input`, addObservationButton: `vn-client-address-edit vn-icon-button[icon="add_circle"]`, saveButton: `${components.vnSubmit}`, cancelButton: `button[ui-sref="client.card.address.index"]` @@ -152,8 +137,7 @@ export default { addGreugeFloatButton: `${components.vnFloatButton}`, amountInput: `${components.vnTextfield}[name="amount"]`, descriptionInput: `${components.vnTextfield}[name="description"]`, - typeInput: `vn-autocomplete[field="$ctrl.greuge.greugeTypeFk"] input`, - typeSecondOption: `vn-autocomplete[field="$ctrl.greuge.greugeTypeFk"] vn-drop-down ul > li`, + typeAutocomplete: `vn-autocomplete[field="$ctrl.greuge.greugeTypeFk"]`, saveButton: `${components.vnSubmit}`, firstGreugeText: 'vn-client-greuge-index vn-card > div vn-table vn-tbody > vn-tr' }, @@ -193,12 +177,9 @@ export default { }, itemCreateView: { name: `${components.vnTextfield}[name="name"]`, - typeSelect: `vn-autocomplete[field="$ctrl.item.typeFk"] input`, - typeSelectOptionThree: `vn-autocomplete[field="$ctrl.item.typeFk"] vn-drop-down ul > li:nth-child(3)`, - intrastatSelect: `vn-autocomplete[field="$ctrl.item.intrastatFk"] input`, - intrastatSelectOptionOne: `vn-autocomplete[field="$ctrl.item.intrastatFk"] vn-drop-down ul > li:nth-child(2)`, - originSelect: `vn-autocomplete[field="$ctrl.item.originFk"] input`, - originSelectOptionOne: `vn-autocomplete[field="$ctrl.item.originFk"] vn-drop-down ul > li:nth-child(2)`, + typeAutocomplete: `vn-autocomplete[field="$ctrl.item.typeFk"]`, + intrastatAutocomplete: `vn-autocomplete[field="$ctrl.item.intrastatFk"]`, + originAutocomplete: `vn-autocomplete[field="$ctrl.item.originFk"]`, createButton: `${components.vnSubmit}`, cancelButton: `button[ui-sref="item.index"]` }, @@ -206,24 +187,19 @@ export default { moreMenu: `vn-item-descriptor > vn-card > div vn-icon-menu > div > vn-icon`, moreMenuRegularizeButton: `vn-item-descriptor vn-icon-menu > div > vn-drop-down > vn-popover ul > li:nth-child(1)`, regularizeQuantityInput: `vn-item-descriptor > vn-dialog > div > form > div.body > tpl-body > div > vn-textfield > div > div > div.infix > input`, - regularizeWarehouseSelect: `#warehouse > div > div > input`, - regularizeWarehouseSelectSecondOption: `#warehouse > vn-drop-down > vn-popover > div > div.content > div > div.list > ul > li:nth-child(2)`, + regularizeWarehouseAutocomplete: `#warehouse`, regularizeSaveButton: `vn-item-descriptor > vn-dialog > div > form > div.buttons > tpl-buttons > button` }, itemBasicData: { goToItemIndexButton: 'vn-item-descriptor [ui-sref="item.index"]', basicDataButton: `vn-left-menu a[ui-sref="item.card.data"]`, - typeSelect: `vn-autocomplete[field="$ctrl.item.typeFk"] input`, - typeSelectOptionThree: `vn-autocomplete[field="$ctrl.item.typeFk"] vn-drop-down ul > li:nth-child(3)`, - intrastatSelect: `vn-autocomplete[field="$ctrl.item.intrastatFk"] input`, - intrastatSelectOptionOne: `vn-autocomplete[field="$ctrl.item.intrastatFk"] vn-drop-down ul > li:nth-child(1)`, + typeAutocomplete: `vn-autocomplete[field="$ctrl.item.typeFk"]`, + intrastatAutocomplete: `vn-autocomplete[field="$ctrl.item.intrastatFk"]`, nameInput: `vn-textfield[label="Name"] input`, relevancyInput: `vn-textfield[label="Relevancy"] input`, - originSelect: `vn-autocomplete[field="$ctrl.item.originFk"] input`, - originSelectOptionTwo: `vn-autocomplete[field="$ctrl.item.originFk"] vn-drop-down ul > li:nth-child(2)`, - expenceSelect: `vn-autocomplete[field="$ctrl.item.expenceFk"] input`, - expenceSelectOptionThree: `vn-autocomplete[field="$ctrl.item.expenceFk"] vn-drop-down ul > li:nth-child(3)`, - longNameInput: `vn-textfield[label="Full name"] input`, + originAutocomplete: `vn-autocomplete[field="$ctrl.item.originFk"]`, + expenceAutocomplete: `vn-autocomplete[field="$ctrl.item.expenceFk"]`, + longNameInput: `vn-textfield[field="$ctrl.item.longName"] input`, isActiveCheckbox: `vn-check[label='Active'] > label > input`, submitBasicDataButton: `${components.vnSubmit}` }, @@ -231,27 +207,22 @@ export default { goToItemIndexButton: 'vn-item-descriptor [ui-sref="item.index"]', tagsButton: `vn-left-menu a[ui-sref="item.card.tags"]`, firstRemoveTagButton: `vn-item-tags vn-horizontal:nth-child(2) vn-icon-button[icon="delete"]`, - firstTagSelect: `vn-item-tags vn-horizontal:nth-child(2) > vn-autocomplete[field="itemTag.tagFk"] input`, - firstTagSelectOptionOne: `vn-item-tags vn-horizontal:nth-child(2) > vn-autocomplete[field="itemTag.tagFk"] vn-drop-down ul > li:nth-child(1)`, + firstTagAutocomplete: `vn-item-tags vn-horizontal:nth-child(2) > vn-autocomplete[field="itemTag.tagFk"]`, firstValueInput: `vn-item-tags vn-horizontal:nth-child(2) > vn-textfield[label="Value"] input`, firstRelevancyInput: `vn-horizontal:nth-child(2) > vn-textfield[label="Relevancy"] input`, - secondTagSelect: `vn-item-tags vn-horizontal:nth-child(3) > vn-autocomplete[field="itemTag.tagFk"] input`, - secondTagSelectOptionOne: `vn-item-tags vn-horizontal:nth-child(3) > vn-autocomplete[field="itemTag.tagFk"] vn-drop-down ul > li:nth-child(1)`, + secondTagAutocomplete: `vn-item-tags vn-horizontal:nth-child(3) > vn-autocomplete[field="itemTag.tagFk"]`, secondValueInput: `vn-item-tags vn-horizontal:nth-child(3) > vn-textfield[label="Value"] input`, secondRelevancyInput: `vn-horizontal:nth-child(3) > vn-textfield[label="Relevancy"] input`, - thirdTagSelect: `vn-item-tags vn-horizontal:nth-child(4) > vn-autocomplete[field="itemTag.tagFk"] input`, - thirdTagSelectOptionOne: `vn-item-tags vn-horizontal:nth-child(4) > vn-autocomplete[field="itemTag.tagFk"] vn-drop-down ul > li:nth-child(1)`, + thirdTagAutocomplete: `vn-item-tags vn-horizontal:nth-child(4) > vn-autocomplete[field="itemTag.tagFk"]`, thirdValueInput: `vn-item-tags vn-horizontal:nth-child(4) > vn-textfield[label="Value"] input`, thirdRelevancyInput: `vn-horizontal:nth-child(4) > vn-textfield[label="Relevancy"] input`, - fourthTagSelect: `vn-item-tags vn-horizontal:nth-child(5) > vn-autocomplete[field="itemTag.tagFk"] input`, - fourthTagSelectOptionOne: `vn-item-tags vn-horizontal:nth-child(5) > vn-autocomplete[field="itemTag.tagFk"] vn-drop-down ul > li:nth-child(1)`, + fourthTagAutocomplete: `vn-item-tags vn-horizontal:nth-child(5) > vn-autocomplete[field="itemTag.tagFk"]`, fourthValueInput: `vn-item-tags vn-horizontal:nth-child(5) > vn-textfield[label="Value"] input`, fourthRelevancyInput: `vn-horizontal:nth-child(5) > vn-textfield[label="Relevancy"] input`, - fifthTagSelect: `vn-item-tags vn-horizontal:nth-child(6) > vn-autocomplete[field="itemTag.tagFk"] input`, + fifthTagAutocomplete: `vn-item-tags vn-horizontal:nth-child(6) > vn-autocomplete[field="itemTag.tagFk"]`, fifthValueInput: `vn-item-tags vn-horizontal:nth-child(6) > vn-textfield[label="Value"] input`, fifthRelevancyInput: `vn-horizontal:nth-child(6) > vn-textfield[label="Relevancy"] input`, - seventhTagSelectOptionFive: `vn-item-tags vn-horizontal:nth-child(8) > vn-autocomplete[field="itemTag.tagFk"] vn-drop-down ul > li:nth-child(5)`, - seventhTagSelect: `vn-item-tags vn-horizontal:nth-child(8) > vn-autocomplete[field="itemTag.tagFk"] input`, + seventhTagAutocomplete: `vn-item-tags vn-horizontal:nth-child(8) > vn-autocomplete[field="itemTag.tagFk"]`, seventhValueInput: `vn-item-tags vn-horizontal:nth-child(8) > vn-textfield[label="Value"] input`, seventhRelevancyInput: `vn-horizontal:nth-child(8) > vn-textfield[label="Relevancy"] input`, addItemTagButton: `vn-icon-button[icon="add_circle"]`, @@ -259,12 +230,9 @@ export default { }, itemTax: { taxButton: `vn-left-menu a[ui-sref="item.card.tax"]`, - firstClassSelect: `vn-horizontal:nth-child(2) > vn-autocomplete[field="tax.taxClassFk"] input`, - firstClassSelectOptionTwo: `vn-horizontal:nth-child(2) > vn-autocomplete vn-drop-down ul > li:nth-child(2)`, - secondClassSelect: `vn-horizontal:nth-child(3) > vn-autocomplete[field="tax.taxClassFk"] input`, - secondClassSelectOptionOne: `vn-horizontal:nth-child(3) > vn-autocomplete vn-drop-down ul > li:nth-child(1)`, - thirdClassSelect: `vn-horizontal:nth-child(4) > vn-autocomplete[field="tax.taxClassFk"] input`, - thirdClassSelectOptionTwo: `vn-horizontal:nth-child(4) > vn-autocomplete vn-drop-down ul > li:nth-child(2)`, + firstClassAutocomplete: `vn-horizontal:nth-child(2) > vn-autocomplete[field="tax.taxClassFk"]`, + secondClassAutocomplete: `vn-horizontal:nth-child(3) > vn-autocomplete[field="tax.taxClassFk"]`, + thirdClassAutocomplete: `vn-horizontal:nth-child(4) > vn-autocomplete[field="tax.taxClassFk"]`, submitTaxButton: `${components.vnSubmit}` }, itemBarcodes: { @@ -277,26 +245,20 @@ export default { itemNiches: { nicheButton: `vn-left-menu a[ui-sref="item.card.niche"]`, addNicheButton: `vn-icon[icon="add_circle"]`, - firstWarehouseSelect: `vn-autocomplete[field="niche.warehouseFk"] input`, - firstWarehouseSelectSecondOption: `vn-autocomplete[field="niche.warehouseFk"] vn-drop-down ul > li:nth-child(2)`, + firstWarehouseAutocomplete: `vn-autocomplete[field="niche.warehouseFk"]`, firstCodeInput: `vn-horizontal:nth-child(2) > vn-textfield[label="Code"] input`, - secondWarehouseSelect: `vn-horizontal:nth-child(3) > vn-autocomplete[field="niche.warehouseFk"] input`, + secondWarehouseAutocomplete: `vn-horizontal:nth-child(3) > vn-autocomplete[field="niche.warehouseFk"]`, secondCodeInput: `vn-horizontal:nth-child(3) > vn-textfield[label="Code"] input`, secondNicheRemoveButton: `vn-horizontal:nth-child(3) > vn-none > vn-icon[icon="delete"]`, - thirdWarehouseSelect: `vn-horizontal:nth-child(4) > vn-autocomplete[field="niche.warehouseFk"] input`, - thirdWarehouseSelectFourthOption: `vn-horizontal:nth-child(4) > vn-autocomplete[field="niche.warehouseFk"] vn-drop-down ul > li:nth-child(4)`, + thirdWarehouseAutocomplete: `vn-horizontal:nth-child(4) > vn-autocomplete[field="niche.warehouseFk"]`, thirdCodeInput: `vn-horizontal:nth-child(4) > vn-textfield[label="Code"] input`, submitNichesButton: `${components.vnSubmit}` }, itemBotanical: { botanicalButton: `vn-left-menu a[ui-sref="item.card.botanical"]`, botanicalInput: `vn-horizontal:nth-child(2) > ${components.vnTextfield}`, - genusSelect: `vn-autocomplete[field="$ctrl.botanical.genusFk"] input`, - genusSelectOptionOne: `vn-autocomplete[field="$ctrl.botanical.genusFk"] vn-drop-down ul > li:nth-child(1)`, - genusSelectOptionTwo: `vn-autocomplete[field="$ctrl.botanical.genusFk"] vn-drop-down ul > li:nth-child(2)`, - speciesSelect: `vn-autocomplete[field="$ctrl.botanical.specieFk"] input`, - speciesSelectOptionOne: `vn-autocomplete[field="$ctrl.botanical.specieFk"] vn-drop-down ul > li:nth-child(1)`, - speciesSelectOptionTwo: `vn-autocomplete[field="$ctrl.botanical.specieFk"] vn-drop-down ul > li:nth-child(2)`, + genusAutocomplete: `vn-autocomplete[field="$ctrl.botanical.genusFk"]`, + speciesAutocomplete: `vn-autocomplete[field="$ctrl.botanical.specieFk"]`, submitBotanicalButton: `${components.vnSubmit}` }, itemSummary: { @@ -311,8 +273,7 @@ export default { thirdTicketId: 'vn-item-diary > vn-vertical > vn-card > div > vn-vertical > vn-table > div > vn-tbody > vn-tr:nth-child(3) > vn-td:nth-child(2) > span', firstBalance: 'vn-item-diary > vn-vertical > vn-card > div > vn-vertical > vn-table > div > vn-tbody > vn-tr:nth-child(1) > vn-td.balance', fifthBalance: 'vn-item-diary > vn-vertical > vn-card > div > vn-vertical > vn-table > div > vn-tbody > vn-tr.ng-scope.isToday.isIn > vn-td.balance > span', - warehouseSelect: 'vn-item-diary vn-autocomplete[field="$ctrl.warehouseFk"] > div > div > input', - warehouseSelectFourthOption: 'vn-item-diary > vn-vertical > vn-card > div > vn-vertical > vn-horizontal > vn-autocomplete > vn-drop-down > vn-popover > div > div.content > div > div.list > ul > li:nth-child(4)' + warehouseAutocomplete: 'vn-item-diary vn-autocomplete[field="$ctrl.warehouseFk"]', }, ticketSummary: { sale: 'vn-ticket-summary > vn-card > div > vn-vertical > vn-horizontal:nth-child(3) > vn-one > table > tbody > tr', @@ -345,8 +306,7 @@ export default { notesButton: `vn-left-menu a[ui-sref="ticket.card.observation"]`, firstNoteRemoveButton: `vn-icon[icon="delete"]`, addNoteButton: `vn-icon[icon="add_circle"]`, - firstNoteSelect: `vn-autocomplete[field="observation.observationTypeFk"] input`, - firstNoteSelectSecondOption: `vn-autocomplete[field="observation.observationTypeFk"] vn-drop-down ul > li:nth-child(2)`, + firstNoteTypeAutocomplete: `vn-autocomplete[field="observation.observationTypeFk"]`, firstDescriptionInput: `vn-textfield[label="Description"] input`, submitNotesButton: `${components.vnSubmit}` }, @@ -358,12 +318,11 @@ export default { }, ticketPackages: { packagesButton: `vn-left-menu a[ui-sref="ticket.card.package.index"]`, - firstPackageSelect: `vn-autocomplete[label="Package"] > div > div > input`, - firstPackageSelectOptionTwo: `vn-autocomplete[label="Package"] vn-drop-down ul > li:nth-child(2)`, + firstPackageAutocomplete: `vn-autocomplete[label="Package"]`, firstQuantityInput: `vn-textfield[label="Quantity"] input`, firstRemovePackageButton: `vn-icon[vn-tooltip="Remove package"]`, addPackageButton: `vn-icon-button[vn-tooltip="Add package"]`, - clearPackageSelectButton: `vn-autocomplete[label="Package"] > div > div > div > vn-icon > i`, + clearPackageAutocompleteButton: `vn-autocomplete[label="Package"] > div > div > div > vn-icon > i`, savePackagesButton: `${components.vnSubmit}` }, ticketSales: { @@ -418,25 +377,18 @@ export default { ticketTracking: { trackingButton: `vn-left-menu a[ui-sref="ticket.card.tracking.index"]`, createStateButton: `${components.vnFloatButton}`, - stateSelect: 'vn-ticket-tracking-edit vn-autocomplete[field="$ctrl.ticket.stateFk"] input', - stateSelectInput: 'vn-ticket-tracking-edit vn-autocomplete > vn-drop-down > vn-popover vn-textfield input', - stateSelectFirstResult: 'vn-ticket-tracking-edit vn-autocomplete > vn-drop-down > vn-popover ul > li:nth-child(1)', + stateAutocomplete: 'vn-ticket-tracking-edit vn-autocomplete[field="$ctrl.ticket.stateFk"]', saveButton: `${components.vnSubmit}` }, ticketBasicData: { basicDataButton: `vn-left-menu a[ui-sref="ticket.card.data.stepOne"]`, - clientSelect: `vn-autocomplete[field="$ctrl.clientFk"] input`, - clientSelectThirdOption: `vn-autocomplete[field="$ctrl.clientFk"] vn-drop-down ul > li:nth-child(3)`, - addressSelect: `vn-autocomplete[field="$ctrl.ticket.addressFk"] input`, - addressSelectSecondOption: `vn-autocomplete[field="$ctrl.ticket.addressFk"] vn-drop-down ul > li:nth-child(2)`, - agencySelect: `vn-autocomplete[field="$ctrl.ticket.agencyModeFk"] input`, - agencySelectOptionSix: `vn-autocomplete[field="$ctrl.ticket.agencyModeFk"] vn-drop-down ul > li:nth-child(6)`, + clientAutocomplete: `vn-autocomplete[field="$ctrl.clientFk"]`, + addressAutocomplete: `vn-autocomplete[field="$ctrl.ticket.addressFk"]`, + agencyAutocomplete: `vn-autocomplete[field="$ctrl.ticket.agencyModeFk"]`, nextStepButton: `vn-step-control > section > section.buttons > section:nth-child(2) > vn-button`, finalizeButton: `vn-step-control > section > section.buttons > section:nth-child(2) > vn-submit`, stepTwoTotalPriceDif: `vn-ticket-data-step-two > form > vn-card > div > vn-horizontal > table > tfoot > tr > td:nth-child(4)`, - chargesReason: `vn-autocomplete[field="$ctrl.ticket.option"] input`, - chargesReasonFourthOption: `vn-autocomplete[field="$ctrl.ticket.option"] vn-drop-down ul > li:nth-child(4)`, - chargesReasonFirstOption: `vn-autocomplete[field="$ctrl.ticket.option"] vn-drop-down ul > li:nth-child(1)` + chargesReasonAutocomplete: `vn-autocomplete[field="$ctrl.ticket.option"]`, }, ticketComponents: { componentsButton: `vn-left-menu a[ui-sref="ticket.card.components"]`, @@ -460,8 +412,7 @@ export default { }, createStateView: { - stateInput: `vn-autocomplete[field="$ctrl.ticket.stateFk"] > div > div > input`, - stateInputOptionOne: `vn-autocomplete[field="$ctrl.ticket.stateFk"] vn-drop-down ul > li:nth-child(1)`, + stateAutocomplete: `vn-autocomplete[field="$ctrl.ticket.stateFk"]`, clearStateInputButton: `vn-autocomplete[field="$ctrl.ticket.stateFk"] > div > div > div > vn-icon > i`, saveStateButton: `${components.vnSubmit}` }, @@ -472,9 +423,7 @@ export default { }, claimBasicData: { basicDataButton: `vn-left-menu a[ui-sref="claim.card.basicData"]`, - claimStateSelect: `vn-autocomplete[field="$ctrl.claim.claimStateFk"] input`, - claimStateSelectThirdOption: `vn-autocomplete[field="$ctrl.claim.claimStateFk"] vn-drop-down ul > li:nth-child(3)`, - claimStateSelectFourthOption: `vn-autocomplete[field="$ctrl.claim.claimStateFk"] vn-drop-down ul > li:nth-child(4)`, + claimStateAutocomplete: 'vn-claim-basic-data vn-autocomplete[field="$ctrl.claim.claimStateFk"]', isPaidWithManaCheckbox: `vn-check[field="$ctrl.claim.isChargedToMana"] > label > input`, responsabilityInputRange: `vn-input-range`, observationInput: `vn-textarea[label="Observation"] textarea`, diff --git a/e2e/paths/claim-module/01_edit_basic_data.spec.js b/e2e/paths/claim-module/01_edit_basic_data.spec.js index b8354415e..3c9355bb6 100644 --- a/e2e/paths/claim-module/01_edit_basic_data.spec.js +++ b/e2e/paths/claim-module/01_edit_basic_data.spec.js @@ -11,10 +11,9 @@ describe('Claim edit basic data path', () => { .accessToSection('claim.card.basicData'); }); - it(`should edit claim state, is paid with mana and observation fields`, async () => { + it(`should edit claim state, is paid with mana and observation fields`, async() => { const result = await nightmare - .waitToClick(selectors.claimBasicData.claimStateSelect) - .waitToClick(selectors.claimBasicData.claimStateSelectThirdOption) + .autocompleteSearch(selectors.claimBasicData.claimStateAutocomplete, 'Gestionado') .waitToClick(selectors.claimBasicData.isPaidWithManaCheckbox) .clearInput(selectors.claimBasicData.observationInput) .type(selectors.claimBasicData.observationInput, 'edited observation') @@ -24,18 +23,18 @@ describe('Claim edit basic data path', () => { expect(result).toEqual(jasmine.arrayContaining(['Data saved!'])); }); - it('should confirm the claim state was edited', async () => { + it('should confirm the claim state was edited', async() => { const result = await nightmare .click(selectors.claimDetails.detailsButton) .wait(selectors.claimDetails.addItemButton) .click(selectors.claimBasicData.basicDataButton) - .wait(selectors.claimBasicData.claimStateSelect) - .waitToGetProperty(selectors.claimBasicData.claimStateSelect, 'value'); + .wait(selectors.claimBasicData.claimStateAutocomplete) + .waitToGetProperty(`${selectors.claimBasicData.claimStateAutocomplete} input`, 'value'); expect(result).toEqual('Gestionado'); }); - it('should confirm the Is paid with mana checkbox is checked', async () => { + it('should confirm the Is paid with mana checkbox is checked', async() => { const value = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -44,17 +43,16 @@ describe('Claim edit basic data path', () => { expect(value).toBeTruthy(); }); - it('should confirm the claim observation was edited', async () => { + it('should confirm the claim observation was edited', async() => { const result = await nightmare .waitToGetProperty(selectors.claimBasicData.observationInput, 'value'); expect(result).toEqual('edited observation'); }); - it(`should edit the claim to leave it untainted`, async () => { + it(`should edit the claim to leave it untainted`, async() => { const result = await nightmare - .waitToClick(selectors.claimBasicData.claimStateSelect) - .waitToClick(selectors.claimBasicData.claimStateSelectFourthOption) + .autocompleteSearch(selectors.claimBasicData.claimStateAutocomplete, 'Pendiente') .waitToClick(selectors.claimBasicData.isPaidWithManaCheckbox) .clearInput(selectors.claimBasicData.observationInput) .type(selectors.claimBasicData.observationInput, 'Observation one') diff --git a/e2e/paths/client-module/01_create_client.spec.js b/e2e/paths/client-module/01_create_client.spec.js index 440ac6b1d..06c981c15 100644 --- a/e2e/paths/client-module/01_create_client.spec.js +++ b/e2e/paths/client-module/01_create_client.spec.js @@ -9,7 +9,7 @@ describe('Client create path', () => { .loginAndModule('employee', 'client'); }); - it(`should search for the user Carol Danvers to confirm it isn't created yet`, async () => { + it(`should search for the user Carol Danvers to confirm it isn't created yet`, async() => { const result = await nightmare .wait(selectors.clientsIndex.searchClientInput) .type(selectors.clientsIndex.searchClientInput, 'Carol Danvers') @@ -20,7 +20,7 @@ describe('Client create path', () => { expect(result).toEqual(0); }); - it('should now access to the create client view by clicking the create-client floating button', async () => { + it('should now access to the create client view by clicking the create-client floating button', async() => { const url = await nightmare .click(selectors.clientsIndex.createClientButton) .wait(selectors.createClientView.createButton) @@ -29,7 +29,7 @@ describe('Client create path', () => { expect(url.hash).toEqual('#!/client/create'); }); - it('should receive an error when clicking the create button having all the form fields empty', async () => { + it('should receive an error when clicking the create button having all the form fields empty', async() => { const result = await nightmare .click(selectors.createClientView.createButton) .waitForLastSnackbar(); @@ -37,20 +37,19 @@ describe('Client create path', () => { expect(result).toEqual('Some fields are invalid'); }); - it('should receive an error when clicking the create button having name and Business name fields empty', async () => { + it('should receive an error when clicking the create button having name and Business name fields empty', async() => { const result = await nightmare .type(selectors.createClientView.taxNumber, '74451390E') .type(selectors.createClientView.userName, 'CaptainMarvel') .type(selectors.createClientView.email, 'CarolDanvers@verdnatura.es') - .waitToClick(selectors.createClientView.salesPersonInput) - .waitToClick(selectors.createClientView.salesBruceBannerOption) + .autocompleteSearch(selectors.createClientView.salesPersonAutocomplete, 'Accessory') .click(selectors.createClientView.createButton) .waitForLastSnackbar(); expect(result).toEqual('Some fields are invalid'); }); - it(`should attempt to create a new user with all it's data but wrong email`, async () => { + it(`should attempt to create a new user with all it's data but wrong email`, async() => { const result = await nightmare .type(selectors.createClientView.name, 'Carol Danvers') .type(selectors.createClientView.socialName, 'AVG tax') @@ -62,7 +61,7 @@ describe('Client create path', () => { expect(result).toEqual('Some fields are invalid'); }); - it(`should create a new user with all correct data`, async () => { + it(`should create a new user with all correct data`, async() => { const result = await nightmare .clearInput(selectors.createClientView.email) .type(selectors.createClientView.email, 'caroldanvers@verdnatura.es') @@ -72,7 +71,7 @@ describe('Client create path', () => { expect(result).toEqual('Data saved!'); }); - it('should click on the Clients button of the top bar menu', async () => { + it('should click on the Clients button of the top bar menu', async() => { const url = await nightmare .waitToClick(selectors.globalItems.applicationsMenuButton) .wait(selectors.globalItems.applicationsMenuVisible) @@ -83,7 +82,7 @@ describe('Client create path', () => { expect(url.hash).toEqual('#!/client/index'); }); - it(`should search for the user Carol Danvers to confirm it exists`, async () => { + it(`should search for the user Carol Danvers to confirm it exists`, async() => { const result = await nightmare .wait(selectors.clientsIndex.searchClientInput) .type(selectors.clientsIndex.searchClientInput, 'Carol Danvers') diff --git a/e2e/paths/client-module/02_edit_basic_data.spec.js b/e2e/paths/client-module/02_edit_basic_data.spec.js index 7ca1d9874..0f3111ab9 100644 --- a/e2e/paths/client-module/02_edit_basic_data.spec.js +++ b/e2e/paths/client-module/02_edit_basic_data.spec.js @@ -11,17 +11,17 @@ describe('Client Edit basicData path', () => { .accessToSection('client.card.basicData'); }); - it('should not be able to change the salesPerson', async () => { + it('should not be able to change the salesPerson', async() => { const result = await nightmare .wait(selectors.clientBasicData.nameInput) .evaluate(selector => { return document.querySelector(selector).disabled; - }, selectors.clientBasicData.salesPersonInput); + }, `${selectors.clientBasicData.salesPersonAutocomplete} input`); expect(result).toBeTruthy(); }); - it('should edit the client basic data but leave salesPerson untainted', async () => { + it('should edit the client basic data but leave salesPerson untainted', async() => { const result = await nightmare .clearInput(selectors.clientBasicData.nameInput) .type(selectors.clientBasicData.nameInput, 'Ptonomy Wallace') @@ -33,15 +33,14 @@ describe('Client Edit basicData path', () => { .type(selectors.clientBasicData.mobileInput, '123456789') .clearInput(selectors.clientBasicData.emailInput) .type(selectors.clientBasicData.emailInput, 'PWallace@verdnatura.es') - .waitToClick(selectors.clientBasicData.channelInput) - .waitToClick(selectors.clientBasicData.channelRumorsOption) + .autocompleteSearch(selectors.clientBasicData.channelAutocomplete, 'Rumors on the streets') .click(selectors.clientBasicData.saveButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it('should confirm the name have been edited', async () => { + it('should confirm the name have been edited', async() => { const result = await nightmare .click(selectors.clientFiscalData.fiscalDataButton) .wait(selectors.clientFiscalData.addressInput) @@ -51,37 +50,37 @@ describe('Client Edit basicData path', () => { expect(result).toEqual('Ptonomy Wallace'); }); - it('should confirm the contact name have been edited', async () => { + it('should confirm the contact name have been edited', async() => { const result = await nightmare .waitToGetProperty(selectors.clientBasicData.contactInput, 'value'); expect(result).toEqual('David Haller'); }); - it('should confirm the landline phone number have been added', async () => { + it('should confirm the landline phone number have been added', async() => { const result = await nightmare .waitToGetProperty(selectors.clientBasicData.phoneInput, 'value'); expect(result).toEqual('987654321'); }); - it('should confirm the mobile phone number have been added', async () => { + it('should confirm the mobile phone number have been added', async() => { const result = await nightmare .waitToGetProperty(selectors.clientBasicData.mobileInput, 'value'); expect(result).toEqual('123456789'); }); - it('should confirm the email have been edited', async () => { + it('should confirm the email have been edited', async() => { const result = await nightmare .waitToGetProperty(selectors.clientBasicData.emailInput, 'value'); expect(result).toEqual('PWallace@verdnatura.es'); }); - it('should confirm the channel have been selected', async () => { + it('should confirm the channel have been selected', async() => { const result = await nightmare - .waitToGetProperty(selectors.clientBasicData.channelInput, 'value'); + .waitToGetProperty(`${selectors.clientBasicData.channelAutocomplete} input`, 'value'); expect(result).toEqual('Rumors on the streets'); }); @@ -96,17 +95,17 @@ describe('Client Edit basicData path', () => { .accessToSection('client.card.basicData'); }); - it('should be able to change the salesPerson', async () => { + it('should be able to change the salesPerson', async() => { const result = await nightmare .wait(selectors.clientBasicData.nameInput) .evaluate(selector => { return document.querySelector(selector).disabled; - }, selectors.clientBasicData.salesPersonInput); + }, `${selectors.clientBasicData.salesPersonAutocomplete} input`); expect(result).toBeFalsy(); }); - it('should edit the client basic data including salesPerson', async () => { + it('should edit the client basic data including salesPerson', async() => { const result = await nightmare .clearInput(selectors.clientBasicData.nameInput) .type(selectors.clientBasicData.nameInput, 'Ororo Munroe') @@ -118,17 +117,15 @@ describe('Client Edit basicData path', () => { .type(selectors.clientBasicData.mobileInput, '987654321') .clearInput(selectors.clientBasicData.emailInput) .type(selectors.clientBasicData.emailInput, 'Storm@verdnatura.es') - .waitToClick(selectors.clientBasicData.salesPersonInput) - .waitToClick(selectors.clientBasicData.salesPersonOptionOne) - .waitToClick(selectors.clientBasicData.channelInput) - .waitToClick(selectors.clientBasicData.channelMetropolisOption) + .autocompleteSearch(selectors.clientBasicData.salesPersonAutocomplete, 'Accessory') + .autocompleteSearch(selectors.clientBasicData.channelAutocomplete, 'Metropolis newspaper') .click(selectors.clientBasicData.saveButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it('should now confirm the name have been edited', async () => { + it('should now confirm the name have been edited', async() => { const result = await nightmare .click(selectors.clientFiscalData.fiscalDataButton) .wait(selectors.clientFiscalData.addressInput) @@ -138,44 +135,44 @@ describe('Client Edit basicData path', () => { expect(result).toEqual('Ororo Munroe'); }); - it('should now confirm the contact name have been edited', async () => { + it('should now confirm the contact name have been edited', async() => { const result = await nightmare .waitToGetProperty(selectors.clientBasicData.contactInput, 'value'); expect(result).toEqual('Black Panther'); }); - it('should now confirm the landline phone number have been added', async () => { + it('should now confirm the landline phone number have been added', async() => { const result = await nightmare .waitToGetProperty(selectors.clientBasicData.phoneInput, 'value'); expect(result).toEqual('123456789'); }); - it('should now confirm the mobile phone number have been added', async () => { + it('should now confirm the mobile phone number have been added', async() => { const result = await nightmare .waitToGetProperty(selectors.clientBasicData.mobileInput, 'value'); expect(result).toEqual('987654321'); }); - it('should now confirm the email have been edited', async () => { + it('should now confirm the email have been edited', async() => { const result = await nightmare .waitToGetProperty(selectors.clientBasicData.emailInput, 'value'); expect(result).toEqual('Storm@verdnatura.es'); }); - it('should confirm the sales person have been selected', async () => { + it('should confirm the sales person have been selected', async() => { const result = await nightmare - .waitToGetProperty(selectors.clientBasicData.salesPersonInput, 'value'); + .waitToGetProperty(`${selectors.clientBasicData.salesPersonAutocomplete} input`, 'value'); expect(result).toEqual('accessory accessory'); }); - it('should now confirm the channel have been selected', async () => { + it('should now confirm the channel have been selected', async() => { const result = await nightmare - .waitToGetProperty(selectors.clientBasicData.channelInput, 'value'); + .waitToGetProperty(`${selectors.clientBasicData.channelAutocomplete} input`, 'value'); expect(result).toEqual('Metropolis newspaper'); }); diff --git a/e2e/paths/client-module/03_edit_fiscal_data.spec.js b/e2e/paths/client-module/03_edit_fiscal_data.spec.js index 8e2617a0e..7144e76a2 100644 --- a/e2e/paths/client-module/03_edit_fiscal_data.spec.js +++ b/e2e/paths/client-module/03_edit_fiscal_data.spec.js @@ -12,7 +12,7 @@ describe('Client Edit fiscalData path', () => { }); // Confirms all addresses have EQtax false for future propagation test step 1 - it(`should click on the 1st edit icon to check EQtax isnt checked`, async () => { + it(`should click on the 1st edit icon to check EQtax isnt checked`, async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.firstEditButton) .wait(selectors.clientAddresses.equalizationTaxCheckboxLabel) @@ -24,7 +24,7 @@ describe('Client Edit fiscalData path', () => { }); // Confirms all addresses have EQtax false for future propagation test step 2 - it(`should go back to addresses then select the second one and confirm the EQtax isnt checked`, async () => { + it(`should go back to addresses then select the second one and confirm the EQtax isnt checked`, async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.addressesButton) .waitToClick(selectors.clientAddresses.secondEditButton) @@ -36,7 +36,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeFalsy(); }); - it(`should click on the fiscal data button`, async () => { + it(`should click on the fiscal data button`, async() => { const url = await nightmare .waitToClick(selectors.clientFiscalData.fiscalDataButton) .waitForURL('fiscal-data') @@ -45,7 +45,7 @@ describe('Client Edit fiscalData path', () => { expect(url.hash).toContain('fiscal-data'); }); - it('should not be able to edit the verified data checkbox', async () => { + it('should not be able to edit the verified data checkbox', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).disabled; @@ -63,7 +63,7 @@ describe('Client Edit fiscalData path', () => { .accessToSection('client.card.fiscalData'); }); - it('should receive an error if VIES and EQtax are being ticked together', async () => { + it('should receive an error if VIES and EQtax are being ticked together', async() => { const result = await nightmare .wait(selectors.clientFiscalData.socialNameInput) .clearInput(selectors.clientFiscalData.socialNameInput) @@ -76,10 +76,8 @@ describe('Client Edit fiscalData path', () => { .type(selectors.clientFiscalData.postcodeInput, '12345') .clearInput(selectors.clientFiscalData.cityInput) .type(selectors.clientFiscalData.cityInput, 'N/A') - .waitToClick(selectors.clientFiscalData.countryInput) - .waitToClick(selectors.clientFiscalData.countryThirdOption) - .waitToClick(selectors.clientFiscalData.provinceInput) - .waitToClick(selectors.clientFiscalData.provinceFifthOption) + .autocompleteSearch(selectors.clientFiscalData.countryAutocomplete, 'Francia') + .autocompleteSearch(selectors.clientFiscalData.provinceAutocomplete, 'Province two') .waitToClick(selectors.clientFiscalData.activeCheckboxLabel) .waitToClick(selectors.clientFiscalData.frozenCheckboxLabel) .waitToClick(selectors.clientFiscalData.hasToInvoiceCheckboxLabel) @@ -94,7 +92,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toEqual('Cannot check VIES and Equalization Tax'); }); - it('should receive an error if the fiscal id contains A or B at the beginning', async () => { + it('should receive an error if the fiscal id contains A or B at the beginning', async() => { const result = await nightmare .waitToClick(selectors.clientFiscalData.viesCheckboxInput) .clearInput(selectors.clientFiscalData.fiscalIdInput) @@ -105,7 +103,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toEqual('Cannot check Equalization Tax in this NIF/CIF'); }); - it('should finally edit the fixcal data correctly as VIES isnt checked and fiscal id is valid for EQtax', async () => { + it('should finally edit the fixcal data correctly as VIES isnt checked and fiscal id is valid for EQtax', async() => { const result = await nightmare .clearInput(selectors.clientFiscalData.fiscalIdInput) .type(selectors.clientFiscalData.fiscalIdInput, '94980061C') @@ -115,7 +113,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toEqual('Data saved!'); }); - it('should propagate the Equalization tax', async () => { + it('should propagate the Equalization tax', async() => { const result = await nightmare .waitToClick(selectors.clientFiscalData.acceptPropagationButton) .waitForLastSnackbar(); @@ -124,7 +122,7 @@ describe('Client Edit fiscalData path', () => { }); // confirm all addresses have now EQtax checked step 1 - it(`should click on the addresses button to access to the client's addresses`, async () => { + it(`should click on the addresses button to access to the client's addresses`, async() => { const url = await nightmare .waitToClick(selectors.clientAddresses.addressesButton) .waitForURL('/address/index') @@ -134,7 +132,7 @@ describe('Client Edit fiscalData path', () => { }); // confirm all addresses have now EQtax checked step 2 - it(`should click on the 1st edit icon to confirm EQtax is checked`, async () => { + it(`should click on the 1st edit icon to confirm EQtax is checked`, async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.firstEditButton) .wait(selectors.clientAddresses.equalizationTaxCheckboxLabel) @@ -146,7 +144,7 @@ describe('Client Edit fiscalData path', () => { }); // confirm all addresses have now EQtax checked step 3 - it(`should go back to addresses then select the second one and confirm the EQtax is checked`, async () => { + it(`should go back to addresses then select the second one and confirm the EQtax is checked`, async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.addressesButton) .waitToClick(selectors.clientAddresses.secondEditButton) @@ -158,7 +156,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeTruthy(); }); - it('should navigate back to fiscal data and uncheck EQtax then check VIES', async () => { + it('should navigate back to fiscal data and uncheck EQtax then check VIES', async() => { const result = await nightmare .waitToClick(selectors.clientFiscalData.fiscalDataButton) .waitToClick(selectors.clientFiscalData.viesCheckboxInput) @@ -169,7 +167,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toEqual('Data saved!'); }); - it('should propagate the Equalization tax changes', async () => { + it('should propagate the Equalization tax changes', async() => { const result = await nightmare .waitToClick(selectors.clientFiscalData.acceptPropagationButton) .waitForLastSnackbar(); @@ -177,7 +175,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toEqual('Equivalent tax spreaded'); }); - it('should confirm its name have been edited', async () => { + it('should confirm its name have been edited', async() => { const result = await nightmare .waitToClick(selectors.clientFiscalData.fiscalDataButton) .waitToGetProperty(selectors.clientFiscalData.socialNameInput, 'value'); @@ -185,49 +183,49 @@ describe('Client Edit fiscalData path', () => { expect(result).toEqual('SMASH!'); }); - it('should confirm the fiscal id have been edited', async () => { + it('should confirm the fiscal id have been edited', async() => { const result = await nightmare .waitToGetProperty(selectors.clientFiscalData.fiscalIdInput, 'value'); expect(result).toEqual('94980061C'); }); - it('should confirm the address have been edited', async () => { + it('should confirm the address have been edited', async() => { const result = await nightmare .waitToGetProperty(selectors.clientFiscalData.addressInput, 'value'); expect(result).toEqual('Somewhere edited'); }); - it('should confirm the postcode have been edited', async () => { + it('should confirm the postcode have been edited', async() => { const result = await nightmare .waitToGetProperty(selectors.clientFiscalData.postcodeInput, 'value'); expect(result).toEqual('12345'); }); - it('should confirm the city have been edited', async () => { + it('should confirm the city have been edited', async() => { const result = await nightmare .waitToGetProperty(selectors.clientFiscalData.cityInput, 'value'); expect(result).toEqual('N/A'); }); - it(`should confirm the country have been selected`, async () => { + it(`should confirm the country have been selected`, async() => { const result = await nightmare - .waitToGetProperty(selectors.clientFiscalData.countryInput, 'value'); + .waitToGetProperty(`${selectors.clientFiscalData.countryAutocomplete} input`, 'value'); expect(result).toEqual('Francia'); }); - it(`should confirm the province have been selected`, async () => { + it(`should confirm the province have been selected`, async() => { const result = await nightmare - .waitToGetProperty(selectors.clientFiscalData.provinceInput, 'value'); + .waitToGetProperty(`${selectors.clientFiscalData.provinceAutocomplete} input`, 'value'); expect(result).toEqual('Province two'); }); - it('should confirm active checkbox is unchecked', async () => { + it('should confirm active checkbox is unchecked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -236,7 +234,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeFalsy(); }); - it('should confirm frozen checkbox is unchecked', async () => { + it('should confirm frozen checkbox is unchecked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -245,7 +243,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeFalsy(); }); - it('should confirm Has to invoice checkbox is unchecked', async () => { + it('should confirm Has to invoice checkbox is unchecked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -254,7 +252,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeFalsy(); }); - it('should confirm Vies checkbox is checked', async () => { + it('should confirm Vies checkbox is checked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -263,7 +261,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeTruthy(); }); - it('should confirm Invoice by mail checkbox is unchecked', async () => { + it('should confirm Invoice by mail checkbox is unchecked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -272,7 +270,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeFalsy(); }); - it('should confirm invoice by address checkbox is unchecked', async () => { + it('should confirm invoice by address checkbox is unchecked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -281,7 +279,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeFalsy(); }); - it('should confirm Equalization tax checkbox is unchecked', async () => { + it('should confirm Equalization tax checkbox is unchecked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -290,7 +288,7 @@ describe('Client Edit fiscalData path', () => { expect(result).toBeFalsy(); }); - it('should confirm Verified data checkbox is checked', async () => { + it('should confirm Verified data checkbox is checked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -300,7 +298,7 @@ describe('Client Edit fiscalData path', () => { }); // confirm invoice by address checkbox gets checked if the EQtax differs between addresses step 1 - it(`should click on the addresses button to access to the client's addresses`, async () => { + it(`should click on the addresses button to access to the client's addresses`, async() => { const url = await nightmare .waitToClick(selectors.clientAddresses.addressesButton) .waitForURL('/address/index') @@ -310,7 +308,7 @@ describe('Client Edit fiscalData path', () => { }); // confirm invoice by address checkbox gets checked if the EQtax differs between addresses step 2 - it(`should click on the 1st edit icon to access the address details and uncheck EQtax checkbox`, async () => { + it(`should click on the 1st edit icon to access the address details and uncheck EQtax checkbox`, async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.firstEditButton) .waitToClick(selectors.clientAddresses.equalizationTaxCheckboxLabel) @@ -321,7 +319,7 @@ describe('Client Edit fiscalData path', () => { }); // confirm invoice by address checkbox gets checked if the EQtax differs between addresses step 3 - it('should navigate back to fiscal data to confirm invoice by address is now checked', async () => { + it('should navigate back to fiscal data to confirm invoice by address is now checked', async() => { const result = await nightmare .waitToClick(selectors.clientFiscalData.fiscalDataButton) .wait(selectors.clientFiscalData.invoiceByAddressCheckboxInput) diff --git a/e2e/paths/client-module/04_edit_pay_method.spec.js b/e2e/paths/client-module/04_edit_pay_method.spec.js index cab7b317c..c785c64a3 100644 --- a/e2e/paths/client-module/04_edit_pay_method.spec.js +++ b/e2e/paths/client-module/04_edit_pay_method.spec.js @@ -11,14 +11,10 @@ describe('Client Edit pay method path', () => { .accessToSection('client.card.billingData'); }); - it(`should attempt to edit the Pay method without an IBAN but fail`, async () => { + it(`should attempt to edit the Pay method without an IBAN but fail`, async() => { const snackbarMessage = await nightmare - .waitToClick(selectors.clientPayMethod.payMethodInput) - .waitToClick(selectors.clientPayMethod.payMethodIBANOption) - .waitForTextInInput(selectors.clientPayMethod.payMethodInput, 'PayMethod with IBAN') - .waitToClick(selectors.clientPayMethod.swiftBicInput) - .waitToClick(selectors.clientPayMethod.firstSwiftBicOption) - .waitForTextInInput(selectors.clientPayMethod.swiftBicInput, 'BBKKESMMMMM') + .autocompleteSearch(selectors.clientPayMethod.payMethodAutocomplete, 'PayMethod with IBAN') + .autocompleteSearch(selectors.clientPayMethod.swiftBicAutocomplete, 'BBKKESMMMMM') .clearInput(selectors.clientPayMethod.dueDayInput) .type(selectors.clientPayMethod.dueDayInput, '60') .waitForTextInInput(selectors.clientPayMethod.dueDayInput, '60') @@ -31,7 +27,7 @@ describe('Client Edit pay method path', () => { expect(snackbarMessage).toEqual('That payment method requires an IBAN'); }); - it(`should add the IBAN but fail as it requires a BIC code`, async () => { + it(`should add the IBAN but fail as it requires a BIC code`, async() => { const snackbarMessage = await nightmare .clearInput(selectors.clientPayMethod.IBANInput) .type(selectors.clientPayMethod.IBANInput, 'ES9121000418450200051332') @@ -43,46 +39,46 @@ describe('Client Edit pay method path', () => { expect(snackbarMessage).toEqual('That payment method requires a BIC'); }); - it(`should create a new BIC code`, async () => { + it(`should create a new BIC code`, async() => { const newcode = await nightmare .click(selectors.clientPayMethod.newBankEntityButton) .type(selectors.clientPayMethod.newBankEntityName, 'Gotham City Banks') .type(selectors.clientPayMethod.newBankEntityBIC, 'GTHMCT') .click(selectors.clientPayMethod.acceptBankEntityButton) - .waitToGetProperty(selectors.clientPayMethod.swiftBicInput, 'value'); + .waitToGetProperty(`${selectors.clientPayMethod.swiftBicAutocomplete} input`, 'value'); expect(newcode).toEqual('GTHMCT Gotham City Banks'); }); - it(`should confirm the IBAN pay method is sucessfully saved`, async () => { + it(`should confirm the IBAN pay method is sucessfully saved`, async() => { const payMethod = await nightmare - .waitToGetProperty(selectors.clientPayMethod.payMethodInput, 'value'); + .waitToGetProperty(`${selectors.clientPayMethod.payMethodAutocomplete} input`, 'value'); expect(payMethod).toEqual('PayMethod with IBAN'); }); - it('should confirm the due day have been edited', async () => { + it('should confirm the due day have been edited', async() => { const dueDate = await nightmare .waitToGetProperty(selectors.clientPayMethod.dueDayInput, 'value'); expect(dueDate).toEqual('60'); }); - it('should confirm the IBAN was saved', async () => { + it('should confirm the IBAN was saved', async() => { const IBAN = await nightmare .waitToGetProperty(selectors.clientPayMethod.IBANInput, 'value'); expect(IBAN).toEqual('ES9121000418450200051332'); }); - it('should confirm the swift / BIC code was saved', async () => { + it('should confirm the swift / BIC code was saved', async() => { const code = await nightmare - .waitToGetProperty(selectors.clientPayMethod.swiftBicInput, 'value'); + .waitToGetProperty(`${selectors.clientPayMethod.swiftBicAutocomplete} input`, 'value'); expect(code).toEqual('GTHMCT Gotham City Banks'); }); - it('should confirm Received LCR checkbox is checked', async () => { + it('should confirm Received LCR checkbox is checked', async() => { const checkedBox = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -91,7 +87,7 @@ describe('Client Edit pay method path', () => { expect(checkedBox).toBeTruthy(); }); - it('should confirm Received core VNL checkbox is unchecked', async () => { + it('should confirm Received core VNL checkbox is unchecked', async() => { const checkedBox = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; @@ -100,7 +96,7 @@ describe('Client Edit pay method path', () => { expect(checkedBox).toBeFalsy(); }); - it('should confirm Received B2B VNL checkbox is unchecked', async () => { + it('should confirm Received B2B VNL checkbox is unchecked', async() => { const checkedBox = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; diff --git a/e2e/paths/client-module/05_add_address.spec.js b/e2e/paths/client-module/05_add_address.spec.js index b24acf57f..f7f3e361e 100644 --- a/e2e/paths/client-module/05_add_address.spec.js +++ b/e2e/paths/client-module/05_add_address.spec.js @@ -11,7 +11,7 @@ describe('Client Add address path', () => { .accessToSection('client.card.address.index'); }); - it(`should click on the add new address button to access to the new address form`, async () => { + it(`should click on the add new address button to access to the new address form`, async() => { const url = await nightmare .waitToClick(selectors.clientAddresses.createAddress) .waitForURL('address/create') @@ -20,7 +20,7 @@ describe('Client Add address path', () => { expect(url.hash).toContain('address/create'); }); - it(`should return to the addreses section by clicking the cancel button`, async () => { + it(`should return to the addreses section by clicking the cancel button`, async() => { const url = await nightmare .waitToClick(selectors.clientAddresses.cancelButton) .waitForURL('address/index') @@ -29,7 +29,7 @@ describe('Client Add address path', () => { expect(url.hash).toContain('address/index'); }); - it(`should now click on the add new address button to access to the new address form`, async () => { + it(`should now click on the add new address button to access to the new address form`, async() => { const url = await nightmare .waitToClick(selectors.clientAddresses.createAddress) .waitForURL('address/create') @@ -38,15 +38,13 @@ describe('Client Add address path', () => { expect(url.hash).toContain('address/create'); }); - it('should receive an error after clicking save button as consignee, street and town fields are empty', async () => { + it('should receive an error after clicking save button as consignee, street and town fields are empty', async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.defaultCheckboxInput) .clearInput(selectors.clientAddresses.streetAddressInput) .type(selectors.clientAddresses.postcodeInput, '10022') - .waitToClick(selectors.clientAddresses.provinceInput) - .waitToClick(selectors.clientAddresses.provinceSecondOption) - .waitToClick(selectors.clientAddresses.agencyInput) - .waitToClick(selectors.clientAddresses.agenctySecondOption) + .autocompleteSearch(selectors.clientAddresses.provinceAutocomplete, 'Province four') + .autocompleteSearch(selectors.clientAddresses.agencyAutocomplete, 'Entanglement') .type(selectors.clientAddresses.phoneInput, '999887744') .type(selectors.clientAddresses.mobileInput, '999887744') .waitToClick(selectors.clientFiscalData.saveButton) @@ -55,7 +53,7 @@ describe('Client Add address path', () => { expect(result).toEqual('Some fields are invalid'); }); - it(`should create a new address with all it's data`, async () => { + it(`should create a new address with all it's data`, async() => { const result = await nightmare .type(selectors.clientAddresses.consigneeInput, 'Bruce Bunner') .type(selectors.clientAddresses.streetAddressInput, '320 Park Avenue New York') @@ -66,7 +64,7 @@ describe('Client Add address path', () => { expect(result).toEqual('Data saved!'); }); - it(`should click on the addresses button confirm the new address exists and it's the default one`, async () => { + it(`should click on the addresses button confirm the new address exists and it's the default one`, async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.addressesButton) .waitToGetProperty(selectors.clientAddresses.defaultAddress, 'innerText'); @@ -74,7 +72,7 @@ describe('Client Add address path', () => { expect(result).toContain('320 Park Avenue New York'); }); - it(`should click on the make default icon of the second address then confirm it is the default one now`, async () => { + it(`should click on the make default icon of the second address then confirm it is the default one now`, async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.secondMakeDefaultStar) .waitForTextInElement(selectors.clientAddresses.defaultAddress, 'Somewhere in Thailand') @@ -83,7 +81,7 @@ describe('Client Add address path', () => { expect(result).toContain('Somewhere in Thailand'); }); - it(`should click on the edit icon of the default address`, async () => { + it(`should click on the edit icon of the default address`, async() => { const url = await nightmare .waitForTextInElement(selectors.clientAddresses.defaultAddress, 'Somewhere in Thailand') .waitToClick(selectors.clientAddresses.firstEditButton) @@ -93,7 +91,7 @@ describe('Client Add address path', () => { expect(url.hash).toContain('/edit'); }); - it(`should click on the active checkbox and receive an error to save it because it is the default address`, async () => { + it(`should click on the active checkbox and receive an error to save it because it is the default address`, async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.activeCheckbox) .waitToClick(selectors.clientAddresses.saveButton) diff --git a/e2e/paths/client-module/06_add_address_notes.spec.js b/e2e/paths/client-module/06_add_address_notes.spec.js index bd5582de4..a27f62430 100644 --- a/e2e/paths/client-module/06_add_address_notes.spec.js +++ b/e2e/paths/client-module/06_add_address_notes.spec.js @@ -11,7 +11,7 @@ describe('Client add address notes path', () => { .accessToSection('client.card.address.index'); }); - it(`should click on the edit icon of the default address`, async () => { + it(`should click on the edit icon of the default address`, async() => { const url = await nightmare .waitForTextInElement(selectors.clientAddresses.defaultAddress, '20 Ingram Street') .waitToClick(selectors.clientAddresses.firstEditButton) @@ -21,7 +21,7 @@ describe('Client add address notes path', () => { expect(url.hash).toContain('/edit'); }); - it('should not save a description without observation type', async () => { + it('should not save a description without observation type', async() => { const result = await nightmare .waitToClick(selectors.clientAddresses.addObservationButton) .wait(selectors.clientAddresses.firstObservationDescriptionInput) @@ -32,23 +32,21 @@ describe('Client add address notes path', () => { expect(result).toEqual('Observation type cannot be blank'); }); - it('should not save an observation type without description', async () => { + it('should not save an observation type without description', async() => { const result = await nightmare .clearInput(selectors.clientAddresses.firstObservationDescriptionInput) - .waitToClick(selectors.clientAddresses.firstObservationTypeSelect) - .waitToClick(selectors.clientAddresses.firstObservationTypeSelectOptionOne) + .autocompleteSearch(selectors.clientAddresses.firstObservationTypeAutocomplete, 'comercial') .waitToClick(selectors.clientAddresses.saveButton) .waitForLastSnackbar(); expect(result).toEqual('Some fields are invalid'); }); - it('should create two new observations', async () => { + it('should create two new observations', async() => { const result = await nightmare .type(selectors.clientAddresses.firstObservationDescriptionInput, 'first description') .waitToClick(selectors.clientAddresses.addObservationButton) - .waitToClick(selectors.clientAddresses.secondObservationTypeSelect) - .waitToClick(selectors.clientAddresses.secondObservationTypeSelectOptionTwo) + .autocompleteSearch(selectors.clientAddresses.secondObservationTypeAutocomplete, 'observation one') .type(selectors.clientAddresses.secondObservationDescriptionInput, 'second description') .waitToClick(selectors.clientAddresses.saveButton) .waitForLastSnackbar(); diff --git a/e2e/paths/client-module/10_add_greuge.spec.js b/e2e/paths/client-module/10_add_greuge.spec.js index 9859fd07e..c1ca1ba18 100644 --- a/e2e/paths/client-module/10_add_greuge.spec.js +++ b/e2e/paths/client-module/10_add_greuge.spec.js @@ -11,7 +11,7 @@ describe('Client Add greuge path', () => { .accessToSection('client.card.greuge.index'); }); - it(`should click on the add greuge button`, async () => { + it(`should click on the add greuge button`, async() => { const url = await nightmare .waitToClick(selectors.clientGreuge.addGreugeFloatButton) .waitForURL('greuge/create') @@ -20,17 +20,16 @@ describe('Client Add greuge path', () => { expect(url.hash).toContain('greuge/create'); }); - it(`should receive an error if all fields are empty but date and type on submit`, async () => { + it(`should receive an error if all fields are empty but date and type on submit`, async() => { const result = await nightmare - .waitToClick(selectors.clientGreuge.typeInput) - .waitToClick(selectors.clientGreuge.typeSecondOption) + .autocompleteSearch(selectors.clientGreuge.typeAutocomplete, 'Diff') .click(selectors.clientGreuge.saveButton) .waitForLastSnackbar(); expect(result).toEqual('Some fields are invalid'); }); - it(`should create a new greuge with all its data`, async () => { + it(`should create a new greuge with all its data`, async() => { const result = await nightmare .type(selectors.clientGreuge.amountInput, 999) .waitForTextInInput(selectors.clientGreuge.amountInput, '999') @@ -41,7 +40,7 @@ describe('Client Add greuge path', () => { expect(result).toEqual('Data saved!'); }); - it('should confirm the greuge was added to the list', async () => { + it('should confirm the greuge was added to the list', async() => { const result = await nightmare .waitToGetProperty(selectors.clientGreuge.firstGreugeText, 'innerText'); diff --git a/e2e/paths/item-module/02_edit_item_basic_data.spec.js b/e2e/paths/item-module/02_edit_item_basic_data.spec.js index 3cd383115..d931a4e8d 100644 --- a/e2e/paths/item-module/02_edit_item_basic_data.spec.js +++ b/e2e/paths/item-module/02_edit_item_basic_data.spec.js @@ -11,31 +11,27 @@ describe('Item Edit basic data path', () => { .accessToSection('item.card.data'); }); - it(`should edit the item basic data`, async () => { + it(`should edit the item basic data`, async() => { const result = await nightmare .wait(selectors.itemBasicData.nameInput) .clearInput(selectors.itemBasicData.nameInput) .type(selectors.itemBasicData.nameInput, 'Rose of Purity') - .waitToClick(selectors.itemBasicData.typeSelect) - .waitToClick(selectors.itemBasicData.typeSelectOptionThree) - .waitToClick(selectors.itemBasicData.intrastatSelect) - .waitToClick(selectors.itemBasicData.intrastatSelectOptionOne) + .autocompleteSearch(selectors.itemBasicData.typeAutocomplete, 'Crisantemo') + .autocompleteSearch(selectors.itemBasicData.intrastatAutocomplete, 'Coral y materiales similares') .clearInput(selectors.itemBasicData.relevancyInput) .type(selectors.itemBasicData.relevancyInput, '1') - .waitToClick(selectors.itemBasicData.originSelect) - .waitToClick(selectors.itemBasicData.originSelectOptionTwo) - .waitToClick(selectors.itemBasicData.expenceSelect) - .waitToClick(selectors.itemBasicData.expenceSelectOptionThree) + .autocompleteSearch(selectors.itemBasicData.originAutocomplete, 'Spain') + .autocompleteSearch(selectors.itemBasicData.expenceAutocomplete, 'Alquiler VNH') .clearInput(selectors.itemBasicData.longNameInput) .type(selectors.itemBasicData.longNameInput, 'RS Rose of Purity') .waitToClick(selectors.itemBasicData.isActiveCheckbox) - .click(selectors.itemBasicData.submitBasicDataButton) + .waitToClick(selectors.itemBasicData.submitBasicDataButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); - }); + }, 15000); - it(`should confirm the item name was edited`, async () => { + it(`should confirm the item name was edited`, async() => { const result = await nightmare .click(selectors.itemNiches.nicheButton) .wait(selectors.itemNiches.firstWarehouseDisabled) @@ -45,49 +41,49 @@ describe('Item Edit basic data path', () => { expect(result).toEqual('Rose of Purity'); }); - it(`should confirm the item type was edited`, async () => { + it(`should confirm the item type was edited`, async() => { const result = await nightmare - .waitToGetProperty(selectors.itemBasicData.typeSelect, 'value'); + .waitToGetProperty(`${selectors.itemBasicData.typeAutocomplete} input`, 'value'); expect(result).toEqual('Crisantemo'); }); - it(`should confirm the item intrastad was edited`, async () => { + it(`should confirm the item intrastad was edited`, async() => { const result = await nightmare - .waitToGetProperty(selectors.itemBasicData.intrastatSelect, 'value'); + .waitToGetProperty(`${selectors.itemBasicData.intrastatAutocomplete} input`, 'value'); expect(result).toEqual('5080000 Coral y materiales similares'); }); - it(`should confirm the item relevancy was edited`, async () => { + it(`should confirm the item relevancy was edited`, async() => { const result = await nightmare .waitToGetProperty(selectors.itemBasicData.relevancyInput, 'value'); expect(result).toEqual('1'); }); - it(`should confirm the item origin was edited`, async () => { + it(`should confirm the item origin was edited`, async() => { const result = await nightmare - .waitToGetProperty(selectors.itemBasicData.originSelect, 'value'); + .waitToGetProperty(`${selectors.itemBasicData.originAutocomplete} input`, 'value'); expect(result).toEqual('Spain'); }); - it(`should confirm the item expence was edited`, async () => { + it(`should confirm the item expence was edited`, async() => { const result = await nightmare - .waitToGetProperty(selectors.itemBasicData.expenceSelect, 'value'); + .waitToGetProperty(`${selectors.itemBasicData.expenceAutocomplete} input`, 'value'); - expect(result).toEqual('Adquisición mercancia Extracomunitaria'); + expect(result).toEqual('Alquiler VNH'); }); - it(`should confirm the item long name was edited`, async () => { + it(`should confirm the item long name was edited`, async() => { const result = await nightmare .waitToGetProperty(selectors.itemBasicData.longNameInput, 'value'); expect(result).toEqual('RS Rose of Purity'); }); - it('should confirm isActive checkbox is unchecked', async () => { + it('should confirm isActive checkbox is unchecked', async() => { const result = await nightmare .evaluate(selector => { return document.querySelector(selector).checked; diff --git a/e2e/paths/item-module/03_edit_item_tax.spec.js b/e2e/paths/item-module/03_edit_item_tax.spec.js index 2db067481..7fa370ebc 100644 --- a/e2e/paths/item-module/03_edit_item_tax.spec.js +++ b/e2e/paths/item-module/03_edit_item_tax.spec.js @@ -11,42 +11,38 @@ describe('Item edit tax path', () => { .accessToSection('item.card.tax'); }); - it(`should add the item tax to all countries`, async () => { + it(`should add the item tax to all countries`, async() => { const result = await nightmare - .waitToClick(selectors.itemTax.firstClassSelect) - .waitToClick(selectors.itemTax.firstClassSelectOptionTwo) - .waitToClick(selectors.itemTax.secondClassSelect) - .waitToClick(selectors.itemTax.secondClassSelectOptionOne) - .waitToClick(selectors.itemTax.thirdClassSelect) - .waitToClick(selectors.itemTax.thirdClassSelectOptionTwo) + .autocompleteSearch(selectors.itemTax.firstClassAutocomplete, 'Reduced VAT') + .autocompleteSearch(selectors.itemTax.secondClassAutocomplete, 'General VAT') + .autocompleteSearch(selectors.itemTax.thirdClassAutocomplete, 'Reduced VAT') .click(selectors.itemTax.submitTaxButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it(`should confirm the first item tax class was edited`, async () => { + it(`should confirm the first item tax class was edited`, async() => { const firstVatType = await nightmare .click(selectors.itemTags.tagsButton) .wait(selectors.itemTags.firstTagDisabled) .click(selectors.itemTax.taxButton) .waitToClick(selectors.itemTax.taxButton) - .waitForTextInInput(selectors.itemTax.firstClassSelect, 'reduced') - .waitToGetProperty(selectors.itemTax.firstClassSelect, 'value'); + .waitToGetProperty(`${selectors.itemTax.firstClassAutocomplete} input`, 'value'); expect(firstVatType).toEqual('Reduced VAT'); }); - it(`should confirm the second item tax class was edited`, async () => { + it(`should confirm the second item tax class was edited`, async() => { const secondVatType = await nightmare - .waitToGetProperty(selectors.itemTax.secondClassSelect, 'value'); + .waitToGetProperty(`${selectors.itemTax.secondClassAutocomplete} input`, 'value'); expect(secondVatType).toEqual('General VAT'); }); - it(`should confirm the third item tax class was edited`, async () => { + it(`should confirm the third item tax class was edited`, async() => { const thirdVatType = await nightmare - .waitToGetProperty(selectors.itemTax.thirdClassSelect, 'value'); + .waitToGetProperty(`${selectors.itemTax.thirdClassAutocomplete} input`, 'value'); expect(thirdVatType).toEqual('Reduced VAT'); }); diff --git a/e2e/paths/item-module/04_create_item_tags.spec.js b/e2e/paths/item-module/04_create_item_tags.spec.js index 075dfd478..85519eeb3 100644 --- a/e2e/paths/item-module/04_create_item_tags.spec.js +++ b/e2e/paths/item-module/04_create_item_tags.spec.js @@ -11,12 +11,11 @@ describe('Item create tags path', () => { .accessToSection('item.card.tags'); }); - it(`should create a new tag and delete a former one`, async () => { + it(`should create a new tag and delete a former one`, async() => { const result = await nightmare .waitToClick(selectors.itemTags.firstRemoveTagButton) .waitToClick(selectors.itemTags.addItemTagButton) - .waitToClick(selectors.itemTags.seventhTagSelect) - .waitToClick(selectors.itemTags.seventhTagSelectOptionFive) + .autocompleteSearch(selectors.itemTags.seventhTagAutocomplete, 'Ancho de la base') .type(selectors.itemTags.seventhValueInput, '50') .clearInput(selectors.itemTags.seventhRelevancyInput) .type(selectors.itemTags.seventhRelevancyInput, '1') @@ -26,13 +25,13 @@ describe('Item create tags path', () => { expect(result).toEqual('Data saved!'); }); - it(`should confirm the first row data is the expected one`, async () => { + it(`should confirm the first row data is the expected one`, async() => { let result = await nightmare .click(selectors.itemBasicData.basicDataButton) .wait(selectors.itemBasicData.nameInput) .click(selectors.itemTags.tagsButton) .wait('vn-item-tags') - .waitToGetProperty(selectors.itemTags.firstTagSelect, 'value'); + .waitToGetProperty(`${selectors.itemTags.firstTagAutocomplete} input`, 'value'); expect(result).toEqual('Ancho de la base'); @@ -47,9 +46,9 @@ describe('Item create tags path', () => { expect(result).toEqual('1'); }); - it(`should confirm the second row data is the expected one`, async () => { + it(`should confirm the second row data is the expected one`, async() => { let tag = await nightmare - .waitToGetProperty(selectors.itemTags.secondTagSelect, 'value'); + .waitToGetProperty(`${selectors.itemTags.secondTagAutocomplete} input`, 'value'); let value = await nightmare .waitToGetProperty(selectors.itemTags.secondValueInput, 'value'); @@ -62,9 +61,9 @@ describe('Item create tags path', () => { expect(relevancy).toEqual('2'); }); - it(`should confirm the third row data is the expected one`, async () => { + it(`should confirm the third row data is the expected one`, async() => { let tag = await nightmare - .waitToGetProperty(selectors.itemTags.thirdTagSelect, 'value'); + .waitToGetProperty(`${selectors.itemTags.thirdTagAutocomplete} input`, 'value'); let value = await nightmare .waitToGetProperty(selectors.itemTags.thirdValueInput, 'value'); @@ -77,9 +76,9 @@ describe('Item create tags path', () => { expect(relevancy).toEqual('3'); }); - it(`should confirm the fourth row data is the expected one`, async () => { + it(`should confirm the fourth row data is the expected one`, async() => { let tag = await nightmare - .waitToGetProperty(selectors.itemTags.fourthTagSelect, 'value'); + .waitToGetProperty(`${selectors.itemTags.fourthTagAutocomplete} input`, 'value'); let value = await nightmare .waitToGetProperty(selectors.itemTags.fourthValueInput, 'value'); @@ -92,9 +91,9 @@ describe('Item create tags path', () => { expect(relevancy).toEqual('4'); }); - it(`should confirm the fifth row data is the expected one`, async () => { + it(`should confirm the fifth row data is the expected one`, async() => { let tag = await nightmare - .waitToGetProperty(selectors.itemTags.fifthTagSelect, 'value'); + .waitToGetProperty(`${selectors.itemTags.fifthTagAutocomplete} input`, 'value'); let value = await nightmare .waitToGetProperty(selectors.itemTags.fifthValueInput, 'value'); diff --git a/e2e/paths/item-module/05_create_item_niche.spec.js b/e2e/paths/item-module/05_create_item_niche.spec.js index a3c2b1d3d..65483561b 100644 --- a/e2e/paths/item-module/05_create_item_niche.spec.js +++ b/e2e/paths/item-module/05_create_item_niche.spec.js @@ -11,12 +11,11 @@ describe('Item create niche path', () => { .accessToSection('item.card.niche'); }); - it(`should click create a new niche and delete a former one`, async () => { + it(`should click create a new niche and delete a former one`, async() => { const result = await nightmare .waitToClick(selectors.itemNiches.addNicheButton) .waitToClick(selectors.itemNiches.secondNicheRemoveButton) - .waitToClick(selectors.itemNiches.thirdWarehouseSelect) - .waitToClick(selectors.itemNiches.thirdWarehouseSelectFourthOption) + .autocompleteSearch(selectors.itemNiches.thirdWarehouseAutocomplete, 'Warehouse Two') .type(selectors.itemNiches.thirdCodeInput, 'A4') .click(selectors.itemNiches.submitNichesButton) .waitForLastSnackbar(); @@ -24,13 +23,13 @@ describe('Item create niche path', () => { expect(result).toEqual('Data saved!'); }); - it(`should confirm the first niche is the expected one`, async () => { + it(`should confirm the first niche is the expected one`, async() => { let result = await nightmare .click(selectors.itemBasicData.basicDataButton) .wait(selectors.itemBasicData.nameInput) .click(selectors.itemNiches.nicheButton) - .waitForTextInInput(selectors.itemNiches.firstWarehouseSelect, 'Warehouse One') - .waitToGetProperty(selectors.itemNiches.firstWarehouseSelect, 'value'); + .waitForTextInInput(`${selectors.itemNiches.firstWarehouseAutocomplete} input`, 'Warehouse One') + .waitToGetProperty(`${selectors.itemNiches.firstWarehouseAutocomplete} input`, 'value'); expect(result).toEqual('Warehouse One'); result = await nightmare @@ -39,9 +38,9 @@ describe('Item create niche path', () => { expect(result).toEqual('A1'); }); - it(`should confirm the second niche is the expected one`, async () => { + it(`should confirm the second niche is the expected one`, async() => { let result = await nightmare - .waitToGetProperty(selectors.itemNiches.secondWarehouseSelect, 'value'); + .waitToGetProperty(`${selectors.itemNiches.secondWarehouseAutocomplete} input`, 'value'); expect(result).toEqual('Warehouse Three'); result = await nightmare @@ -51,9 +50,9 @@ describe('Item create niche path', () => { expect(result).toEqual('A3'); }); - it(`should confirm the third niche is the expected one`, async () => { + it(`should confirm the third niche is the expected one`, async() => { let result = await nightmare - .waitToGetProperty(selectors.itemNiches.thirdWarehouseSelect, 'value'); + .waitToGetProperty(`${selectors.itemNiches.thirdWarehouseAutocomplete} input`, 'value'); expect(result).toEqual('Warehouse Two'); result = await nightmare diff --git a/e2e/paths/item-module/06_create_item_botanical.spec.js b/e2e/paths/item-module/06_create_item_botanical.spec.js index d52c877d4..a7f91a8d8 100644 --- a/e2e/paths/item-module/06_create_item_botanical.spec.js +++ b/e2e/paths/item-module/06_create_item_botanical.spec.js @@ -11,21 +11,19 @@ describe('Item Create botanical path', () => { .accessToSection('item.card.botanical'); }); - it(`should create a new botanical for the item Mjolnir`, async () => { + it(`should create a new botanical for the item Mjolnir`, async() => { const result = await nightmare .wait(selectors.itemBotanical.botanicalInput) .type(selectors.itemBotanical.botanicalInput, 'Cicuta maculata') - .waitToClick(selectors.itemBotanical.genusSelect) - .waitToClick(selectors.itemBotanical.genusSelectOptionOne) - .waitToClick(selectors.itemBotanical.speciesSelect) - .waitToClick(selectors.itemBotanical.speciesSelectOptionOne) + .autocompleteSearch(selectors.itemBotanical.genusAutocomplete, 'Abelia') + .autocompleteSearch(selectors.itemBotanical.speciesAutocomplete, 'dealbata') .waitToClick(selectors.itemBotanical.submitBotanicalButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it(`should confirm the botanical for item Mjolnir was created`, async () => { + it(`should confirm the botanical for item Mjolnir was created`, async() => { const result = await nightmare .click(selectors.itemBasicData.basicDataButton) .wait(selectors.itemBasicData.nameInput) @@ -36,36 +34,34 @@ describe('Item Create botanical path', () => { expect(result).toEqual('Cicuta maculata'); }); - it(`should confirm the Genus for item Mjolnir was created`, async () => { + it(`should confirm the Genus for item Mjolnir was created`, async() => { const result = await nightmare - .waitForTextInInput(selectors.itemBotanical.genusSelect, 'Abelia') - .waitToGetProperty(selectors.itemBotanical.genusSelect, 'value'); + .waitForTextInInput(`${selectors.itemBotanical.genusAutocomplete} input`, 'Abelia') + .waitToGetProperty(`${selectors.itemBotanical.genusAutocomplete} input`, 'value'); expect(result).toEqual('Abelia'); }); - it(`should confirm the Species for item Mjolnir was created`, async () => { + it(`should confirm the Species for item Mjolnir was created`, async() => { const result = await nightmare - .waitToGetProperty(selectors.itemBotanical.speciesSelect, 'value'); + .waitToGetProperty(`${selectors.itemBotanical.speciesAutocomplete} input`, 'value'); expect(result).toEqual('dealbata'); }); - it(`should edit botanical for the item Mjolnir`, async () => { + it(`should edit botanical for the item Mjolnir`, async() => { const result = await nightmare .clearInput(selectors.itemBotanical.botanicalInput) .type(selectors.itemBotanical.botanicalInput, 'Herp Derp') - .waitToClick(selectors.itemBotanical.genusSelect) - .waitToClick(selectors.itemBotanical.genusSelectOptionTwo) - .waitToClick(selectors.itemBotanical.speciesSelect) - .waitToClick(selectors.itemBotanical.speciesSelectOptionTwo) + .autocompleteSearch(selectors.itemBotanical.genusAutocomplete, 'Abies') + .autocompleteSearch(selectors.itemBotanical.speciesAutocomplete, 'decurrens') .waitToClick(selectors.itemBotanical.submitBotanicalButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it(`should confirm the botanical for item Mjolnir was edited`, async () => { + it(`should confirm the botanical for item Mjolnir was edited`, async() => { const result = await nightmare .click(selectors.itemBasicData.basicDataButton) .wait(selectors.itemBasicData.nameInput) @@ -76,17 +72,17 @@ describe('Item Create botanical path', () => { expect(result).toEqual('Herp Derp'); }); - it(`should confirm the Genus for item Mjolnir was edited`, async () => { + it(`should confirm the Genus for item Mjolnir was edited`, async() => { const result = await nightmare - .waitForTextInInput(selectors.itemBotanical.genusSelect, 'Abies') - .waitToGetProperty(selectors.itemBotanical.genusSelect, 'value'); + .waitForTextInInput(`${selectors.itemBotanical.genusAutocomplete} input`, 'Abies') + .waitToGetProperty(`${selectors.itemBotanical.genusAutocomplete} input`, 'value'); expect(result).toEqual('Abies'); }); - it(`should confirm the Species for item Mjolnir was edited`, async () => { + it(`should confirm the Species for item Mjolnir was edited`, async() => { const result = await nightmare - .waitToGetProperty(selectors.itemBotanical.speciesSelect, 'value'); + .waitToGetProperty(`${selectors.itemBotanical.speciesAutocomplete} input`, 'value'); expect(result).toEqual('decurrens'); }); diff --git a/e2e/paths/item-module/08_item_create_and_clone.spec.js b/e2e/paths/item-module/08_item_create_and_clone.spec.js index 31a31b52e..2d82c16d8 100644 --- a/e2e/paths/item-module/08_item_create_and_clone.spec.js +++ b/e2e/paths/item-module/08_item_create_and_clone.spec.js @@ -9,7 +9,7 @@ describe('Item Create/Clone path', () => { .loginAndModule('buyer', 'item'); }); - it(`should search for the item Infinity Gauntlet to confirm it isn't created yet`, async () => { + it(`should search for the item Infinity Gauntlet to confirm it isn't created yet`, async() => { const result = await nightmare .wait(selectors.itemsIndex.searchItemInput) .type(selectors.itemsIndex.searchItemInput, 'Infinity Gauntlet') @@ -20,7 +20,7 @@ describe('Item Create/Clone path', () => { expect(result).toEqual(0); }); - it('should access to the create item view by clicking the create floating button', async () => { + it('should access to the create item view by clicking the create floating button', async() => { const url = await nightmare .click(selectors.itemsIndex.createItemButton) .wait(selectors.itemCreateView.createButton) @@ -29,7 +29,7 @@ describe('Item Create/Clone path', () => { expect(url.hash).toEqual('#!/item/create'); }); - it('should return to the item index by clickig the cancel button', async () => { + it('should return to the item index by clickig the cancel button', async() => { const url = await nightmare .click(selectors.itemCreateView.cancelButton) .wait(selectors.itemsIndex.createItemButton) @@ -38,7 +38,7 @@ describe('Item Create/Clone path', () => { expect(url.hash).toEqual('#!/item/index'); }); - it('should now access to the create item view by clicking the create floating button', async () => { + it('should now access to the create item view by clicking the create floating button', async() => { const url = await nightmare .click(selectors.itemsIndex.createItemButton) .wait(selectors.itemCreateView.createButton) @@ -47,22 +47,19 @@ describe('Item Create/Clone path', () => { expect(url.hash).toEqual('#!/item/create'); }); - it('should create the Infinity Gauntlet item', async () => { + it('should create the Infinity Gauntlet item', async() => { const result = await nightmare .type(selectors.itemCreateView.name, 'Infinity Gauntlet') - .waitToClick(selectors.itemCreateView.typeSelect) - .waitToClick(selectors.itemCreateView.typeSelectOptionThree) - .waitToClick(selectors.itemCreateView.intrastatSelect) - .waitToClick(selectors.itemCreateView.intrastatSelectOptionOne) - .waitToClick(selectors.itemCreateView.originSelect) - .waitToClick(selectors.itemCreateView.originSelectOptionOne) + .autocompleteSearch(selectors.itemCreateView.typeAutocomplete, 'Crisantemo') + .autocompleteSearch(selectors.itemCreateView.intrastatAutocomplete, 'Coral y materiales similares') + .autocompleteSearch(selectors.itemCreateView.originAutocomplete, 'Holand') .click(selectors.itemCreateView.createButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it('should confirm Infinity Gauntlet item was created', async () => { + it('should confirm Infinity Gauntlet item was created', async() => { let result = await nightmare .waitToGetProperty(selectors.itemBasicData.nameInput, 'value'); @@ -70,24 +67,24 @@ describe('Item Create/Clone path', () => { result = await nightmare - .waitToGetProperty(selectors.itemBasicData.typeSelect, 'value'); + .waitToGetProperty(`${selectors.itemBasicData.typeAutocomplete} input`, 'value'); expect(result).toEqual('Crisantemo'); result = await nightmare - .waitToGetProperty(selectors.itemBasicData.intrastatSelect, 'value'); + .waitToGetProperty(`${selectors.itemBasicData.intrastatAutocomplete} input`, 'value'); - expect(result).toEqual('6021010 Plantas vivas: Esqueje/injerto, Vid'); + expect(result).toEqual('5080000 Coral y materiales similares'); result = await nightmare - .waitToGetProperty(selectors.itemBasicData.originSelect, 'value'); + .waitToGetProperty(`${selectors.itemBasicData.originAutocomplete} input`, 'value'); - expect(result).toEqual('Spain'); + expect(result).toEqual('Holand'); }); }); describe('clone', () => { - it('should return to the items index by clicking the return to items button', async () => { + it('should return to the items index by clicking the return to items button', async() => { const url = await nightmare .click(selectors.itemBasicData.goToItemIndexButton) .wait(selectors.itemsIndex.createItemButton) @@ -97,7 +94,7 @@ describe('Item Create/Clone path', () => { expect(url.hash).toContain('#!/item/index'); }); - it(`should search for the item Infinity Gauntlet`, async () => { + it(`should search for the item Infinity Gauntlet`, async() => { const result = await nightmare .wait(selectors.itemsIndex.searchItemInput) .type(selectors.itemsIndex.searchItemInput, 'Infinity Gauntlet') @@ -108,7 +105,7 @@ describe('Item Create/Clone path', () => { expect(result).toEqual(1); }); - it(`should clone the Infinity Gauntlet`, async () => { + it(`should clone the Infinity Gauntlet`, async() => { const url = await nightmare .waitForTextInElement(selectors.itemsIndex.searchResult, 'Infinity Gauntlet') .click(selectors.itemsIndex.searchResultCloneButton) @@ -119,7 +116,7 @@ describe('Item Create/Clone path', () => { expect(url.hash).toContain('tags'); }); - it('should search for the item Infinity Gauntlet and find two', async () => { + it('should search for the item Infinity Gauntlet and find two', async() => { const result = await nightmare .waitToClick(selectors.itemTags.goToItemIndexButton) .wait(selectors.itemsIndex.searchItemInput) diff --git a/e2e/paths/item-module/09_regularize_item.spec.js b/e2e/paths/item-module/09_regularize_item.spec.js index 933572495..68a59009d 100644 --- a/e2e/paths/item-module/09_regularize_item.spec.js +++ b/e2e/paths/item-module/09_regularize_item.spec.js @@ -8,7 +8,7 @@ describe('Item regularize path', () => { .loginAndModule('employee', 'item'); }); - it('should search for the item Mjolnir', async () => { + it('should search for the item Mjolnir', async() => { const resultCount = await nightmare .wait(selectors.itemsIndex.searchItemInput) .type(selectors.itemsIndex.searchItemInput, 'Mjolnir') @@ -19,7 +19,7 @@ describe('Item regularize path', () => { expect(resultCount).toEqual(1); }); - it(`should click on the search result to access to the item tax`, async () => { + it(`should click on the search result to access to the item tax`, async() => { const url = await nightmare .waitForTextInElement(selectors.itemsIndex.searchResult, 'Mjolnir') .waitToClick(selectors.itemsIndex.searchResult) @@ -29,21 +29,20 @@ describe('Item regularize path', () => { expect(url.hash).toContain('/summary'); }); - it('should regularize the item', async () => { + it('should regularize the item', async() => { const result = await nightmare .waitToClick(selectors.itemDescriptor.moreMenu) .waitToClick(selectors.itemDescriptor.moreMenuRegularizeButton) .wait(selectors.itemDescriptor.regularizeQuantityInput) .type(selectors.itemDescriptor.regularizeQuantityInput, 100) - .waitToClick(selectors.itemDescriptor.regularizeWarehouseSelect) - .waitToClick(selectors.itemDescriptor.regularizeWarehouseSelectSecondOption) + .autocompleteSearch(selectors.itemDescriptor.regularizeWarehouseAutocomplete, 'Warehouse One') .waitToClick(selectors.itemDescriptor.regularizeSaveButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it('should click on the Tickets button of the top bar menu', async () => { + it('should click on the Tickets button of the top bar menu', async() => { const url = await nightmare .waitToClick(selectors.globalItems.applicationsMenuButton) .wait(selectors.globalItems.applicationsMenuVisible) @@ -54,7 +53,7 @@ describe('Item regularize path', () => { expect(url.hash).toEqual('#!/ticket/index'); }); - it('should search for the ticket with alias missing', async () => { + it('should search for the ticket with alias missing', async() => { const result = await nightmare .wait(selectors.ticketsIndex.searchTicketInput) .type(selectors.ticketsIndex.searchTicketInput, 'missing') @@ -65,7 +64,7 @@ describe('Item regularize path', () => { expect(result).toEqual(1); }); - it(`should click on the search result to access to the ticket summary`, async () => { + it(`should click on the search result to access to the ticket summary`, async() => { const url = await nightmare .waitForTextInElement(selectors.ticketsIndex.searchResult, 'Missing') .waitToClick(selectors.ticketsIndex.searchResult) @@ -75,7 +74,7 @@ describe('Item regularize path', () => { expect(url.hash).toContain('/summary'); }); - it(`should check the ticket sale quantity is showing a negative value`, async () => { + it(`should check the ticket sale quantity is showing a negative value`, async() => { const result = await nightmare .waitForTextInElement(selectors.ticketSummary.firstSaleQuantity, '-100') .waitToGetProperty(selectors.ticketSummary.firstSaleQuantity, 'innerText'); @@ -83,14 +82,14 @@ describe('Item regularize path', () => { expect(result).toContain('-100'); }); - it(`should check the ticket sale discount is 100%`, async () => { + it(`should check the ticket sale discount is 100%`, async() => { const result = await nightmare .waitToGetProperty(selectors.ticketSummary.firstSaleDiscount, 'innerText'); expect(result).toContain('100 %'); }); - it('should now click on the Items button of the top bar menu', async () => { + it('should now click on the Items button of the top bar menu', async() => { const url = await nightmare .waitToClick(selectors.globalItems.applicationsMenuButton) .wait(selectors.globalItems.applicationsMenuVisible) @@ -101,7 +100,7 @@ describe('Item regularize path', () => { expect(url.hash).toEqual('#!/item/index'); }); - it('should search for the item Mjolnir once again', async () => { + it('should search for the item Mjolnir once again', async() => { const resultCount = await nightmare .wait(selectors.itemsIndex.searchItemInput) .type(selectors.itemsIndex.searchItemInput, 'Mjolnir') @@ -112,7 +111,7 @@ describe('Item regularize path', () => { expect(resultCount).toEqual(1); }); - it(`should click on the search result to access to the item tax`, async () => { + it(`should click on the search result to access to the item tax`, async() => { const url = await nightmare .waitForTextInElement(selectors.itemsIndex.searchResult, 'Mjolnir') .waitToClick(selectors.itemsIndex.searchResult) @@ -122,21 +121,20 @@ describe('Item regularize path', () => { expect(url.hash).toContain('/summary'); }); - it('should regularize the item once more', async () => { + it('should regularize the item once more', async() => { const result = await nightmare .waitToClick(selectors.itemDescriptor.moreMenu) .waitToClick(selectors.itemDescriptor.moreMenuRegularizeButton) .wait(selectors.itemDescriptor.regularizeQuantityInput) .type(selectors.itemDescriptor.regularizeQuantityInput, 100) - .waitToClick(selectors.itemDescriptor.regularizeWarehouseSelect) - .waitToClick(selectors.itemDescriptor.regularizeWarehouseSelectSecondOption) + .autocompleteSearch(selectors.itemDescriptor.regularizeWarehouseAutocomplete, 'Warehouse One') .waitToClick(selectors.itemDescriptor.regularizeSaveButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it('should again click on the Tickets button of the top bar menu', async () => { + it('should again click on the Tickets button of the top bar menu', async() => { const url = await nightmare .waitToClick(selectors.globalItems.applicationsMenuButton) .wait(selectors.globalItems.applicationsMenuVisible) @@ -147,7 +145,7 @@ describe('Item regularize path', () => { expect(url.hash).toEqual('#!/ticket/index'); }); - it('should search for the ticket with id 22 once again', async () => { + it('should search for the ticket with id 22 once again', async() => { const result = await nightmare .wait(selectors.ticketsIndex.searchTicketInput) .type(selectors.ticketsIndex.searchTicketInput, 'id:22') @@ -158,7 +156,7 @@ describe('Item regularize path', () => { expect(result).toEqual(1); }); - it(`should now click on the search result to access to the ticket summary`, async () => { + it(`should now click on the search result to access to the ticket summary`, async() => { const url = await nightmare .waitForTextInElement(selectors.ticketsIndex.searchResult, '22') .waitToClick(selectors.ticketsIndex.searchResult) @@ -168,7 +166,7 @@ describe('Item regularize path', () => { expect(url.hash).toContain('/summary'); }); - it(`should check the ticket contains now two sales`, async () => { + it(`should check the ticket contains now two sales`, async() => { const result = await nightmare .waitForTextInElement(selectors.ticketSummary.firstSaleQuantity, '-100') .countElement(selectors.ticketSummary.sale); diff --git a/e2e/paths/ticket-module/01_create_ticket_observations.spec.js b/e2e/paths/ticket-module/01_create_ticket_observations.spec.js index 0a5a2b4ce..0beded970 100644 --- a/e2e/paths/ticket-module/01_create_ticket_observations.spec.js +++ b/e2e/paths/ticket-module/01_create_ticket_observations.spec.js @@ -11,12 +11,11 @@ describe('Ticket Create notes path', () => { .accessToSection('ticket.card.observation'); }); - it(`should click create a new note and delete a former one`, async () => { + it(`should click create a new note and delete a former one`, async() => { let result = await nightmare .waitToClick(selectors.ticketNotes.firstNoteRemoveButton) .waitToClick(selectors.ticketNotes.addNoteButton) - .waitToClick(selectors.ticketNotes.firstNoteSelect) - .waitToClick(selectors.ticketNotes.firstNoteSelectSecondOption) + .autocompleteSearch(selectors.ticketNotes.firstNoteTypeAutocomplete, 'observation one') .type(selectors.ticketNotes.firstDescriptionInput, 'description') .click(selectors.ticketNotes.submitNotesButton) .waitForLastSnackbar(); @@ -24,14 +23,14 @@ describe('Ticket Create notes path', () => { expect(result).toEqual('Data saved!'); }); - it(`should confirm the note is the expected one`, async () => { - let firstNoteSelect = await nightmare + it(`should confirm the note is the expected one`, async() => { + let result = await nightmare .click(selectors.ticketPackages.packagesButton) - .wait(selectors.ticketPackages.firstPackageSelect) + .wait(selectors.ticketPackages.firstPackageAutocomplete) .click(selectors.ticketNotes.notesButton) - .waitToGetProperty(selectors.ticketNotes.firstNoteSelect, 'value'); + .waitToGetProperty(`${selectors.ticketNotes.firstNoteTypeAutocomplete} input`, 'value'); - expect(firstNoteSelect).toEqual('observation one'); + expect(result).toEqual('observation one'); let firstDescription = await nightmare .waitToGetProperty(selectors.ticketNotes.firstDescriptionInput, 'value'); diff --git a/e2e/paths/ticket-module/02_delete_ticket_expeditions.spec.js b/e2e/paths/ticket-module/02_delete_ticket_expeditions.spec.js index 2d589ea9a..087613b3f 100644 --- a/e2e/paths/ticket-module/02_delete_ticket_expeditions.spec.js +++ b/e2e/paths/ticket-module/02_delete_ticket_expeditions.spec.js @@ -11,12 +11,12 @@ describe('Ticket Delete expeditions path', () => { .accessToSection('ticket.card.expedition'); }); - it(`should delete a former expedition and confirm the remaining expedition are the expected ones`, async () => { + it(`should delete a former expedition and confirm the remaining expedition are the expected ones`, async() => { const result = await nightmare .waitToClick(selectors.ticketExpedition.secondExpeditionRemoveButton) .waitToClick(selectors.ticketExpedition.acceptDeleteRowButton) .click(selectors.ticketPackages.packagesButton) - .wait(selectors.ticketPackages.firstPackageSelect) + .wait(selectors.ticketPackages.firstPackageAutocomplete) .click(selectors.ticketExpedition.expeditionButton) .wait(selectors.ticketExpedition.expeditionRow) .countElement(selectors.ticketExpedition.expeditionRow); diff --git a/e2e/paths/ticket-module/04_create_ticket_packages.spec.js b/e2e/paths/ticket-module/04_create_ticket_packages.spec.js index 1f514fb3a..39536da61 100644 --- a/e2e/paths/ticket-module/04_create_ticket_packages.spec.js +++ b/e2e/paths/ticket-module/04_create_ticket_packages.spec.js @@ -11,19 +11,18 @@ describe('Ticket Create packages path', () => { .accessToSection('ticket.card.package.index'); }); - it(`should delete the first package and receive and error to save a new one with blank quantity`, async () => { + it(`should delete the first package and receive and error to save a new one with blank quantity`, async() => { const result = await nightmare .waitToClick(selectors.ticketPackages.firstRemovePackageButton) .waitToClick(selectors.ticketPackages.addPackageButton) - .waitToClick(selectors.ticketPackages.firstPackageSelect) - .waitToClick(selectors.ticketPackages.firstPackageSelectOptionTwo) + .autocompleteSearch(selectors.ticketPackages.firstPackageAutocomplete, 'Legendary Box') .click(selectors.ticketPackages.savePackagesButton) .waitForLastSnackbar(); expect(result).toEqual('Some fields are invalid'); }); - it(`should attempt create a new package but receive an error if quantity is a string`, async () => { + it(`should attempt create a new package but receive an error if quantity is a string`, async() => { const result = await nightmare .type(selectors.ticketPackages.firstQuantityInput, 'ninety 9') .click(selectors.ticketPackages.savePackagesButton) @@ -32,7 +31,7 @@ describe('Ticket Create packages path', () => { expect(result).toEqual('Some fields are invalid'); }); - it(`should attempt create a new package but receive an error if quantity is 0`, async () => { + it(`should attempt create a new package but receive an error if quantity is 0`, async() => { const result = await nightmare .clearInput(selectors.ticketPackages.firstQuantityInput) .type(selectors.ticketPackages.firstQuantityInput, 0) @@ -42,40 +41,38 @@ describe('Ticket Create packages path', () => { expect(result).toEqual('Some fields are invalid'); }); - it(`should attempt create a new package but receive an error if package is blank`, async () => { + it(`should attempt create a new package but receive an error if package is blank`, async() => { const result = await nightmare .clearInput(selectors.ticketPackages.firstQuantityInput) .type(selectors.ticketPackages.firstQuantityInput, 99) - .click(selectors.ticketPackages.clearPackageSelectButton) + .click(selectors.ticketPackages.clearPackageAutocompleteButton) .click(selectors.ticketPackages.savePackagesButton) .waitForLastSnackbar(); expect(result).toEqual('Package cannot be blank'); }); - it(`should create a new package with correct data`, async () => { + it(`should create a new package with correct data`, async() => { const result = await nightmare - .waitToClick(selectors.ticketPackages.firstPackageSelect) - .waitToClick(selectors.ticketPackages.firstPackageSelectOptionTwo) - .waitForTextInInput(selectors.ticketPackages.firstPackageSelect, 'Legendary Box') + .autocompleteSearch(selectors.ticketPackages.firstPackageAutocomplete, 'Legendary Box') .click(selectors.ticketPackages.savePackagesButton) .waitForLastSnackbar(); expect(result).toEqual('Data saved!'); }); - it(`should confirm the first select is the expected one`, async () => { + it(`should confirm the first select is the expected one`, async() => { const result = await nightmare - .click(selectors.ticketSales.saleButton) - .wait(selectors.ticketSales.firstPackageSelect) - .click(selectors.ticketPackages.packagesButton) - .waitForTextInInput(selectors.ticketPackages.firstPackageSelect, 'Legendary Box') - .waitToGetProperty(selectors.ticketPackages.firstPackageSelect, 'value'); + .waitToClick(selectors.ticketSales.saleButton) + .wait(selectors.ticketSales.firstPackageAutocomplete) + .waitToClick(selectors.ticketPackages.packagesButton) + .waitForTextInInput(`${selectors.ticketPackages.firstPackageAutocomplete} input`, 'Legendary Box') + .waitToGetProperty(`${selectors.ticketPackages.firstPackageAutocomplete} input`, 'value'); expect(result).toEqual('7 : Legendary Box'); }); - it(`should confirm the first quantity is the expected one`, async () => { + it(`should confirm the first quantity is the expected one`, async() => { const result = await nightmare .waitForTextInInput(selectors.ticketPackages.firstQuantityInput, '99') .waitToGetProperty(selectors.ticketPackages.firstQuantityInput, 'value'); diff --git a/e2e/paths/ticket-module/05_create_new_tracking_state.spec.js b/e2e/paths/ticket-module/05_create_new_tracking_state.spec.js index 7af14fb6d..44f3dae51 100644 --- a/e2e/paths/ticket-module/05_create_new_tracking_state.spec.js +++ b/e2e/paths/ticket-module/05_create_new_tracking_state.spec.js @@ -11,16 +11,16 @@ describe('Ticket Create new tracking state path', () => { .accessToSection('ticket.card.tracking.index'); }); - it('should access to the create state view by clicking the create floating button', async () => { + it('should access to the create state view by clicking the create floating button', async() => { let url = await nightmare .waitToClick(selectors.ticketTracking.createStateButton) - .wait(selectors.createStateView.stateInput) + .wait(selectors.createStateView.stateAutocomplete) .parsedUrl(); expect(url.hash).toContain('tracking/edit'); }); - it(`should attempt create a new state but receive an error if state is empty`, async () => { + it(`should attempt create a new state but receive an error if state is empty`, async() => { let result = await nightmare .click(selectors.createStateView.saveStateButton) .waitForLastSnackbar(); @@ -28,10 +28,9 @@ describe('Ticket Create new tracking state path', () => { expect(result).toEqual('No changes to save'); }); - it(`should attempt create a new state then clear and save it`, async () => { + it(`should attempt create a new state then clear and save it`, async() => { let result = await nightmare - .waitToClick(selectors.createStateView.stateInput) - .waitToClick(selectors.createStateView.stateInputOptionOne) + .autocompleteSearch(selectors.createStateView.stateAutocomplete, '¿Fecha?') .waitToClick(selectors.createStateView.clearStateInputButton) .click(selectors.createStateView.saveStateButton) .waitForLastSnackbar(); @@ -39,19 +38,18 @@ describe('Ticket Create new tracking state path', () => { expect(result).toEqual('Data saved!'); }); - it('should again access to the create state view by clicking the create floating button', async () => { + it('should again access to the create state view by clicking the create floating button', async() => { let url = await nightmare .click(selectors.ticketTracking.createStateButton) - .wait(selectors.createStateView.stateInput) + .wait(selectors.createStateView.stateAutocomplete) .parsedUrl(); expect(url.hash).toContain('tracking/edit'); }); - it(`should create a new state`, async () => { + it(`should create a new state`, async() => { let result = await nightmare - .waitToClick(selectors.createStateView.stateInput) - .waitToClick(selectors.createStateView.stateInputOptionOne) + .autocompleteSearch(selectors.createStateView.stateAutocomplete, '¿Fecha?') .click(selectors.createStateView.saveStateButton) .waitForLastSnackbar(); diff --git a/e2e/paths/ticket-module/06_edit_basic_data_steps.spec.js b/e2e/paths/ticket-module/06_edit_basic_data_steps.spec.js index 33d426388..8606dfbcb 100644 --- a/e2e/paths/ticket-module/06_edit_basic_data_steps.spec.js +++ b/e2e/paths/ticket-module/06_edit_basic_data_steps.spec.js @@ -11,14 +11,11 @@ describe('Ticket Edit basic data path', () => { .accessToSection('ticket.card.data.stepOne'); }); - it(`should edit the client and address of the ticket then click next`, async () => { + it(`should edit the client and address of the ticket then click next`, async() => { let url = await nightmare - .waitToClick(selectors.ticketBasicData.clientSelect) - .waitToClick(selectors.ticketBasicData.clientSelectThirdOption) + .autocompleteSearch(selectors.ticketBasicData.clientAutocomplete, 'Charles Xavier') .wait(500) - .waitToClick(selectors.ticketBasicData.addressSelect) - .waitToClick(selectors.ticketBasicData.addressSelectSecondOption) - .waitForTextInInput(selectors.ticketBasicData.addressSelect, 'Charles Xavier') + .autocompleteSearch(selectors.ticketBasicData.addressAutocomplete, 'Charles Xavier') .click(selectors.ticketBasicData.nextStepButton) .waitForURL('data/step-two') .parsedUrl(); @@ -26,14 +23,14 @@ describe('Ticket Edit basic data path', () => { expect(url.hash).toContain('data/step-two'); }); - it(`should have no price diference`, async () => { + it(`should have no price diference`, async() => { const result = await nightmare .waitToGetProperty(selectors.ticketBasicData.stepTwoTotalPriceDif, 'innerText'); expect(result).toContain('0'); }); - it(`should click next to move on to step three`, async () => { + it(`should click next to move on to step three`, async() => { let url = await nightmare .click(selectors.ticketBasicData.nextStepButton) .waitForURL('data/step-three') @@ -42,11 +39,9 @@ describe('Ticket Edit basic data path', () => { expect(url.hash).toContain('data/step-three'); }); - it(`should select a reason for the changes made then click on finalize`, async () => { + it(`should select a reason for the changes made then click on finalize`, async() => { let url = await nightmare - .waitToClick(selectors.ticketBasicData.chargesReason) - .waitToClick(selectors.ticketBasicData.chargesReasonFourthOption) - .waitForTextInInput(selectors.ticketBasicData.chargesReason, 'No realizar modificaciones en precios') + .autocompleteSearch(selectors.ticketBasicData.chargesReasonAutocomplete, 'No realizar modificaciones en precios') .waitToClick(selectors.ticketBasicData.finalizeButton) .waitForURL('summary') .parsedUrl(); @@ -54,7 +49,7 @@ describe('Ticket Edit basic data path', () => { expect(url.hash).toContain('summary'); }); - it(`should go back to ticket.basicData section`, async () => { + it(`should go back to ticket.basicData section`, async() => { let url = await nightmare .waitToClick(selectors.ticketBasicData.basicDataButton) .waitForURL('data/step-one') @@ -63,11 +58,9 @@ describe('Ticket Edit basic data path', () => { expect(url.hash).toContain('data/step-one'); }); - it(`should edit the ticket agency then click next`, async () => { + it(`should edit the ticket agency then click next`, async() => { let url = await nightmare - .waitToClick(selectors.ticketBasicData.agencySelect) - .waitToClick(selectors.ticketBasicData.agencySelectOptionSix) - .waitForTextInInput(selectors.ticketBasicData.agencySelect, 'Expensive') + .autocompleteSearch(selectors.ticketBasicData.agencyAutocomplete, 'Silla247Expensive') .click(selectors.ticketBasicData.nextStepButton) .waitForURL('data/step-two') .parsedUrl(); @@ -75,14 +68,14 @@ describe('Ticket Edit basic data path', () => { expect(url.hash).toContain('data/step-two'); }); - it(`should have a price diference`, async () => { + it(`should have a price diference`, async() => { const result = await nightmare .waitToGetProperty(selectors.ticketBasicData.stepTwoTotalPriceDif, 'innerText'); expect(result).toContain('-20.65 €'); }); - it(`should then click next to move on to step three`, async () => { + it(`should then click next to move on to step three`, async() => { let url = await nightmare .click(selectors.ticketBasicData.nextStepButton) .waitForURL('data/step-three') @@ -91,11 +84,9 @@ describe('Ticket Edit basic data path', () => { expect(url.hash).toContain('data/step-three'); }); - it(`should select a new reason for the changes made then click on finalize`, async () => { + it(`should select a new reason for the changes made then click on finalize`, async() => { let url = await nightmare - .waitToClick(selectors.ticketBasicData.chargesReason) - .waitToClick(selectors.ticketBasicData.chargesReasonFirstOption) - .waitForTextInInput(selectors.ticketBasicData.chargesReason, 'Cambiar los precios en el ticket') + .autocompleteSearch(selectors.ticketBasicData.chargesReasonAutocomplete, 'Cambiar los precios en el ticket') .click(selectors.ticketBasicData.finalizeButton) .waitForURL('summary') .parsedUrl(); diff --git a/e2e/paths/ticket-module/07_edit_sale.spec.js b/e2e/paths/ticket-module/07_edit_sale.spec.js index a0806994b..9ef21ed1d 100644 --- a/e2e/paths/ticket-module/07_edit_sale.spec.js +++ b/e2e/paths/ticket-module/07_edit_sale.spec.js @@ -11,17 +11,17 @@ describe('Ticket Edit sale path', () => { .accessToSection('ticket.card.sale'); }); - it(`should click on the first claim id to navigate over there`, async () => { + it(`should click on the first claim id to navigate over there`, async() => { const url = await nightmare .waitToClick(selectors.ticketSales.secondSaleClaimId) - .wait(selectors.claimBasicData.claimStateSelect) + .wait(selectors.claimBasicData.claimStateAutocomplete) .parsedUrl(); expect(url.hash).toEqual('#!/claim/2/basic-data'); }); - it('should now click on the Tickets button of the top bar menu', async () => { + it('should now click on the Tickets button of the top bar menu', async() => { const url = await nightmare .waitToClick(selectors.globalItems.applicationsMenuButton) .wait(selectors.globalItems.applicationsMenuVisible) @@ -32,7 +32,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toEqual('#!/ticket/index'); }); - it('should again search for a specific ticket', async () => { + it('should again search for a specific ticket', async() => { const result = await nightmare .wait(selectors.ticketsIndex.searchTicketInput) .type(selectors.ticketsIndex.searchTicketInput, 'id:16') @@ -43,7 +43,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(1); }); - it(`should now click on the search result to access to the ticket Sale`, async () => { + it(`should now click on the search result to access to the ticket Sale`, async() => { const url = await nightmare .waitForTextInElement(selectors.ticketsIndex.searchResult, 'address 21') .waitToClick(selectors.ticketsIndex.searchResult) @@ -54,14 +54,14 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/sale'); }); - it(`should check the zoomed image isnt present`, async () => { + it(`should check the zoomed image isnt present`, async() => { const result = await nightmare .countElement(selectors.ticketSales.firstSaleZoomedImage); expect(result).toEqual(0); }); - it(`should click on the thumbnail image of the 1st sale and see the zoomed image`, async () => { + it(`should click on the thumbnail image of the 1st sale and see the zoomed image`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleThumbnailImage) .countElement(selectors.ticketSales.firstSaleZoomedImage); @@ -69,7 +69,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(1); }); - it(`should click on the zoomed image to close it`, async () => { + it(`should click on the zoomed image to close it`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleZoomedImage) .countElement(selectors.ticketSales.firstSaleZoomedImage); @@ -77,14 +77,14 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(0); }); - it(`should confirm the item descriptor insnt visible yet`, async () => { + it(`should confirm the item descriptor insnt visible yet`, async() => { const visible = await nightmare .isVisible(selectors.ticketSales.saleDescriptorPopover); expect(visible).toBeFalsy(); }); - it(`should click on the first sale ID making the item descriptor visible`, async () => { + it(`should click on the first sale ID making the item descriptor visible`, async() => { const visible = await nightmare .waitToClick(selectors.ticketSales.firstSaleID) .wait(1000) @@ -93,7 +93,7 @@ describe('Ticket Edit sale path', () => { expect(visible).toBeTruthy(); }); - it(`should click on the descriptor image of the 1st sale and see the zoomed image`, async () => { + it(`should click on the descriptor image of the 1st sale and see the zoomed image`, async() => { const result = await nightmare .waitToClick('vn-item-descriptor img') .countElement(selectors.ticketSales.firstSaleZoomedImage); @@ -101,7 +101,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(1); }); - it(`should click on the zoomed image to close it`, async () => { + it(`should click on the zoomed image to close it`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleZoomedImage) .countElement(selectors.ticketSales.firstSaleZoomedImage); @@ -109,7 +109,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(0); }); - it(`should click on the summary icon of the item-descriptor to access to the item summary`, async () => { + it(`should click on the summary icon of the item-descriptor to access to the item summary`, async() => { const url = await nightmare .waitToClick(selectors.ticketSales.saleDescriptorPopoverSummaryButton) .waitForURL('/summary') @@ -118,7 +118,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/summary'); }); - it('should return to ticket sales section', async () => { + it('should return to ticket sales section', async() => { const url = await nightmare .waitToClick(selectors.globalItems.applicationsMenuButton) .wait(selectors.globalItems.applicationsMenuVisible) @@ -136,7 +136,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/sale'); }); - it('should try to add a higher quantity value and then receive an error', async () => { + it('should try to add a higher quantity value and then receive an error', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleQuantityClearInput) .type(selectors.ticketSales.firstSaleQuantity, '9\u000d') @@ -145,7 +145,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual('The new quantity should be smaller than the old one'); }); - it('should remove 1 from quantity', async () => { + it('should remove 1 from quantity', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleQuantityClearInput) .type(selectors.ticketSales.firstSaleQuantity, '4\u000d') @@ -154,7 +154,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual('Data saved!'); }); - it('should update the price', async () => { + it('should update the price', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSalePrice) .wait(selectors.ticketSales.firstSalePriceInput) @@ -165,21 +165,21 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual('Data saved!'); }); - it('should confirm the price have been updated', async () => { + it('should confirm the price have been updated', async() => { const result = await nightmare .waitToGetProperty(selectors.ticketSales.firstSalePrice, 'innerText'); expect(result).toContain('5.00'); }); - it('should confirm the total price for that item have been updated', async () => { + it('should confirm the total price for that item have been updated', async() => { const result = await nightmare .waitToGetProperty(selectors.ticketSales.firstSaleImport, 'innerText'); expect(result).toContain('20.00'); }); - it('should update the discount', async () => { + it('should update the discount', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleDiscount) .wait('vn-textfield[label="Discount"] > div[class="container selected"]') // a function selects the text after it's loaded @@ -190,7 +190,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual('Data saved!'); }); - it('should confirm the discount have been updated', async () => { + it('should confirm the discount have been updated', async() => { const result = await nightmare .waitForTextInElement(selectors.ticketSales.firstSaleDiscount, '50 %') .waitToGetProperty(selectors.ticketSales.firstSaleDiscount, 'innerText'); @@ -198,7 +198,7 @@ describe('Ticket Edit sale path', () => { expect(result).toContain('50 %'); }); - it('should confirm the total import for that item have been updated', async () => { + it('should confirm the total import for that item have been updated', async() => { const result = await nightmare .waitForTextInElement(selectors.ticketSales.firstSaleImport, '10.00') .waitToGetProperty(selectors.ticketSales.firstSaleImport, 'innerText'); @@ -206,18 +206,18 @@ describe('Ticket Edit sale path', () => { expect(result).toContain('10.00'); }); - it('should select the third sale and create a claim of it', async () => { + it('should select the third sale and create a claim of it', async() => { const url = await nightmare .waitToClick(selectors.ticketSales.thirdSaleCheckbox) .waitToClick(selectors.ticketSales.moreMenuButton) .waitToClick(selectors.ticketSales.moreMenuCreateClaim) - .wait(selectors.claimBasicData.claimStateSelect) + .wait(selectors.claimBasicData.claimStateAutocomplete) .parsedUrl(); expect(url.hash).toEqual('#!/claim/4/basic-data'); }); - it('should click on the Claims button of the top bar menu', async () => { + it('should click on the Claims button of the top bar menu', async() => { const url = await nightmare .waitToClick(selectors.globalItems.applicationsMenuButton) .wait(selectors.globalItems.applicationsMenuVisible) @@ -228,7 +228,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toEqual('#!/claim/index'); }); - it('should search for the claim with id 4', async () => { + it('should search for the claim with id 4', async() => { const result = await nightmare .wait(selectors.claimsIndex.searchResult) .type(selectors.claimsIndex.searchClaimInput, 4) @@ -239,7 +239,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(1); }); - it('should click the Tickets button of the top bar menu', async () => { + it('should click the Tickets button of the top bar menu', async() => { const url = await nightmare .waitToClick(selectors.globalItems.applicationsMenuButton) .wait(selectors.globalItems.applicationsMenuVisible) @@ -250,7 +250,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toEqual('#!/ticket/index'); }); - it('should search the ticket', async () => { + it('should search the ticket', async() => { const result = await nightmare .wait(selectors.ticketsIndex.searchTicketInput) .type(selectors.ticketsIndex.searchTicketInput, 'id:16') @@ -261,7 +261,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(1); }); - it(`should click on the result to access to the ticket Sale`, async () => { + it(`should click on the result to access to the ticket Sale`, async() => { const url = await nightmare .waitForTextInElement(selectors.ticketsIndex.searchResult, 'address 21') .waitToClick(selectors.ticketsIndex.searchResult) @@ -272,7 +272,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/sale'); }); - it('should select the third sale and delete it', async () => { + it('should select the third sale and delete it', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.thirdSaleCheckbox) .waitToClick(selectors.ticketSales.deleteSaleButton) @@ -282,14 +282,14 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual('Data saved!'); }); - it(`should confirm the third sale was deleted`, async () => { + it(`should confirm the third sale was deleted`, async() => { const result = await nightmare .countElement(selectors.ticketSales.saleLine); expect(result).toEqual(3); }); - it('should select the third sale and attempt to send it to a frozen client ticket', async () => { + it('should select the third sale and attempt to send it to a frozen client ticket', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.thirdSaleCheckbox) .waitToClick(selectors.ticketSales.transferSaleButton) @@ -301,7 +301,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(`The sales of this ticket can't be modified`); }); - it('should transfer the sale to a valid ticket', async () => { + it('should transfer the sale to a valid ticket', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.moveToTicketInputClearButton) .type(selectors.ticketSales.moveToTicketInput, 12) @@ -312,7 +312,7 @@ describe('Ticket Edit sale path', () => { expect(result.hash).toContain(`ticket/12/sale`); }); - it('should confirm the transfered line is the correct one', async () => { + it('should confirm the transfered line is the correct one', async() => { const result = await nightmare .wait(selectors.ticketSales.firstSaleText) .waitToGetProperty(selectors.ticketSales.firstSaleText, 'innerText'); @@ -320,7 +320,7 @@ describe('Ticket Edit sale path', () => { expect(result).toContain(`Mark I`); }); - it('should go back to the original ticket sales section', async () => { + it('should go back to the original ticket sales section', async() => { const url = await nightmare .waitToClick(selectors.itemsIndex.goBackToModuleIndexButton) .wait(selectors.ticketsIndex.searchTicketInput) @@ -336,7 +336,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/sale'); }); - it(`should confirm the original ticket has only two lines now`, async () => { + it(`should confirm the original ticket has only two lines now`, async() => { const result = await nightmare .wait(selectors.ticketSales.saleLine) .countElement(selectors.ticketSales.saleLine); @@ -344,7 +344,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(2); }); - it('should go back to the receiver ticket sales section', async () => { + it('should go back to the receiver ticket sales section', async() => { const url = await nightmare .waitToClick(selectors.itemsIndex.goBackToModuleIndexButton) .wait(selectors.ticketsIndex.searchTicketInput) @@ -360,7 +360,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/sale'); }); - it('should transfer the sale back to the original ticket', async () => { + it('should transfer the sale back to the original ticket', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleCheckbox) .waitToClick(selectors.ticketSales.transferSaleButton) @@ -373,7 +373,7 @@ describe('Ticket Edit sale path', () => { expect(result.hash).toContain(`ticket/16/sale`); }); - it('should confirm the original ticket received the line', async () => { + it('should confirm the original ticket received the line', async() => { const result = await nightmare .wait(selectors.ticketSales.saleLine) .countElement(selectors.ticketSales.saleLine); @@ -381,7 +381,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(3); }); - it('should go back to the original ticket sales section', async () => { + it('should go back to the original ticket sales section', async() => { const url = await nightmare .waitToClick(selectors.itemsIndex.goBackToModuleIndexButton) .wait(selectors.ticketsIndex.searchTicketInput) @@ -397,7 +397,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/sale'); }); - it('should select the second and third sale and tranfer them to a new ticket then get to the ticket index', async () => { + it('should select the second and third sale and tranfer them to a new ticket then get to the ticket index', async() => { const url = await nightmare .waitToClick(selectors.ticketSales.firstSaleCheckbox) .waitToClick(selectors.ticketSales.transferSaleButton) @@ -412,7 +412,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toEqual('#!/ticket/index'); }); - it('should search for a specific created ticket', async () => { + it('should search for a specific created ticket', async() => { const result = await nightmare .wait(selectors.ticketsIndex.searchTicketInput) .type(selectors.ticketsIndex.searchTicketInput, 'nickname:(address 24) stateFk:2') @@ -423,7 +423,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(1); }); - it(`should click on the search result to access to the ticket Sale once more`, async () => { + it(`should click on the search result to access to the ticket Sale once more`, async() => { const url = await nightmare .waitForTextInElement(selectors.ticketsIndex.searchResult, 'address 24') .waitToClick(selectors.ticketsIndex.searchResult) @@ -434,21 +434,21 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/sale'); }); - it('should confirm the new ticket received both lines', async () => { + it('should confirm the new ticket received both lines', async() => { const result = await nightmare .countElement(selectors.ticketSales.saleLine); expect(result).toEqual(1); }); - it('should check the first sale reserved icon isnt visible', async () => { + it('should check the first sale reserved icon isnt visible', async() => { const result = await nightmare .isVisible(selectors.ticketSales.firstSaleReservedIcon); expect(result).toBeFalsy(); }); - it('should mark the first sale as reserved', async () => { + it('should mark the first sale as reserved', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleCheckbox) .waitToClick(selectors.ticketSales.moreMenuButton) @@ -459,7 +459,7 @@ describe('Ticket Edit sale path', () => { expect(result).toBeTruthy(); }); - it('should unmark the first sale as reserved', async () => { + it('should unmark the first sale as reserved', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleCheckbox) .waitToClick(selectors.ticketSales.moreMenuButton) @@ -470,7 +470,7 @@ describe('Ticket Edit sale path', () => { expect(result).toBeFalsy(); }); - it('should update all sales discount', async () => { + it('should update all sales discount', async() => { const result = await nightmare .waitToClick(selectors.ticketSales.selectAllSalesCheckbox) .waitToClick(selectors.ticketSales.moreMenuButton) @@ -484,7 +484,7 @@ describe('Ticket Edit sale path', () => { expect(result).toContain('0.00'); }); - it('should log in as Production role and go to the ticket index', async () => { + it('should log in as Production role and go to the ticket index', async() => { const url = await nightmare .waitToClick(selectors.globalItems.logOutButton) .waitForLogin('production') @@ -497,7 +497,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toEqual('#!/ticket/index'); }); - it('should now search for a specific ticket', async () => { + it('should now search for a specific ticket', async() => { const result = await nightmare .wait(selectors.ticketsIndex.searchTicketInput) .type(selectors.ticketsIndex.searchTicketInput, 'id:16') @@ -508,7 +508,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(1); }); - it(`should now click on the search result to access to the ticket Tracking`, async () => { + it(`should now click on the search result to access to the ticket Tracking`, async() => { const url = await nightmare .waitForTextInElement(selectors.ticketsIndex.searchResult, 'address 21') .waitToClick(selectors.ticketsIndex.searchResult) @@ -519,7 +519,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/tracking/index'); }); - it(`should click on the edit ticket tracking state button`, async () => { + it(`should click on the edit ticket tracking state button`, async() => { const url = await nightmare .waitToClick(selectors.ticketTracking.createStateButton) .waitForURL('/tracking/edit') @@ -528,13 +528,9 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/tracking/edit'); }); - it(`should set the state of the ticket to preparation`, async () => { + it(`should set the state of the ticket to preparation`, async() => { const url = await nightmare - .waitToClick(selectors.ticketTracking.stateSelect) - .wait(selectors.ticketTracking.stateSelectInput) - .type(selectors.ticketTracking.stateSelectInput, 'Preparación') - .waitToClick(selectors.ticketTracking.stateSelectFirstResult) - .waitForTextInInput(selectors.ticketTracking.stateSelectInput, 'Preparación') + .autocompleteSearch(selectors.ticketTracking.stateAutocomplete, 'Preparación') .click(selectors.ticketTracking.saveButton) .waitForURL('/tracking/index') .parsedUrl(); @@ -542,7 +538,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toContain('/tracking/index'); }); - it(`should click on the ticket Sale menu button`, async () => { + it(`should click on the ticket Sale menu button`, async() => { const url = await nightmare .waitToClick(selectors.ticketSales.saleButton) .waitForURL('/sale') @@ -552,7 +548,7 @@ describe('Ticket Edit sale path', () => { }); describe('when state is preparation and loged as Production', () => { - it(`should not be able to edit the sale price`, async () => { + it(`should not be able to edit the sale price`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSalePrice) .exists(selectors.ticketSales.firstSalePriceInput); @@ -560,7 +556,7 @@ describe('Ticket Edit sale path', () => { expect(result).toBeFalsy(); }); - it(`should not be able to edit the sale discount`, async () => { + it(`should not be able to edit the sale discount`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleDiscount) .exists(selectors.ticketSales.firstSaleDiscountInput); @@ -568,7 +564,7 @@ describe('Ticket Edit sale path', () => { expect(result).toBeFalsy(); }); - it(`should not be able to edit the sale state`, async () => { + it(`should not be able to edit the sale state`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.stateMenuButton) .exists(selectors.ticketSales.stateMenuOptions); @@ -576,7 +572,7 @@ describe('Ticket Edit sale path', () => { expect(result).toBeFalsy(); }); - it('should log in as salesPerson role and go to the ticket index', async () => { + it('should log in as salesPerson role and go to the ticket index', async() => { const url = await nightmare .waitToClick(selectors.globalItems.logOutButton) .waitForLogin('salesPerson') @@ -589,7 +585,7 @@ describe('Ticket Edit sale path', () => { expect(url.hash).toEqual('#!/ticket/index'); }); - it('should once again search for a specific ticket', async () => { + it('should once again search for a specific ticket', async() => { const result = await nightmare .wait(selectors.ticketsIndex.searchTicketInput) .type(selectors.ticketsIndex.searchTicketInput, 'id:16') @@ -600,7 +596,7 @@ describe('Ticket Edit sale path', () => { expect(result).toEqual(1); }); - it(`should click on the search result to access to the ticket Sale once again`, async () => { + it(`should click on the search result to access to the ticket Sale once again`, async() => { const url = await nightmare .waitForTextInElement(selectors.ticketsIndex.searchResult, 'address 21') .waitToClick(selectors.ticketsIndex.searchResult) @@ -613,7 +609,7 @@ describe('Ticket Edit sale path', () => { }); describe('when state is preparation and loged as salesPerson', () => { - it(`shouldnt be able to edit the sale price`, async () => { + it(`shouldnt be able to edit the sale price`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSalePrice) .exists(selectors.ticketSales.firstSalePriceInput); @@ -621,7 +617,7 @@ describe('Ticket Edit sale path', () => { expect(result).toBeFalsy(); }); - it(`shouldnt be able to edit the sale discount`, async () => { + it(`shouldnt be able to edit the sale discount`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.firstSaleDiscount) .exists(selectors.ticketSales.firstSaleDiscountInput); @@ -629,7 +625,7 @@ describe('Ticket Edit sale path', () => { expect(result).toBeFalsy(); }); - it(`shouldnt be able to edit the sale state`, async () => { + it(`shouldnt be able to edit the sale state`, async() => { const result = await nightmare .waitToClick(selectors.ticketSales.stateMenuButton) .exists(selectors.ticketSales.stateMenuOptions); diff --git a/e2e/paths/ticket-module/10_ticket_request.spec.js b/e2e/paths/ticket-module/10_ticket_request.spec.js index 47515c6c4..fcc7eb0a4 100644 --- a/e2e/paths/ticket-module/10_ticket_request.spec.js +++ b/e2e/paths/ticket-module/10_ticket_request.spec.js @@ -11,7 +11,7 @@ describe('Ticket purchase request path', () => { .accessToSection('ticket.card.request.index'); }); - it(`should add a new request`, async () => { + it(`should add a new request`, async() => { const result = await nightmare .waitToClick(selectors.ticketRequests.addRequestButton) .wait(selectors.ticketRequests.descriptionInput) @@ -26,7 +26,7 @@ describe('Ticket purchase request path', () => { expect(result).toEqual('Data saved!'); }); - it(`should have been redirected to the request index`, async () => { + it(`should have been redirected to the request index`, async() => { const url = await nightmare .waitForURL('/request') .parsedUrl(); @@ -34,17 +34,17 @@ describe('Ticket purchase request path', () => { expect(url.hash).toContain('/request'); }); - it(`should confirm the new request was added`, async () => { + it(`should confirm the new request was added`, async() => { const result = await nightmare .waitToClick(selectors.ticketBasicData.basicDataButton) - .wait(selectors.ticketBasicData.clientSelect) + .wait(selectors.ticketBasicData.clientAutocomplete) .waitToClick(selectors.ticketRequests.requestButton) .waitToGetProperty(selectors.ticketRequests.firstDescription, 'innerText'); expect(result).toEqual('New stuff'); }); - it(`should delete the added request`, async () => { + it(`should delete the added request`, async() => { const result = await nightmare .waitToClick(selectors.ticketRequests.firstRemoveRequestButton) .waitForLastSnackbar(); @@ -52,10 +52,10 @@ describe('Ticket purchase request path', () => { expect(result).toEqual('Data saved!'); }); - it(`should confirm the request was deleted`, async () => { + it(`should confirm the request was deleted`, async() => { const result = await nightmare .waitToClick(selectors.ticketBasicData.basicDataButton) - .wait(selectors.ticketBasicData.clientSelect) + .wait(selectors.ticketBasicData.clientAutocomplete) .waitToClick(selectors.ticketRequests.requestButton) .wait(selectors.ticketRequests.addRequestButton) .exists(selectors.ticketRequests.request); diff --git a/e2e/paths/ticket-module/11_ticket_diary.spec.js b/e2e/paths/ticket-module/11_ticket_diary.spec.js index 3f7edf1cc..10b05363d 100644 --- a/e2e/paths/ticket-module/11_ticket_diary.spec.js +++ b/e2e/paths/ticket-module/11_ticket_diary.spec.js @@ -10,7 +10,7 @@ describe('Ticket diary path', () => { .loginAndModule('employee', 'ticket'); }); - it('should search for a specific ticket', async () => { + it('should search for a specific ticket', async() => { const result = await nightmare .wait(selectors.ticketsIndex.searchTicketInput) .type(selectors.ticketsIndex.searchTicketInput, 'id:1') @@ -21,7 +21,7 @@ describe('Ticket diary path', () => { expect(result).toEqual(1); }); - it(`should click on the search result to access to the ticket summary`, async () => { + it(`should click on the search result to access to the ticket summary`, async() => { const url = await nightmare .waitForTextInElement(selectors.ticketsIndex.searchResult, 'address 21') .waitToClick(selectors.ticketsIndex.searchResult) @@ -31,7 +31,7 @@ describe('Ticket diary path', () => { expect(url.hash).toContain('/summary'); }); - it(`should navigate to the item diary from the 1st sale item id descriptor popover`, async () => { + it(`should navigate to the item diary from the 1st sale item id descriptor popover`, async() => { const url = await nightmare .waitToClick(selectors.ticketSummary.firstSaleItemId) .waitToClick(selectors.ticketSummary.popoverDiaryButton) @@ -42,24 +42,23 @@ describe('Ticket diary path', () => { expect(url.hash).toContain('/diary'); }); - it(`should check the seventh line id is marked as counter`, async () => { + it(`should check the seventh line id is marked as counter`, async() => { const result = await nightmare .waitToGetProperty(selectors.itemDiary.thirdTicketId, 'className'); expect(result).toContain('counter'); }); - it(`should check the fifth line balance is marked as counter`, async () => { + it(`should check the fifth line balance is marked as counter`, async() => { const result = await nightmare .waitToGetProperty(selectors.itemDiary.fifthBalance, 'className'); expect(result).toContain('counter'); }); - it(`should change to the warehouse two and check there are sales marked as negative balance`, async () => { + it(`should change to the warehouse two and check there are sales marked as negative balance`, async() => { const result = await nightmare - .waitToClick(selectors.itemDiary.warehouseSelect) - .waitToClick(selectors.itemDiary.warehouseSelectFourthOption) + .autocompleteSearch(selectors.itemDiary.warehouseAutocomplete, 'Warehouse Two') .waitToGetProperty(selectors.itemDiary.firstBalance, 'className'); expect(result).toContain('balance'); diff --git a/modules/order/front/filter/index.html b/modules/order/front/filter/index.html index ddf2e6ffc..ebfa682c9 100644 --- a/modules/order/front/filter/index.html +++ b/modules/order/front/filter/index.html @@ -1,7 +1,7 @@ + data="categories" auto-load="true">