109 lines
4.1 KiB
JavaScript
109 lines
4.1 KiB
JavaScript
|
import selectors from '../../helpers/selectors.js';
|
||
|
import getBrowser from '../../helpers/puppeteer';
|
||
|
|
||
|
describe('Ticket Summary path', () => {
|
||
|
let browser;
|
||
|
let page;
|
||
|
const ticketId = '20';
|
||
|
|
||
|
beforeAll(async() => {
|
||
|
browser = await getBrowser();
|
||
|
page = browser.page;
|
||
|
});
|
||
|
|
||
|
afterAll(async() => {
|
||
|
await browser.close();
|
||
|
});
|
||
|
|
||
|
it('should navigate to the target ticket summary section', async() => {
|
||
|
await page.loginAndModule('employee', 'ticket');
|
||
|
await page.accessToSearchResult(ticketId);
|
||
|
await page.waitForState('ticket.card.summary');
|
||
|
});
|
||
|
|
||
|
it(`should display details from the ticket and it's client on the top of the header`, async() => {
|
||
|
await page.waitForTextInElement(selectors.ticketSummary.header, 'Bruce Banner');
|
||
|
const result = await page.waitToGetProperty(selectors.ticketSummary.header, 'innerText');
|
||
|
|
||
|
expect(result).toContain(`Ticket #${ticketId}`);
|
||
|
expect(result).toContain('Bruce Banner (1109)');
|
||
|
expect(result).toContain('Somewhere in Thailand');
|
||
|
});
|
||
|
|
||
|
it('should display ticket details', async() => {
|
||
|
let result = await page
|
||
|
.waitToGetProperty(selectors.ticketSummary.state, 'innerText');
|
||
|
|
||
|
expect(result).toContain('Arreglar');
|
||
|
});
|
||
|
|
||
|
it('should display delivery details', async() => {
|
||
|
let result = await page
|
||
|
.waitToGetProperty(selectors.ticketSummary.route, 'innerText');
|
||
|
|
||
|
expect(result).toContain('3');
|
||
|
});
|
||
|
|
||
|
it('should display the ticket total', async() => {
|
||
|
let result = await page
|
||
|
.waitToGetProperty(selectors.ticketSummary.total, 'innerText');
|
||
|
|
||
|
expect(result).toContain('€155.54');
|
||
|
});
|
||
|
|
||
|
it('should display the ticket line(s)', async() => {
|
||
|
let result = await page
|
||
|
.waitToGetProperty(selectors.ticketSummary.firstSaleItemId, 'innerText');
|
||
|
|
||
|
expect(result).toContain('2');
|
||
|
});
|
||
|
|
||
|
it(`should click on the first sale ID to make the item descriptor visible`, async() => {
|
||
|
await page.waitToClick(selectors.ticketSummary.firstSaleItemId);
|
||
|
await page.waitImgLoad(selectors.ticketSummary.firstSaleDescriptorImage);
|
||
|
const visible = await page.isVisible(selectors.ticketSummary.itemDescriptorPopover);
|
||
|
|
||
|
expect(visible).toBeTruthy();
|
||
|
});
|
||
|
|
||
|
it(`should check the url for the item diary link of the descriptor is for the right item id`, async() => {
|
||
|
await page.waitForSelector(selectors.ticketSummary.itemDescriptorPopoverItemDiaryButton, {visible: true});
|
||
|
});
|
||
|
|
||
|
it('should log in as production then navigate to the summary of the same ticket', async() => {
|
||
|
await page.loginAndModule('production', 'ticket');
|
||
|
await page.accessToSearchResult(ticketId);
|
||
|
await page.waitForState('ticket.card.summary');
|
||
|
});
|
||
|
|
||
|
it('should set the ticket state to OK using the top right button', async() => {
|
||
|
const searchValue = 'OK';
|
||
|
await page.waitToClick(selectors.ticketSummary.stateButton);
|
||
|
await page.write(selectors.ticketSummary.stateAutocomplete, searchValue);
|
||
|
try {
|
||
|
await page.waitForFunction(text => {
|
||
|
const element = document.querySelector('li.active');
|
||
|
if (element)
|
||
|
return element.innerText.toLowerCase().includes(text.toLowerCase());
|
||
|
}, {}, searchValue);
|
||
|
} catch (error) {
|
||
|
const state = await page.evaluate(() => {
|
||
|
const stateSelector = 'vn-ticket-summary vn-label-value:nth-child(1) > section > span';
|
||
|
return document.querySelector(stateSelector).value;
|
||
|
});
|
||
|
throw new Error(`${stateSelector} innerText is ${state}! ${error}`);
|
||
|
}
|
||
|
await page.keyboard.press('Enter');
|
||
|
const message = await page.waitForSnackbar();
|
||
|
|
||
|
expect(message.text).toContain('Data saved!');
|
||
|
});
|
||
|
|
||
|
it('should confirm the ticket state was updated', async() => {
|
||
|
await page.waitForSpinnerLoad();
|
||
|
const result = await page.waitToGetProperty(selectors.ticketSummary.state, 'innerText');
|
||
|
|
||
|
expect(result).toContain('OK');
|
||
|
});
|
||
|
});
|