2019-03-12 07:38:17 +00:00
|
|
|
import selectors from '../../helpers/selectors.js';
|
2020-01-23 15:01:29 +00:00
|
|
|
import getBrowser from '../../helpers/puppeteer';
|
2019-03-12 07:38:17 +00:00
|
|
|
|
2019-09-30 11:02:11 +00:00
|
|
|
describe('Ticket descriptor path', () => {
|
2020-01-23 15:01:29 +00:00
|
|
|
let browser;
|
|
|
|
let page;
|
2019-03-12 07:38:17 +00:00
|
|
|
|
2020-01-23 15:01:29 +00:00
|
|
|
beforeAll(async() => {
|
|
|
|
browser = await getBrowser();
|
|
|
|
page = browser.page;
|
|
|
|
await page.loginAndModule('salesperson', 'ticket');
|
|
|
|
});
|
|
|
|
|
|
|
|
afterAll(async() => {
|
|
|
|
await browser.close();
|
2019-03-12 07:38:17 +00:00
|
|
|
});
|
|
|
|
|
2019-11-13 11:18:30 +00:00
|
|
|
describe('Delete ticket', () => {
|
2019-03-12 07:38:17 +00:00
|
|
|
it('should search for an specific ticket', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.write(selectors.ticketsIndex.searchTicketInput, '18');
|
|
|
|
await page.waitToClick(selectors.ticketsIndex.searchButton);
|
|
|
|
await page.waitForNumberOfElements(selectors.ticketsIndex.searchResult, 1);
|
|
|
|
const result = await page.countElement(selectors.ticketsIndex.searchResult);
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(result).toEqual(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it(`should click on the search result to access to the ticket summary`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitForTextInElement(selectors.ticketsIndex.searchResult, 'Cerebro');
|
|
|
|
await page.waitToClick(selectors.ticketsIndex.searchResult);
|
|
|
|
await page.waitForURL('/summary');
|
|
|
|
const url = await page.parsedUrl();
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(url.hash).toContain('/summary');
|
|
|
|
});
|
|
|
|
|
2019-10-15 05:23:34 +00:00
|
|
|
it(`should update the shipped hour using the descriptor menu`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitForContentLoaded();
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenu);
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenuChangeShippedHour);
|
|
|
|
await page.pickTime(selectors.ticketDescriptor.changeShippedHourInput, '08:15');
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.acceptChangeHourButton);
|
|
|
|
const result = await page.waitForLastSnackbar();
|
2019-08-21 07:32:21 +00:00
|
|
|
|
|
|
|
expect(result).toEqual('Shipped hour updated');
|
|
|
|
});
|
|
|
|
|
|
|
|
it(`should confirm the ticket descriptor shows the correct shipping hour`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
const result = await page
|
2019-08-21 07:32:21 +00:00
|
|
|
.waitToGetProperty(selectors.ticketDescriptor.descriptorDeliveryDate, 'innerText');
|
|
|
|
|
|
|
|
expect(result).toContain('08:15');
|
|
|
|
});
|
|
|
|
|
2019-03-12 07:38:17 +00:00
|
|
|
it('should delete the ticket using the descriptor more menu', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenu);
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenuDeleteTicket);
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.acceptDeleteButton);
|
|
|
|
const result = await page.waitForLastSnackbar();
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(result).toEqual('Ticket deleted');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should have been relocated to the ticket index', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
const url = await page.parsedUrl();
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(url.hash).toEqual('#!/ticket/index');
|
|
|
|
});
|
|
|
|
|
|
|
|
it(`should search for the deleted ticket and check it's date`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.write(selectors.ticketsIndex.searchTicketInput, '18');
|
|
|
|
await page.waitToClick(selectors.ticketsIndex.searchButton);
|
|
|
|
await page.waitForNumberOfElements(selectors.ticketsIndex.searchResult, 1);
|
|
|
|
await page.wait(selectors.ticketsIndex.searchResultDate);
|
|
|
|
const result = await page.waitToGetProperty(selectors.ticketsIndex.searchResultDate, 'innerText');
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(result).toContain(2000);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('add stowaway', () => {
|
|
|
|
it('should search for a ticket', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.clearInput(selectors.ticketsIndex.searchTicketInput);
|
|
|
|
await page.write(selectors.ticketsIndex.searchTicketInput, '16');
|
|
|
|
await page.waitToClick(selectors.ticketsIndex.searchButton);
|
|
|
|
await page.waitForNumberOfElements(selectors.ticketsIndex.searchResult, 1);
|
|
|
|
const result = await page.countElement(selectors.ticketsIndex.searchResult);
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(result).toEqual(1);
|
|
|
|
});
|
|
|
|
|
2019-06-19 07:03:45 +00:00
|
|
|
it(`should now click on the search result to access to the ticket summary`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitForTextInElement(selectors.ticketsIndex.searchResult, 'Many Places');
|
|
|
|
await page.waitToClick(selectors.ticketsIndex.searchResult);
|
|
|
|
await page.waitForURL('/summary');
|
|
|
|
const url = await page.parsedUrl();
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(url.hash).toContain('/summary');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should open the add stowaway dialog', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitForFunction(() => {
|
|
|
|
let element = document.querySelector('vn-ticket-descriptor');
|
|
|
|
return element.$ctrl.canShowStowaway === true;
|
|
|
|
});
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenu);
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenuAddStowaway);
|
|
|
|
await page.wait(selectors.ticketDescriptor.addStowawayDialogFirstTicket);
|
|
|
|
const isVisible = await page.isVisible(selectors.ticketDescriptor.addStowawayDialogFirstTicket);
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(isVisible).toBeTruthy();
|
|
|
|
});
|
|
|
|
|
2019-06-19 07:03:45 +00:00
|
|
|
it('should add a ticket as stowaway', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitToClick(selectors.ticketDescriptor.addStowawayDialogFirstTicket);
|
|
|
|
const result = await page.waitForLastSnackbar();
|
2019-03-12 07:38:17 +00:00
|
|
|
|
|
|
|
expect(result).toEqual('Data saved!');
|
|
|
|
});
|
|
|
|
|
2019-07-01 11:41:38 +00:00
|
|
|
it(`should check the state of the stowaway ticket is embarked`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
const state = await page.waitToGetProperty(selectors.ticketDescriptor.stateLabelValue, 'innerText');
|
2019-07-01 11:41:38 +00:00
|
|
|
|
|
|
|
expect(state).toEqual('State Embarcando');
|
|
|
|
});
|
|
|
|
|
2019-03-20 14:33:33 +00:00
|
|
|
it(`should navigate back to the added ticket using the descriptors ship button`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitToClick(selectors.ticketDescriptor.shipButton);
|
|
|
|
await page.waitForURL('#!/ticket/17/summary');
|
|
|
|
const url = await page.parsedUrl();
|
2019-03-20 14:33:33 +00:00
|
|
|
|
2019-06-19 12:40:47 +00:00
|
|
|
expect(url.hash).toContain('#!/ticket/17/summary');
|
2019-03-20 14:33:33 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should delete the stowaway', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitForContentLoaded();
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenu);
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenuDeleteStowawayButton);
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.acceptDeleteStowawayButton);
|
|
|
|
const result = await page.waitForLastSnackbar();
|
2019-03-20 14:33:33 +00:00
|
|
|
|
|
|
|
expect(result).toEqual('Data saved!');
|
|
|
|
});
|
|
|
|
|
|
|
|
it(`should confirm the ship buton doesn't exisist any more`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitForSelector(selectors.ticketDescriptor.shipButton, {hidden: true});
|
2019-03-20 14:33:33 +00:00
|
|
|
});
|
2019-03-12 07:38:17 +00:00
|
|
|
});
|
2019-04-23 06:58:49 +00:00
|
|
|
|
|
|
|
describe('Make invoice', () => {
|
2019-04-23 11:29:52 +00:00
|
|
|
it('should login as adminBoss role then search for a ticket', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
const invoiceableTicketId = '14';
|
2019-04-23 06:58:49 +00:00
|
|
|
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.loginAndModule('adminBoss', 'ticket');
|
|
|
|
await page.accessToSearchResult(invoiceableTicketId);
|
|
|
|
await page.waitForURL('/summary');
|
|
|
|
const url = await page.parsedUrl();
|
2019-04-23 06:58:49 +00:00
|
|
|
|
|
|
|
expect(url.hash).toContain(`ticket/${invoiceableTicketId}/summary`);
|
|
|
|
});
|
|
|
|
|
|
|
|
it(`should make sure the ticket doesn't have an invoiceOutFk yet`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
const result = await page
|
2019-04-23 06:58:49 +00:00
|
|
|
.waitToGetProperty(selectors.ticketSummary.invoiceOutRef, 'innerText');
|
|
|
|
|
|
|
|
expect(result).toEqual('-');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should invoice the ticket using the descriptor more menu', async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitForContentLoaded();
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenu);
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.moreMenuMakeInvoice);
|
|
|
|
await page.waitToClick(selectors.ticketDescriptor.acceptInvoiceOutButton);
|
|
|
|
const result = await page.waitForLastSnackbar();
|
2019-04-23 06:58:49 +00:00
|
|
|
|
|
|
|
expect(result).toEqual('Ticket invoiced');
|
|
|
|
});
|
|
|
|
|
|
|
|
it(`should make sure the ticket summary have an invoiceOutFk`, async() => {
|
2020-01-23 15:01:29 +00:00
|
|
|
await page.waitForTextInElement(selectors.ticketSummary.invoiceOutRef, 'T4444445');
|
|
|
|
const result = await page.waitToGetProperty(selectors.ticketSummary.invoiceOutRef, 'innerText');
|
2019-04-23 06:58:49 +00:00
|
|
|
|
|
|
|
expect(result).toEqual('T4444445');
|
|
|
|
});
|
|
|
|
});
|
2019-03-12 07:38:17 +00:00
|
|
|
});
|