141 lines
5.3 KiB
JavaScript
141 lines
5.3 KiB
JavaScript
var should = require("should");
|
|
var helper = require("node-red-node-test-helper");
|
|
var bookNode = require("../book.js");
|
|
var sheetNode = require("../sheet.js");
|
|
var cellNode = require("../cell.js");
|
|
var fs = require("fs");
|
|
|
|
helper.init(require.resolve('node-red'));
|
|
|
|
describe('cell Node', function () {
|
|
|
|
before(function (done) {
|
|
helper.startServer(done);
|
|
});
|
|
|
|
after(function (done) {
|
|
helper.stopServer(done);
|
|
});
|
|
|
|
afterEach(function () {
|
|
helper.unload();
|
|
});
|
|
|
|
it('should be loaded', function (done) {
|
|
var flow = [{ id: "n1", type: "cell", name: "cell1" }];
|
|
helper.load(cellNode, flow, function () {
|
|
var n1 = helper.getNode("n1");
|
|
n1.should.have.property('name', 'cell1');
|
|
done();
|
|
});
|
|
});
|
|
|
|
it('should pick the cell value specified in node config', function (done) {
|
|
var flow = [
|
|
{ id: "n1", type: "book", name: "book1", wires: [["n2"]] },
|
|
{ id: "n2", type: "sheet", name: "sheet1", wires: [["n3"]], sheetName: "Sheet1" },
|
|
{ id: "n3", type: "cell", name: "cell1", wires: [["n4"]], address: "A1", dataType: "w" },
|
|
{ id: "n4", type: "helper" }
|
|
];
|
|
helper.load([bookNode, sheetNode, cellNode], flow, function () {
|
|
var n4 = helper.getNode("n4");
|
|
n4.on("input", function (msg) {
|
|
msg.should.have.property('payload', 'col1');
|
|
done();
|
|
});
|
|
var n1 = helper.getNode("n1");
|
|
var data = fs.readFileSync(__dirname + "/example.xlsx");
|
|
n1.receive({ payload: data });
|
|
});
|
|
});
|
|
|
|
it('should pick the cell type specified in node config', function (done) {
|
|
var flow = [
|
|
{ id: "n1", type: "book", name: "book1", wires: [["n2"]] },
|
|
{ id: "n2", type: "sheet", name: "sheet1", wires: [["n3"]], sheetName: "Sheet1" },
|
|
{ id: "n3", type: "cell", name: "cell1", wires: [["n4"]], address: "A1", dataType: "t" },
|
|
{ id: "n4", type: "helper" }
|
|
];
|
|
helper.load([bookNode, sheetNode, cellNode], flow, function () {
|
|
var n4 = helper.getNode("n4");
|
|
n4.on("input", function (msg) {
|
|
msg.should.have.property('payload', 's');
|
|
done();
|
|
});
|
|
var n1 = helper.getNode("n1");
|
|
var data = fs.readFileSync(__dirname + "/example.xlsx");
|
|
n1.receive({ payload: data });
|
|
});
|
|
});
|
|
|
|
it('should pick the cell value specified in msg object', function (done) {
|
|
var flow = [
|
|
{ id: "n1", type: "book", name: "book1", wires: [["n2"]] },
|
|
{ id: "n2", type: "sheet", name: "sheet1", wires: [["n3"]], sheetName: "Sheet1" },
|
|
{ id: "n3", type: "cell", name: "cell1", wires: [["n4"]], address: "", dataType: "w" },
|
|
{ id: "n4", type: "helper" }
|
|
];
|
|
helper.load([bookNode, sheetNode, cellNode], flow, function () {
|
|
var n4 = helper.getNode("n4");
|
|
n4.on("input", function (msg) {
|
|
msg.should.have.property('payload', 'col1');
|
|
done();
|
|
});
|
|
var n1 = helper.getNode("n1");
|
|
var data = fs.readFileSync(__dirname + "/example.xlsx");
|
|
n1.receive({ payload: data, selectAddress: "A1" });
|
|
});
|
|
});
|
|
|
|
it('should log an error due to no address', function (done) {
|
|
var flow = [
|
|
{ id: "n1", type: "cell", name: "cell1", wires: [["n2"]], address: "", dataType: "w" }
|
|
];
|
|
helper.load(cellNode, flow, function () {
|
|
var n1 = helper.getNode("n1");
|
|
n1.receive({});
|
|
try {
|
|
helper.log().called.should.be.true();
|
|
var logEvents = helper.log().args.filter(function (evt) {
|
|
return evt[0].type == "cell";
|
|
});
|
|
logEvents.should.have.length(1);
|
|
var msg = logEvents[0][0];
|
|
msg.should.have.property('level', helper.log().ERROR);
|
|
msg.should.have.property('id', 'n1');
|
|
msg.should.have.property('type', 'cell');
|
|
msg.should.have.property('msg', 'cell.errors.no-address');
|
|
done();
|
|
} catch (err) {
|
|
done(err);
|
|
}
|
|
});
|
|
});
|
|
|
|
it('should log an error due to invalid address', function (done) {
|
|
var flow = [
|
|
{ id: "n1", type: "cell", name: "cell1", wires: [["n2"]], address: "INVARID_ADDRESS", dataType: "w" }
|
|
];
|
|
helper.load(cellNode, flow, function () {
|
|
var n1 = helper.getNode("n1");
|
|
n1.receive({});
|
|
try {
|
|
helper.log().called.should.be.true();
|
|
var logEvents = helper.log().args.filter(function (evt) {
|
|
return evt[0].type == "cell";
|
|
});
|
|
logEvents.should.have.length(1);
|
|
var msg = logEvents[0][0];
|
|
msg.should.have.property('level', helper.log().ERROR);
|
|
msg.should.have.property('id', 'n1');
|
|
msg.should.have.property('type', 'cell');
|
|
msg.should.have.property('msg', 'cell.errors.invalid-address: INVARID_ADDRESS');
|
|
done();
|
|
} catch (err) {
|
|
done(err);
|
|
}
|
|
});
|
|
});
|
|
|
|
});
|