mirror of
https://github.com/Koenkk/zigbee2mqtt.git
synced 2026-07-03 02:21:38 +00:00
7d63a9a0f2
Co-authored-by: Nerivec <62446222+Nerivec@users.noreply.github.com>
102 lines
3.5 KiB
TypeScript
102 lines
3.5 KiB
TypeScript
import * as data from '../mocks/data';
|
|
import {mockLogger} from '../mocks/logger';
|
|
import {mockMQTTPublishAsync} from '../mocks/mqtt';
|
|
import {flushPromises} from '../mocks/utils';
|
|
import {devices, events as mockZHEvents} from '../mocks/zigbeeHerdsman';
|
|
|
|
import * as zhc from 'zigbee-herdsman-converters';
|
|
|
|
import {Controller} from '../../lib/controller';
|
|
import * as settings from '../../lib/util/settings';
|
|
|
|
const mockOnEvent = vi.fn();
|
|
const mockLivoloOnEvent = vi.fn();
|
|
// @ts-expect-error mock
|
|
zhc.onEvent = mockOnEvent;
|
|
|
|
const mocksClear = [mockMQTTPublishAsync, mockLogger.warning, mockLogger.debug];
|
|
|
|
describe('Extension: OnEvent', () => {
|
|
let controller: Controller;
|
|
|
|
beforeAll(async () => {
|
|
const mappedLivolo = (await zhc.findByDevice(devices.LIVOLO))!;
|
|
mappedLivolo.onEvent = mockLivoloOnEvent;
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
vi.useFakeTimers();
|
|
data.writeDefaultConfiguration();
|
|
settings.reRead();
|
|
controller = new Controller(vi.fn(), vi.fn());
|
|
await controller.start();
|
|
await flushPromises();
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
// @ts-expect-error private
|
|
controller.state.state = {};
|
|
data.writeDefaultConfiguration();
|
|
settings.reRead();
|
|
mocksClear.forEach((m) => m.mockClear());
|
|
mockOnEvent.mockClear();
|
|
});
|
|
|
|
afterAll(async () => {
|
|
vi.useRealTimers();
|
|
});
|
|
|
|
it('Should call with start event', async () => {
|
|
expect(mockLivoloOnEvent).toHaveBeenCalledTimes(1);
|
|
const call = mockLivoloOnEvent.mock.calls[0];
|
|
expect(call[0]).toBe('start');
|
|
expect(call[1]).toStrictEqual({});
|
|
expect(call[2]).toBe(devices.LIVOLO);
|
|
expect(call[3]).toStrictEqual(settings.getDevice(devices.LIVOLO.ieeeAddr));
|
|
expect(call[4]).toStrictEqual({});
|
|
});
|
|
|
|
it('Should call with stop event', async () => {
|
|
mockLivoloOnEvent.mockClear();
|
|
await controller.stop();
|
|
await flushPromises();
|
|
expect(mockLivoloOnEvent).toHaveBeenCalledTimes(1);
|
|
const call = mockLivoloOnEvent.mock.calls[0];
|
|
expect(call[0]).toBe('stop');
|
|
expect(call[1]).toStrictEqual({});
|
|
expect(call[2]).toBe(devices.LIVOLO);
|
|
});
|
|
|
|
it('Should call with zigbee event', async () => {
|
|
mockLivoloOnEvent.mockClear();
|
|
await mockZHEvents.deviceAnnounce({device: devices.LIVOLO});
|
|
await flushPromises();
|
|
expect(mockLivoloOnEvent).toHaveBeenCalledTimes(1);
|
|
expect(mockLivoloOnEvent).toHaveBeenCalledWith(
|
|
'deviceAnnounce',
|
|
{device: devices.LIVOLO},
|
|
devices.LIVOLO,
|
|
settings.getDevice(devices.LIVOLO.ieeeAddr),
|
|
{},
|
|
{
|
|
deviceExposesChanged: expect.any(Function),
|
|
},
|
|
);
|
|
|
|
// Test deviceExposesChanged
|
|
mockMQTTPublishAsync.mockClear();
|
|
console.log(mockLivoloOnEvent.mock.calls[0][5].deviceExposesChanged());
|
|
expect(mockMQTTPublishAsync.mock.calls[0][0]).toStrictEqual('zigbee2mqtt/bridge/devices');
|
|
});
|
|
|
|
it('Should call index onEvent with zigbee event', async () => {
|
|
mockOnEvent.mockClear();
|
|
await mockZHEvents.deviceAnnounce({device: devices.LIVOLO});
|
|
await flushPromises();
|
|
expect(mockOnEvent).toHaveBeenCalledTimes(1);
|
|
expect(zhc.onEvent).toHaveBeenCalledWith('deviceAnnounce', {device: devices.LIVOLO}, devices.LIVOLO, {
|
|
deviceExposesChanged: expect.any(Function),
|
|
});
|
|
});
|
|
});
|