580 lines
21 KiB
JavaScript
580 lines
21 KiB
JavaScript
import config from '../helpers/config.js';
|
|
import createNightmare from '../helpers/nightmare';
|
|
import selectors from '../helpers/selectors.js';
|
|
import {catchErrors} from '../../services/utils/jasmineHelpers';
|
|
const nightmare = createNightmare();
|
|
const moduleAccessViewHashURL = '#!/';
|
|
|
|
jasmine.DEFAULT_TIMEOUT_INTERVAL = 10000;
|
|
|
|
describe('Edit fiscalData path', () => {
|
|
describe('warm up', () => {
|
|
it('should warm up login and fixtures', done => {
|
|
nightmare
|
|
.login()
|
|
.waitForURL(moduleAccessViewHashURL)
|
|
.waitToClick(selectors.globalItems.logOutButton)
|
|
.then(() => {
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
});
|
|
|
|
it('should log in', done => {
|
|
nightmare
|
|
.login()
|
|
.waitForURL(moduleAccessViewHashURL)
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toEqual(config.url + moduleAccessViewHashURL);
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should make sure the language is English', done => {
|
|
nightmare
|
|
.changeLanguageToEnglish()
|
|
.then(() => {
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should click on the Clients button of the top bar menu', done => {
|
|
nightmare
|
|
.waitToClick(selectors.globalItems.applicationsMenuButton)
|
|
.wait(selectors.globalItems.applicationsMenuVisible)
|
|
.waitToClick(selectors.globalItems.clientsButton)
|
|
.wait(selectors.clientsIndex.createClientButton)
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toEqual(config.url + '#!/clients');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should search for the user Bruce Banner', done => {
|
|
nightmare
|
|
.wait(selectors.clientsIndex.searchResult)
|
|
.type(selectors.clientsIndex.searchClientInput, 'Bruce Banner')
|
|
.click(selectors.clientsIndex.searchButton)
|
|
.waitForNumberOfElements(selectors.clientsIndex.searchResult, 1)
|
|
.countSearchResults(selectors.clientsIndex.searchResult)
|
|
.then(result => {
|
|
expect(result).toEqual(1);
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
describe('Confirm all addresses have EQtax for future propagation test', () => {
|
|
it(`should click on the search result to access to the client's addresses`, done => {
|
|
nightmare
|
|
.waitForTextInElement(selectors.clientsIndex.searchResult, 'Bruce Banner')
|
|
.waitToClick(selectors.clientsIndex.searchResult)
|
|
.waitToClick(selectors.addresses.addressesButton)
|
|
.waitForURL('/addresses/list')
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toContain('/addresses/list');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it(`should click on the 1st edit icon to check EQtax is checked`, done => {
|
|
nightmare
|
|
.waitToClick(selectors.addresses.firstEditButton)
|
|
.wait(selectors.addresses.equalizationTaxCheckboxLabel)
|
|
.wait(200)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.addresses.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it(`should go back to addresses then select the second one and confirm the EQtax is checked`, done => {
|
|
nightmare
|
|
.waitToClick(selectors.addresses.addressesButton)
|
|
.waitToClick(selectors.addresses.secondEditButton)
|
|
.wait(selectors.addresses.equalizationTaxCheckboxLabel)
|
|
.wait(200)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.addresses.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
});
|
|
|
|
it(`should click on the fiscal data button to start editing`, done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.waitForURL('fiscal-data')
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toContain('fiscal-data');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should edit the social name', done => {
|
|
nightmare
|
|
.wait(selectors.fiscalData.socialNameInput)
|
|
.clearInput(selectors.fiscalData.socialNameInput)
|
|
.type(selectors.fiscalData.socialNameInput, 'Hulk edited')
|
|
.click(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm the social name have been edited', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.socialNameInput)
|
|
.getInputValue(selectors.fiscalData.socialNameInput)
|
|
.then(result => {
|
|
expect(result).toEqual('Hulk edited');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should edit the fiscal id', done => {
|
|
nightmare
|
|
.wait(selectors.fiscalData.fiscalIdInput)
|
|
.clearInput(selectors.fiscalData.fiscalIdInput)
|
|
.type(selectors.fiscalData.fiscalIdInput, '94980061C')
|
|
.click(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm the fiscal id have been edited', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.fiscalIdInput)
|
|
.getInputValue(selectors.fiscalData.fiscalIdInput)
|
|
.then(result => {
|
|
expect(result).toEqual('94980061C');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should uncheck the Equalization tax checkbox', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.equalizationTaxCheckboxLabel)
|
|
.waitToClick(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should propagate the Equalization tax', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.acceptPropagationButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm Equalization tax checkbox is unchecked', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.equalizationTaxCheckboxLabel)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.fiscalData.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
describe('Confirm all addresses havent got EQtax as uncheck was propagated', () => {
|
|
it(`should click on the addresses button to access to the client's addresses`, done => {
|
|
nightmare
|
|
.waitToClick(selectors.addresses.addressesButton)
|
|
.waitForURL('/addresses/list')
|
|
.url()
|
|
.then(url => {
|
|
expect(url).toContain('/addresses/list');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it(`should click on the 1st edit icon to check EQtax is unchecked`, done => {
|
|
nightmare
|
|
.waitToClick(selectors.addresses.firstEditButton)
|
|
.wait(selectors.addresses.equalizationTaxCheckboxLabel)
|
|
.wait(200)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.addresses.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it(`should go back to addresses then select the second one and confirm the EQtax is checked`, done => {
|
|
nightmare
|
|
.waitToClick(selectors.addresses.addressesButton)
|
|
.waitToClick(selectors.addresses.secondEditButton)
|
|
.wait(selectors.addresses.equalizationTaxCheckboxLabel)
|
|
.wait(200)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.addresses.equalizationTaxCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
});
|
|
|
|
it('should go to fiscal data then edit the address', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.addressInput)
|
|
.clearInput(selectors.fiscalData.addressInput)
|
|
.type(selectors.fiscalData.addressInput, 'Somewhere edited')
|
|
.click(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm the address have been edited', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.click(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.click(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.addressInput)
|
|
.getInputValue(selectors.fiscalData.addressInput)
|
|
.then(result => {
|
|
expect(result).toEqual('Somewhere edited');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should edit the city', done => {
|
|
nightmare
|
|
.wait(selectors.fiscalData.cityInput)
|
|
.clearInput(selectors.fiscalData.cityInput)
|
|
.type(selectors.fiscalData.cityInput, 'N/A')
|
|
.click(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm the city have been edited', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.click(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.click(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.cityInput)
|
|
.getInputValue(selectors.fiscalData.cityInput)
|
|
.then(result => {
|
|
expect(result).toEqual('N/A');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should edit the postcode', done => {
|
|
nightmare
|
|
.wait(selectors.fiscalData.postcodeInput)
|
|
.clearInput(selectors.fiscalData.postcodeInput)
|
|
.type(selectors.fiscalData.postcodeInput, '12345')
|
|
.click(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm the postcode have been edited', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.click(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.click(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.postcodeInput)
|
|
.getInputValue(selectors.fiscalData.postcodeInput)
|
|
.then(result => {
|
|
expect(result).toEqual('12345');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it(`should edit the province`, done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.provinceInput)
|
|
.waitToClick(selectors.fiscalData.provinceFifthOption)
|
|
.wait(200)
|
|
.waitToClick(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it(`should confirm the province have been selected`, done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.click(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.click(selectors.fiscalData.fiscalDataButton)
|
|
.wait(200)
|
|
.getInputValue(selectors.fiscalData.provinceInput)
|
|
.then(result => {
|
|
expect(result).toEqual('Province two');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should uncheck the active checkbox', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.activeCheckboxLabel)
|
|
.waitToClick(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm active checkbox is unchecked', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.activeCheckboxLabel)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.fiscalData.activeCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should check the invoice by address checkbox', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.invoiceByAddressCheckboxInput)
|
|
.waitToClick(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm invoice by address checkbox is checked', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.invoiceByAddressCheckboxInput)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.fiscalData.invoiceByAddressCheckboxInput)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should check the Verified data checkbox', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.verifiedDataCheckboxInput)
|
|
.waitToClick(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm Verified data checkbox is checked', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.verifiedDataCheckboxInput)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.fiscalData.verifiedDataCheckboxInput)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should uncheck the Has to invoice checkbox', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.hasToInvoiceCheckboxLabel)
|
|
.waitToClick(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm Has to invoice checkbox is unchecked', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.hasToInvoiceCheckboxLabel)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.fiscalData.hasToInvoiceCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should uncheck the Invoice by mail checkbox', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.invoiceByMailCheckboxLabel)
|
|
.waitToClick(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm Invoice by mail checkbox is unchecked', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.invoiceByMailCheckboxLabel)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.fiscalData.invoiceByMailCheckboxLabel)
|
|
.then(value => {
|
|
expect(value).toBeFalsy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should check the Vies checkbox', done => {
|
|
nightmare
|
|
.waitToClick(selectors.fiscalData.viesCheckboxInput)
|
|
.waitToClick(selectors.fiscalData.saveButton)
|
|
.wait(selectors.globalItems.snackbarIsActive)
|
|
.getInnerText(selectors.globalItems.snackbarIsActive)
|
|
.then(result => {
|
|
expect(result).toEqual('Data saved!');
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
|
|
it('should confirm Vies checkbox is checked', done => {
|
|
nightmare
|
|
.waitForSnackbarReset()
|
|
.waitToClick(selectors.basicData.basicDataButton)
|
|
.wait(selectors.basicData.nameInput)
|
|
.waitToClick(selectors.fiscalData.fiscalDataButton)
|
|
.wait(selectors.fiscalData.viesCheckboxInput)
|
|
.evaluate(selector => {
|
|
return document.querySelector(selector).checked;
|
|
}, selectors.fiscalData.viesCheckboxInput)
|
|
.then(value => {
|
|
expect(value).toBeTruthy();
|
|
done();
|
|
})
|
|
.catch(catchErrors(done));
|
|
});
|
|
});
|