Skip to content

Commit

Permalink
Merge 46cd167 into 2a91b6f
Browse files Browse the repository at this point in the history
  • Loading branch information
ottoszika authored Dec 10, 2019
2 parents 2a91b6f + 46cd167 commit 80b2d65
Show file tree
Hide file tree
Showing 4 changed files with 133 additions and 1 deletion.
3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@
"ewelink-devices": "src/devices/devices.js",
"ewelink-generic-device": "src/generic-device/generic-device.js",
"ewelink-firmware-version": "src/firmware-version/firmware-version.js",
"ewelink-power-state": "src/power-state/power-state.js"
"ewelink-power-state": "src/power-state/power-state.js",
"ewelink-channel-count": "src/channel-count/channel-count.js"
}
},
"dependencies": {
Expand Down
35 changes: 35 additions & 0 deletions src/channel-count/channel-count.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
<script type="text/javascript">
RED.nodes.registerType('ewelink-channel-count', {
category: 'eWeLink',
color: '#a6bbcf',
defaults: {
name: { value: '' },
deviceId: { value: '' },
auth: { value: '', type: 'ewelink-credentials' }
},
inputs: 1,
outputs: 1,
label: function () {
return this.name || 'eWeLink Channel Count';
}
});
</script>

<script type="text/x-red" data-template-name="ewelink-channel-count">
<div class="form-row">
<label for="node-input-name"><i class="icon-tag"></i> Name</label>
<input type="text" id="node-input-name" placeholder="Name">
</div>
<div class="form-row">
<label for="node-input-name"><i class="icon-tag"></i> Device ID</label>
<input type="text" id="node-input-deviceId" placeholder="Device ID">
</div>
<div class="form-row">
<label for="node-input-auth"><i class="icon-tag"></i> eWeLink Credentials</label>
<input type="text" id="node-input-auth" placeholder="eWeLink Credentials">
</div>
</script>

<script type="text/x-red" data-help-name="ewelink-channel-count">
<p>Retrieves the channel count of the device</p>
</script>
22 changes: 22 additions & 0 deletions src/channel-count/channel-count.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
const eWeLinkConnect = require('../utils/ewelink-connect');

/**
* Channel count node.
*/
module.exports = (RED) => {
/**
* Channel count node constructor.
*
* @param {object} config The node configuration.
*/
function ChannelCountNode(config) {
// Create the node
RED.nodes.createNode(this, config);

// Initialize device node
eWeLinkConnect.initializeDeviceNode(RED, this, config, 'getDeviceChannelCount');
}

// Register node
RED.nodes.registerType('ewelink-channel-count', ChannelCountNode);
}
74 changes: 74 additions & 0 deletions test/channel-count_spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
const chai = require('chai');
const expect = chai.expect;
const sinon = require('sinon');
const helper = require('node-red-node-test-helper');
const credentialsNode = require('../src/credentials/credentials');
const channelCountNode = require('../src/channel-count/channel-count');
const eWeLinkConnect = require('../src/utils/ewelink-connect');

describe('Channel Count Node', () => {

beforeEach(done => {
helper.startServer(done);
});

afterEach(done => {
helper.unload().then(() => {
helper.stopServer(done);
});
});

it('should be loaded', done => {
const flow = [
{ id: 'n1', type: 'ewelink-credentials' },
{ id: 'n2', type: 'ewelink-channel-count', auth: 'n1', deviceId: '12345', name: 'Device 123' }
];
helper.load([credentialsNode, channelCountNode], flow, () => {
const n2 = helper.getNode('n2');

n2.should.have.property('name', 'Device 123');

done();
});
});

it('should return the result of the getDeviceChannelCount call', done => {
const connection = { getDeviceChannelCount() { } };

const methodStub = sinon.stub(connection, 'getDeviceChannelCount')
.callsFake(() => Promise.resolve({ methodResult: 'great' }));

const loginStub = sinon.stub(eWeLinkConnect, 'login')
.callsFake(() => Promise.resolve(connection));

const flow = [
{ id: 'n1', type: 'ewelink-credentials' },
{ id: 'n2', type: 'ewelink-channel-count', auth: 'n1', deviceId: '12345', wires: [['n4']] },
{ id: 'n3', type: 'helper', wires: [['n2']] },
{ id: 'n4', type: 'helper' }
];
helper.load([credentialsNode, channelCountNode], flow, () => {
const n2 = helper.getNode('n2');
const n3 = helper.getNode('n3');
const n4 = helper.getNode('n4');

setTimeout(() => {
n2.on('input', () => {
sinon.assert.calledWith(methodStub, '12345');
sinon.assert.calledOnce(loginStub);

methodStub.restore();
loginStub.restore();

n4.on('input', msg => {
expect(msg).to.deep.include({ payload: { methodResult: 'great' } });

done();
});
});

n3.send({ payload: '' });
});
});
});
});

0 comments on commit 80b2d65

Please sign in to comment.