2018-02-20 09:00:19 +00:00
|
|
|
import selectors from '../../helpers/selectors';
|
2018-10-24 08:57:14 +00:00
|
|
|
import createNightmare from '../../helpers/nightmare';
|
2017-12-13 10:25:50 +00:00
|
|
|
|
2018-11-20 13:22:00 +00:00
|
|
|
describe('Client create path', () => {
|
|
|
|
const nightmare = createNightmare();
|
|
|
|
|
|
|
|
beforeAll(() => {
|
|
|
|
nightmare
|
2018-11-23 07:05:57 +00:00
|
|
|
.loginAndModule('employee', 'client');
|
2018-11-20 13:22:00 +00:00
|
|
|
});
|
|
|
|
|
2019-01-07 08:33:07 +00:00
|
|
|
it(`should search for the user Carol Danvers to confirm it isn't created yet`, async() => {
|
2018-11-20 13:22:00 +00:00
|
|
|
const result = await nightmare
|
2019-01-23 14:33:25 +00:00
|
|
|
.write(selectors.clientsIndex.searchClientInput, 'Carol Danvers')
|
2019-01-23 15:00:56 +00:00
|
|
|
.waitToClick(selectors.clientsIndex.searchButton)
|
2018-11-20 13:22:00 +00:00
|
|
|
.waitForNumberOfElements(selectors.clientsIndex.searchResult, 0)
|
|
|
|
.countElement(selectors.clientsIndex.searchResult);
|
|
|
|
|
|
|
|
expect(result).toEqual(0);
|
|
|
|
});
|
|
|
|
|
2019-01-07 08:33:07 +00:00
|
|
|
it('should now access to the create client view by clicking the create-client floating button', async() => {
|
2018-11-20 13:22:00 +00:00
|
|
|
const url = await nightmare
|
2019-01-23 15:00:56 +00:00
|
|
|
.waitToClick(selectors.clientsIndex.createClientButton)
|
2018-11-20 13:22:00 +00:00
|
|
|
.wait(selectors.createClientView.createButton)
|
|
|
|
.parsedUrl();
|
|
|
|
|
|
|
|
expect(url.hash).toEqual('#!/client/create');
|
|
|
|
});
|
|
|
|
|
2019-01-07 08:33:07 +00:00
|
|
|
it('should receive an error when clicking the create button having all the form fields empty', async() => {
|
2018-11-20 13:22:00 +00:00
|
|
|
const result = await nightmare
|
2019-01-23 15:00:56 +00:00
|
|
|
.waitToClick(selectors.createClientView.createButton)
|
2018-11-20 13:22:00 +00:00
|
|
|
.waitForLastSnackbar();
|
|
|
|
|
|
|
|
expect(result).toEqual('Some fields are invalid');
|
|
|
|
});
|
|
|
|
|
2019-01-07 08:33:07 +00:00
|
|
|
it('should receive an error when clicking the create button having name and Business name fields empty', async() => {
|
2018-11-20 13:22:00 +00:00
|
|
|
const result = await nightmare
|
2019-01-23 14:33:25 +00:00
|
|
|
.write(selectors.createClientView.taxNumber, '74451390E')
|
|
|
|
.write(selectors.createClientView.userName, 'CaptainMarvel')
|
|
|
|
.write(selectors.createClientView.email, 'CarolDanvers@verdnatura.es')
|
2019-04-17 06:21:58 +00:00
|
|
|
.autocompleteSearch(selectors.createClientView.salesPersonAutocomplete, 'replenisher')
|
2019-01-23 15:00:56 +00:00
|
|
|
.waitToClick(selectors.createClientView.createButton)
|
2018-11-20 13:22:00 +00:00
|
|
|
.waitForLastSnackbar();
|
|
|
|
|
|
|
|
expect(result).toEqual('Some fields are invalid');
|
|
|
|
});
|
|
|
|
|
2019-01-07 08:33:07 +00:00
|
|
|
it(`should attempt to create a new user with all it's data but wrong email`, async() => {
|
2018-11-20 13:22:00 +00:00
|
|
|
const result = await nightmare
|
2019-01-23 14:33:25 +00:00
|
|
|
.write(selectors.createClientView.name, 'Carol Danvers')
|
|
|
|
.write(selectors.createClientView.socialName, 'AVG tax')
|
2019-02-28 07:55:34 +00:00
|
|
|
.write(selectors.createClientView.street, 'Many places')
|
2019-06-13 11:08:11 +00:00
|
|
|
.autocompleteSearch(selectors.createClientView.postcode, '46000')
|
2018-11-20 13:22:00 +00:00
|
|
|
.clearInput(selectors.createClientView.email)
|
2019-01-23 14:33:25 +00:00
|
|
|
.write(selectors.createClientView.email, 'incorrect email format')
|
2019-01-23 15:00:56 +00:00
|
|
|
.waitToClick(selectors.createClientView.createButton)
|
2018-11-20 13:22:00 +00:00
|
|
|
.waitForLastSnackbar();
|
|
|
|
|
|
|
|
expect(result).toEqual('Some fields are invalid');
|
|
|
|
});
|
|
|
|
|
2019-06-13 11:08:11 +00:00
|
|
|
it(`should check for autocompleted city, province and country`, async() => {
|
|
|
|
const clientCity = await nightmare
|
|
|
|
.waitToGetProperty(`${selectors.createClientView.city} input`, 'value');
|
|
|
|
|
|
|
|
const clientProvince = await nightmare
|
|
|
|
.waitToGetProperty(`${selectors.createClientView.province} input`, 'value');
|
|
|
|
|
|
|
|
const clientCountry = await nightmare
|
|
|
|
.waitToGetProperty(`${selectors.createClientView.country} input`, 'value');
|
|
|
|
|
|
|
|
expect(clientCity).toEqual('Valencia');
|
|
|
|
expect(clientProvince).toEqual('Province one');
|
|
|
|
expect(clientCountry).toEqual('España');
|
|
|
|
});
|
|
|
|
|
2019-01-07 08:33:07 +00:00
|
|
|
it(`should create a new user with all correct data`, async() => {
|
2018-11-20 13:22:00 +00:00
|
|
|
const result = await nightmare
|
|
|
|
.clearInput(selectors.createClientView.email)
|
2019-01-23 14:33:25 +00:00
|
|
|
.write(selectors.createClientView.email, 'caroldanvers@verdnatura.es')
|
2019-01-23 15:00:56 +00:00
|
|
|
.waitToClick(selectors.createClientView.createButton)
|
2018-11-20 13:22:00 +00:00
|
|
|
.waitForLastSnackbar();
|
|
|
|
|
|
|
|
expect(result).toEqual('Data saved!');
|
|
|
|
});
|
|
|
|
|
2019-01-07 08:33:07 +00:00
|
|
|
it('should click on the Clients button of the top bar menu', async() => {
|
2018-11-20 13:22:00 +00:00
|
|
|
const url = await nightmare
|
|
|
|
.waitToClick(selectors.globalItems.applicationsMenuButton)
|
|
|
|
.wait(selectors.globalItems.applicationsMenuVisible)
|
|
|
|
.waitToClick(selectors.globalItems.clientsButton)
|
|
|
|
.wait(selectors.clientsIndex.createClientButton)
|
|
|
|
.parsedUrl();
|
|
|
|
|
|
|
|
expect(url.hash).toEqual('#!/client/index');
|
|
|
|
});
|
|
|
|
|
2019-01-07 08:33:07 +00:00
|
|
|
it(`should search for the user Carol Danvers to confirm it exists`, async() => {
|
2018-11-20 13:22:00 +00:00
|
|
|
const result = await nightmare
|
2019-01-23 14:33:25 +00:00
|
|
|
.write(selectors.clientsIndex.searchClientInput, 'Carol Danvers')
|
2019-01-23 15:00:56 +00:00
|
|
|
.waitToClick(selectors.clientsIndex.searchButton)
|
2018-11-20 13:22:00 +00:00
|
|
|
.waitForNumberOfElements(selectors.clientsIndex.searchResult, 1)
|
|
|
|
.countElement(selectors.clientsIndex.searchResult);
|
|
|
|
|
|
|
|
expect(result).toEqual(1);
|
2017-10-29 14:49:44 +00:00
|
|
|
});
|
2017-09-11 14:12:32 +00:00
|
|
|
});
|