odoo.define('point_of_sale.tests.ChromeWidgets', function (require) {
'use strict';
const PosComponent = require('point_of_sale.PosComponent');
const PopupControllerMixin = require('point_of_sale.PopupControllerMixin');
const testUtils = require('web.test_utils');
const makePosTestEnv = require('point_of_sale.test_env');
const { xml } = owl.tags;
QUnit.module('unit tests for Chrome Widgets', {});
QUnit.test('CashierName', async function (assert) {
assert.expect(1);
class Parent extends PosComponent {}
Parent.env = makePosTestEnv();
Parent.template = xml/* html */ `
`;
Parent.env.pos.employee.name = 'Test Employee';
const parent = new Parent();
await parent.mount(testUtils.prepareTarget());
assert.strictEqual(parent.el.querySelector('span.username').innerText, 'Test Employee');
parent.unmount();
parent.destroy();
});
QUnit.test('HeaderButton', async function (assert) {
assert.expect(1);
class Parent extends PosComponent {}
Parent.env = makePosTestEnv();
Parent.template = xml/* html */ `
`;
const parent = new Parent();
await parent.mount(testUtils.prepareTarget());
const headerButton = parent.el.querySelector('.header-button');
await testUtils.dom.click(headerButton);
await testUtils.nextTick();
assert.ok(headerButton.classList.contains('confirm'));
parent.unmount();
parent.destroy();
});
QUnit.test('SyncNotification', async function (assert) {
assert.expect(5);
class Parent extends PosComponent {}
Parent.env = makePosTestEnv();
Parent.template = xml/* html */ `
`;
const pos = Parent.env.pos;
pos.set('synch', { status: 'connected', pending: false });
const parent = new Parent();
await parent.mount(testUtils.prepareTarget());
assert.ok(parent.el.querySelector('i.fa').parentElement.classList.contains('js_connected'));
pos.set('synch', { status: 'connecting', pending: false });
await testUtils.nextTick();
assert.ok(parent.el.querySelector('i.fa').parentElement.classList.contains('js_connecting'));
pos.set('synch', { status: 'disconnected', pending: false });
await testUtils.nextTick();
assert.ok(parent.el.querySelector('i.fa').parentElement.classList.contains('js_disconnected'));
pos.set('synch', { status: 'error', pending: false });
await testUtils.nextTick();
assert.ok(parent.el.querySelector('i.fa').parentElement.classList.contains('js_error'));
pos.set('synch', { status: 'error', pending: 10 });
await testUtils.nextTick();
assert.ok(parent.el.querySelector('.js_msg').innerText.includes('10'));
parent.unmount();
parent.destroy();
});
});