1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
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 */ `
<div><CashierName></CashierName></div>
`;
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 */ `
<div><HeaderButton></HeaderButton></div>
`;
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 */ `
<div>
<SyncNotification></SyncNotification>
</div>
`;
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();
});
});
|