415 lines
17 KiB
JavaScript
415 lines
17 KiB
JavaScript
import selectors from '../../helpers/selectors.js';
|
|
import createNightmare from '../../helpers/nightmare';
|
|
|
|
describe('Client Edit fiscalData path', () => {
|
|
const nightmare = createNightmare();
|
|
describe('as employee', () => {
|
|
beforeAll(() => {
|
|
return nightmare
|
|
.waitForLogin('employee');
|
|
});
|
|
|
|
it('should click on the Clients button of the top bar menu', done => {
|
|
return nightmare
|
|
.waitToClick(selectors.globalItems.applicationsMenuButton)
|
|
.wait(selectors.globalItems.applicationsMenuVisible)
|
|
.waitToClick(selectors.globalItems.clientsButton)
|
|
.wait(selectors.clientsIndex.createClientButton)
|
|
.parsedUrl()
|
|
.then(url => {
|
|
expect(url.hash).toEqual('#!/client/index');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should search for the user Bruce Banner', done => {
|
|
return nightmare
|
|
.wait(selectors.clientsIndex.searchResult)
|
|
.type(selectors.clientsIndex.searchClientInput, 'Bruce Banner')
|
|
.click(selectors.clientsIndex.searchButton)
|
|
.waitForNumberOfElements(selectors.clientsIndex.searchResult, 1)
|
|
.countElement(selectors.clientsIndex.searchResult)
|
|
.then(result => {
|
|
expect(result).toEqual(1);
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
// Confirms all addresses have EQtax false for future propagation test step 1
|
|
it(`should click on the search result to access to the client's addresses`, () => {
|
|
return nightmare
|
|
.waitForTextInElement(selectors.clientsIndex.searchResult, 'Bruce Banner')
|
|
.waitToClick(selectors.clientsIndex.searchResult)
|
|
.waitToClick(selectors.clientAddresses.addressesButton)
|
|
.waitForURL('/address/index')
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toContain('/address/index');
|
|
});
|
|
});
|
|
|
|
// Confirms all addresses have EQtax false for future propagation test step 2
|
|
it(`should click on the 1st edit icon to check EQtax isnt checked`, () => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientAddresses.firstEditButton)
|
|
.wait(selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
});
|
|
});
|
|
|
|
// Confirms all addresses have EQtax false for future propagation test step 3
|
|
it(`should go back to addresses then select the second one and confirm the EQtax isnt checked`, () => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientAddresses.addressesButton)
|
|
.waitToClick(selectors.clientAddresses.secondEditButton)
|
|
.wait(selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
});
|
|
});
|
|
|
|
it(`should click on the fiscal data button`, () => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientFiscalData.fiscalDataButton)
|
|
.waitForURL('fiscal-data')
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toContain('fiscal-data');
|
|
});
|
|
});
|
|
|
|
it('should not be able to edit the verified data checkbox', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).disabled;
|
|
}, selectors.clientFiscalData.verifiedDataCheckboxInput)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
});
|
|
|
|
describe('as administrative', () => {
|
|
beforeAll(() => {
|
|
return nightmare
|
|
.waitForLogin('administrative');
|
|
});
|
|
|
|
it('should now click on the Clients button of the top bar menu', done => {
|
|
return nightmare
|
|
.waitToClick(selectors.globalItems.applicationsMenuButton)
|
|
.wait(selectors.globalItems.applicationsMenuVisible)
|
|
.waitToClick(selectors.globalItems.clientsButton)
|
|
.wait(selectors.clientsIndex.createClientButton)
|
|
.parsedUrl()
|
|
.then(url => {
|
|
expect(url.hash).toEqual('#!/client/index');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should now search for the user Bruce Banner', done => {
|
|
return nightmare
|
|
.wait(selectors.clientsIndex.searchResult)
|
|
.type(selectors.clientsIndex.searchClientInput, 'Bruce Banner')
|
|
.click(selectors.clientsIndex.searchButton)
|
|
.waitForNumberOfElements(selectors.clientsIndex.searchResult, 1)
|
|
.countElement(selectors.clientsIndex.searchResult)
|
|
.then(result => {
|
|
expect(result).toEqual(1);
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it(`should access to the client fiscal data`, () => {
|
|
return nightmare
|
|
.waitForTextInElement(selectors.clientsIndex.searchResult, 'Bruce Banner')
|
|
.waitToClick(selectors.clientsIndex.searchResult)
|
|
.waitToClick(selectors.clientFiscalData.fiscalDataButton)
|
|
.waitForURL('fiscal-data')
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toContain('fiscal-data');
|
|
});
|
|
});
|
|
|
|
it('should edit the clients fiscal data', done => {
|
|
return nightmare
|
|
.wait(selectors.clientFiscalData.socialNameInput)
|
|
.clearInput(selectors.clientFiscalData.socialNameInput)
|
|
.type(selectors.clientFiscalData.socialNameInput, 'SMASH!')
|
|
.waitForTextInInput(selectors.clientFiscalData.socialNameInput, 'SMASH!')
|
|
.clearInput(selectors.clientFiscalData.fiscalIdInput)
|
|
.type(selectors.clientFiscalData.fiscalIdInput, '94980061C')
|
|
.clearInput(selectors.clientFiscalData.addressInput)
|
|
.type(selectors.clientFiscalData.addressInput, 'Somewhere edited')
|
|
.clearInput(selectors.clientFiscalData.postcodeInput)
|
|
.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)
|
|
.waitToClick(selectors.clientFiscalData.activeCheckboxLabel)
|
|
.waitToClick(selectors.clientFiscalData.frozenCheckboxLabel)
|
|
.waitToClick(selectors.clientFiscalData.hasToInvoiceCheckboxLabel)
|
|
.waitToClick(selectors.clientFiscalData.viesCheckboxInput)
|
|
.waitToClick(selectors.clientFiscalData.invoiceByMailCheckboxLabel)
|
|
.waitToClick(selectors.clientFiscalData.invoiceByAddressCheckboxInput)
|
|
.waitToClick(selectors.clientFiscalData.equalizationTaxCheckboxLabel)
|
|
.waitToClick(selectors.clientFiscalData.verifiedDataCheckboxInput)
|
|
.click(selectors.clientFiscalData.saveButton)
|
|
.waitForLastSnackbar()
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should propagate the Equalization tax', done => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientFiscalData.acceptPropagationButton)
|
|
.waitForLastSnackbar()
|
|
.then(result => {
|
|
expect(result).toEqual('Equivalent tax spreaded');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
// confirm all addresses have now EQtax checked step 1
|
|
it(`should click on the addresses button to access to the client's addresses`, () => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientAddresses.addressesButton)
|
|
.waitForURL('/address/index')
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toContain('/address/index');
|
|
});
|
|
});
|
|
|
|
// confirm all addresses have now EQtax checked step 2
|
|
it(`should click on the 1st edit icon to confirm EQtax is checked`, () => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientAddresses.firstEditButton)
|
|
.wait(selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
});
|
|
});
|
|
|
|
// 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`, () => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientAddresses.addressesButton)
|
|
.waitToClick(selectors.clientAddresses.secondEditButton)
|
|
.wait(selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
});
|
|
});
|
|
|
|
it('should navigate back to fiscal data to confirm its name have been edited', done => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientFiscalData.fiscalDataButton)
|
|
.wait(selectors.clientFiscalData.socialNameInput)
|
|
.getInputValue(selectors.clientFiscalData.socialNameInput)
|
|
.then(result => {
|
|
expect(result).toEqual('SMASH!');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm the fiscal id have been edited', done => {
|
|
return nightmare
|
|
.getInputValue(selectors.clientFiscalData.fiscalIdInput)
|
|
.then(result => {
|
|
expect(result).toEqual('94980061C');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm the address have been edited', done => {
|
|
return nightmare
|
|
.getInputValue(selectors.clientFiscalData.addressInput)
|
|
.then(result => {
|
|
expect(result).toEqual('Somewhere edited');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm the postcode have been edited', done => {
|
|
return nightmare
|
|
.getInputValue(selectors.clientFiscalData.postcodeInput)
|
|
.then(result => {
|
|
expect(result).toEqual('12345');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm the city have been edited', done => {
|
|
return nightmare
|
|
.getInputValue(selectors.clientFiscalData.cityInput)
|
|
.then(result => {
|
|
expect(result).toEqual('N/A');
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it(`should confirm the country have been selected`, () => {
|
|
return nightmare
|
|
.getInputValue(selectors.clientFiscalData.countryInput)
|
|
.then(result => {
|
|
expect(result).toEqual('Francia');
|
|
});
|
|
});
|
|
|
|
it(`should confirm the province have been selected`, () => {
|
|
return nightmare
|
|
.getInputValue(selectors.clientFiscalData.provinceInput)
|
|
.then(result => {
|
|
expect(result).toEqual('Province two');
|
|
});
|
|
});
|
|
|
|
it('should confirm active checkbox is unchecked', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.activeCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm frozen checkbox is unchecked', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.frozenCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm Has to invoice checkbox is unchecked', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.hasToInvoiceCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm Vies checkbox is checked', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.viesCheckboxInput)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm Invoice by mail checkbox is unchecked', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.invoiceByMailCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm invoice by address checkbox is unchecked', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.invoiceByAddressCheckboxInput)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm Equalization tax checkbox is checked', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
it('should confirm Verified data checkbox is checked', done => {
|
|
return nightmare
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.verifiedDataCheckboxInput)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
|
|
// 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`, () => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientAddresses.addressesButton)
|
|
.waitForURL('/address/index')
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toContain('/address/index');
|
|
});
|
|
});
|
|
|
|
// 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`, () => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientAddresses.firstEditButton)
|
|
.waitToClick(selectors.clientAddresses.equalizationTaxCheckboxLabel)
|
|
.click(selectors.clientAddresses.saveButton)
|
|
.waitForLastSnackbar()
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
});
|
|
});
|
|
|
|
// 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', done => {
|
|
return nightmare
|
|
.waitToClick(selectors.clientFiscalData.fiscalDataButton)
|
|
.wait(selectors.clientFiscalData.invoiceByAddressCheckboxInput)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.clientFiscalData.invoiceByAddressCheckboxInput)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
}).catch(done.fail);
|
|
});
|
|
});
|
|
});
|