mirror of
https://github.com/Koenkk/zigbee2mqtt.git
synced 2024-11-16 18:39:09 -07:00
bb6c226d55
* Add missing `zcl-id` dependency * Improve devicePublish test Now passes in both mocha and jest Each test now waits for all publishes, such as readbacks, and asserts their number. Replaced `calledOnce` and such with numeric assertion, for a more informative error message. * Use sinon default sandbox * Take assert out of chai Improves clutter, but also `jest-codemods` also makes use of this. * Replace proxyquire with simple cache delete * Reduce shared mutable state in settings.test
728 lines
42 KiB
JavaScript
728 lines
42 KiB
JavaScript
const assert = require('chai').assert;
|
|
const sinon = require('sinon');
|
|
const DevicePublish = require('../lib/extension/devicePublish');
|
|
const settings = require('../lib/util/settings');
|
|
const utils = require('./utils');
|
|
|
|
const wait = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
|
|
const mqtt = {
|
|
subscribe: (topic) => {},
|
|
};
|
|
|
|
const zigbee = {
|
|
getDevice: null,
|
|
publish: sinon.stub().callsFake((entityID, entityType, cid, cmd, cmdType, zclData, cfg, ep, callback) => {
|
|
callback(false, null);
|
|
}),
|
|
};
|
|
|
|
const publishEntityState = sinon.stub().callsFake((entityID, payload, cache) => {
|
|
});
|
|
|
|
const cfg = {
|
|
default: {
|
|
manufSpec: 0,
|
|
disDefaultRsp: 0,
|
|
},
|
|
};
|
|
|
|
describe('DevicePublish', () => {
|
|
let devicePublish;
|
|
|
|
beforeEach(() => {
|
|
utils.stubLogger(sinon);
|
|
devicePublish = new DevicePublish(zigbee, mqtt, null, publishEntityState);
|
|
});
|
|
|
|
afterEach(() => {
|
|
sinon.restore();
|
|
});
|
|
|
|
describe('Parse topic', () => {
|
|
it('Should publish messages to zigbee devices', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000001/set', JSON.stringify({brightness: '200'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000001');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToLevelWithOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {level: 200, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000001');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON', brightness: 200});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
sinon.stub(settings, 'getIeeeAddrByFriendlyName').callsFake(() => '0x00000002');
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'LCT003'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/wohnzimmer.light.wall.right/set', JSON.stringify({state: 'ON'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000002');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'on');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000002');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON'});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices when brightness is in %', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000003/set', JSON.stringify({brightness_percent: '92'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000003');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToLevelWithOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {level: 235, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000003');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON', brightness: 235});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices when brightness is in number', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000004/set', JSON.stringify({brightness: 230}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000004');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToLevelWithOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {level: 230, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000004');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON', brightness: 230});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color_temp', async () => {
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 WS opal 980lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000005/set', JSON.stringify({color_temp: '222'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000005');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToColorTemp');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {colortemp: '222', transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color_temp in %', async () => {
|
|
publishEntityState.resetHistory();
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 WS opal 980lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000006/set', JSON.stringify({color_temp_percent: '100'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000006');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToColorTemp');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {colortemp: '500', transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.isTrue(publishEntityState.notCalled);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with non-default ep', async () => {
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'lumi.ctrl_neutral1'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000007/set', JSON.stringify({state: 'OFF'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000007');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'off');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[7], 2);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with non-default ep and postfix', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'lumi.ctrl_neutral2'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000008/right/set', JSON.stringify({state: 'OFF'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000008');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'off');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[7], 3);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000008');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state_right: 'OFF'});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
|
|
it('Should publish messages to zigbee gledopto with [11,13]', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'GLEDOPTO', epList: [11, 13]});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000009/set', JSON.stringify({state: 'OFF'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000009');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'off');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[7], 11);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000009');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'OFF'});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
|
|
it('Should publish messages to zigbee gledopto with [11,12,13]', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'GLEDOPTO', epList: [11, 12, 13]});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000010/set', JSON.stringify({state: 'OFF', brightness: 50}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000010');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'off');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[7], 12);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000010');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'OFF'});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color xy', async () => {
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000011/set', JSON.stringify({color: {x: 100, y: 50}}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000011');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToColor');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {colorx: 6553500, colory: 3276750, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color xy and state', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
const payload = {color: {x: 100, y: 50}, state: 'ON'};
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000012/set', JSON.stringify(payload));
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000012');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'on');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[0], '0x00000012');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[3], 'moveToColor');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[5], {colorx: 6553500, colory: 3276750, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000012');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON'});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 3);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color xy and brightness', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
const payload = {color: {x: 100, y: 50}, brightness: 20};
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000013/set', JSON.stringify(payload));
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000013');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToLevelWithOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {level: 20, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[0], '0x00000013');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[3], 'moveToColor');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[5], {colorx: 6553500, colory: 3276750, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000013');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON', brightness: 20});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 4);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color xy, brightness and state on', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
const payload = {color: {x: 100, y: 50}, brightness: 20, state: 'oN'};
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000014/set', JSON.stringify(payload));
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000014');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToLevelWithOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {level: 20, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[0], '0x00000014');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[3], 'moveToColor');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[5], {colorx: 6553500, colory: 3276750, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000014');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON', brightness: 20});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 4);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color xy, brightness and state off', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
const payload = {color: {x: 100, y: 50}, brightness: 20, state: 'oFF'};
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000015/set', JSON.stringify(payload));
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000015');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'off');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[0], '0x00000015');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[3], 'moveToColor');
|
|
assert.strictEqual(zigbee.publish.getCall(1).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[5], {colorx: 6553500, colory: 3276750, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(1).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000015');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'OFF'});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 3);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color rgb', async () => {
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000016/set', JSON.stringify({color: {r: 100, g: 200, b: 10}}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000016');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToColor');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {colorx: 17085, colory: 44000, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish messages to zigbee devices with color rgb string', async () => {
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000017/set', JSON.stringify({color: {rgb: '100,200,10'}}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000017');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'lightingColorCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToColor');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {colorx: 17085, colory: 44000, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish 1 message when brightness with state is send', async () => {
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'TRADFRI bulb E27 CWS opal 600lm'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000018/set', JSON.stringify({state: 'ON', brightness: '50'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], '0x00000018');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'device');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToLevelWithOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {level: 50, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], '0x00000018');
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON', brightness: 50});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
|
|
it('Should publish messages to groups', async () => {
|
|
sinon.stub(settings, 'getGroupIDByFriendlyName').callsFake(() => '1');
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/group/group_1/set', JSON.stringify({state: 'ON'}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'group');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'on');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], 1);
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON'});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
|
|
it('Should publish messages to groups with brightness_percent', async () => {
|
|
sinon.stub(settings, 'getGroupIDByFriendlyName').callsFake(() => '1');
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/group/group_1/set', JSON.stringify({brightness_percent: 50}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'group');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToLevelWithOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {level: 127, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], 1);
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON', brightness: 127});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
|
|
it('Should publish messages to groups with on and brightness', async () => {
|
|
sinon.stub(settings, 'getGroupIDByFriendlyName').callsFake(() => '1');
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/group/group_1/set', JSON.stringify({state: 'ON', brightness: 50}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'group');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'moveToLevelWithOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {level: 50, transtime: 0});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], 1);
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'ON', brightness: 50});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
|
|
it('Should publish messages to groups with off and brightness', async () => {
|
|
sinon.stub(settings, 'getGroupIDByFriendlyName').callsFake(() => '1');
|
|
zigbee.publish.resetHistory();
|
|
publishEntityState.resetHistory();
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/group/group_1/set', JSON.stringify({state: 'OFF', brightness: 5}));
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[0], 1);
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[1], 'group');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[3], 'off');
|
|
assert.strictEqual(zigbee.publish.getCall(0).args[4], 'functional');
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[5], {});
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[6], cfg.default);
|
|
assert.deepEqual(zigbee.publish.getCall(0).args[7], null);
|
|
assert.strictEqual(publishEntityState.callCount, 1);
|
|
assert.strictEqual(publishEntityState.getCall(0).args[0], 1);
|
|
assert.deepEqual(publishEntityState.getCall(0).args[1], {state: 'OFF'});
|
|
assert.strictEqual(publishEntityState.getCall(0).args[2], true);
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 1);
|
|
});
|
|
});
|
|
|
|
describe('Parse topic', () => {
|
|
it('Should handle non-valid topics', () => {
|
|
const topic = 'zigbee2mqtt1/my_device_id/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed, null);
|
|
});
|
|
|
|
it('Should handle non-valid topics', () => {
|
|
const topic = 'zigbee2mqtt1/my_device_id/sett';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed, null);
|
|
});
|
|
|
|
it('Should handle non-valid topics', () => {
|
|
const topic = 'zigbee2mqtt/my_device_id/write';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed, null);
|
|
});
|
|
|
|
it('Should handle non-valid topics', () => {
|
|
const topic = 'zigbee2mqtt/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed, null);
|
|
});
|
|
|
|
it('Should handle non-valid topics', () => {
|
|
const topic = 'set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed, null);
|
|
});
|
|
|
|
it('Should parse set topic', () => {
|
|
const topic = 'zigbee2mqtt/my_device_id/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, 'my_device_id');
|
|
assert.strictEqual(parsed.postfix, '');
|
|
});
|
|
|
|
it('Should parse get topic', () => {
|
|
const topic = 'zigbee2mqtt/my_device_id2/get';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'get');
|
|
assert.strictEqual(parsed.ID, 'my_device_id2');
|
|
assert.strictEqual(parsed.postfix, '');
|
|
});
|
|
|
|
it('Should parse topic with when base topic has multiple slashes', () => {
|
|
sinon.stub(settings, 'get').callsFake(() => {
|
|
return {
|
|
mqtt: {
|
|
base_topic: 'zigbee2mqtt/at/my/home',
|
|
},
|
|
};
|
|
});
|
|
|
|
const topic = 'zigbee2mqtt/at/my/home/my_device_id2/get';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'get');
|
|
assert.strictEqual(parsed.ID, 'my_device_id2');
|
|
assert.strictEqual(parsed.postfix, '');
|
|
});
|
|
|
|
it('Should parse topic with when deviceID has multiple slashes', () => {
|
|
const topic = 'zigbee2mqtt/floor0/basement/my_device_id2/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, 'floor0/basement/my_device_id2');
|
|
assert.strictEqual(parsed.postfix, '');
|
|
});
|
|
|
|
it('Should parse topic with when base and deviceID have multiple slashes', () => {
|
|
sinon.stub(settings, 'get').callsFake(() => {
|
|
return {
|
|
mqtt: {
|
|
base_topic: 'zigbee2mqtt/at/my/basement',
|
|
},
|
|
};
|
|
});
|
|
|
|
const topic = 'zigbee2mqtt/at/my/basement/floor0/basement/my_device_id2/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, 'floor0/basement/my_device_id2');
|
|
assert.strictEqual(parsed.postfix, '');
|
|
});
|
|
|
|
it('Should parse set with ieeAddr topic', () => {
|
|
const topic = 'zigbee2mqtt/0x12345689/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, '0x12345689');
|
|
assert.strictEqual(parsed.postfix, '');
|
|
});
|
|
|
|
it('Should parse set with postfix topic', () => {
|
|
const topic = 'zigbee2mqtt/0x12345689/left/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, '0x12345689');
|
|
assert.strictEqual(parsed.postfix, 'left');
|
|
});
|
|
|
|
it('Should parse set with almost postfix topic', () => {
|
|
const topic = 'zigbee2mqtt/wohnzimmer.light.wall.right/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, 'wohnzimmer.light.wall.right');
|
|
assert.strictEqual(parsed.postfix, '');
|
|
});
|
|
|
|
it('Should parse set with postfix topic', () => {
|
|
const topic = 'zigbee2mqtt/0x12345689/right/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, '0x12345689');
|
|
assert.strictEqual(parsed.postfix, 'right');
|
|
});
|
|
|
|
it('Should parse set with postfix topic', () => {
|
|
const topic = 'zigbee2mqtt/0x12345689/bottom_left/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, '0x12345689');
|
|
assert.strictEqual(parsed.postfix, 'bottom_left');
|
|
});
|
|
|
|
it('Shouldnt parse set with invalid postfix topic', () => {
|
|
const topic = 'zigbee2mqtt/0x12345689/invalid/set';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'set');
|
|
assert.strictEqual(parsed.ID, '0x12345689/invalid');
|
|
assert.strictEqual(parsed.postfix, '');
|
|
});
|
|
|
|
it('Should parse set with and slashes in base and deviceID postfix topic', () => {
|
|
sinon.stub(settings, 'get').callsFake(() => {
|
|
return {
|
|
mqtt: {
|
|
base_topic: 'zigbee2mqtt/at/my/home',
|
|
},
|
|
};
|
|
});
|
|
|
|
const topic = 'zigbee2mqtt/at/my/home/my/device/in/basement/sensor/bottom_left/get';
|
|
const parsed = devicePublish.parseTopic(topic);
|
|
assert.strictEqual(parsed.type, 'get');
|
|
assert.strictEqual(parsed.ID, 'my/device/in/basement/sensor');
|
|
assert.strictEqual(parsed.postfix, 'bottom_left');
|
|
});
|
|
});
|
|
|
|
it('Should not publish messages to zigbee devices when payload is invalid', async () => {
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'lumi.ctrl_neutral1'});
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000019/set', JSON.stringify({state: true}));
|
|
await wait(10);
|
|
assert.isTrue(zigbee.publish.notCalled);
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000019/set', JSON.stringify({state: 1}));
|
|
await wait(10);
|
|
assert.isTrue(zigbee.publish.notCalled);
|
|
});
|
|
|
|
it('Should set state before color', async () => {
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'LCT001'});
|
|
const msg = {'state': 'ON', 'color': {'x': 0.701, 'y': 0.299}};
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000020/set', JSON.stringify(msg));
|
|
assert.equal(zigbee.publish.callCount, 2);
|
|
assert.equal(zigbee.publish.getCall(0).args[2], 'genOnOff');
|
|
assert.equal(zigbee.publish.getCall(0).args[3], 'on');
|
|
assert.equal(zigbee.publish.getCall(1).args[2], 'lightingColorCtrl');
|
|
assert.equal(zigbee.publish.getCall(1).args[3], 'moveToColor');
|
|
await wait(10);
|
|
assert.equal(zigbee.publish.callCount, 3);
|
|
assert.equal(zigbee.publish.getCall(2).args[2], 'lightingColorCtrl');
|
|
assert.equal(zigbee.publish.getCall(2).args[3], 'read');
|
|
});
|
|
|
|
it('Should set state with brightness before color', async () => {
|
|
zigbee.publish.resetHistory();
|
|
zigbee.getDevice = sinon.fake.returns({modelId: 'LCT001'});
|
|
const msg = {'state': 'ON', 'color': {'x': 0.701, 'y': 0.299}, 'transition': 3, 'brightness': 100};
|
|
devicePublish.onMQTTMessage('zigbee2mqtt/0x00000021/set', JSON.stringify(msg));
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
assert.equal(zigbee.publish.getCall(0).args[2], 'genLevelCtrl');
|
|
assert.equal(zigbee.publish.getCall(1).args[2], 'lightingColorCtrl');
|
|
await wait(10);
|
|
assert.strictEqual(zigbee.publish.callCount, 2);
|
|
});
|
|
});
|