2014-07-29 12:10:20 +01:00
|
|
|
/**
|
|
|
|
* Copyright 2014 IBM Corp.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
**/
|
|
|
|
|
|
|
|
var should = require("should");
|
2015-01-29 09:57:09 +00:00
|
|
|
var sinon = require("sinon");
|
2014-07-29 12:10:20 +01:00
|
|
|
var when = require("when");
|
|
|
|
var request = require('supertest');
|
2015-03-16 21:57:05 +00:00
|
|
|
var express = require("express");
|
2014-10-01 14:35:51 +01:00
|
|
|
var nock;
|
|
|
|
if (!process.version.match(/^v0\.[0-9]\./)) {
|
|
|
|
// only set nock for node >= 0.10
|
2014-10-01 17:46:00 +01:00
|
|
|
try {
|
|
|
|
nock = require('nock');
|
|
|
|
} catch (err) {
|
|
|
|
// nevermind, will skip nock tests
|
|
|
|
nock = null;
|
|
|
|
}
|
2014-10-01 14:35:51 +01:00
|
|
|
}
|
2014-07-29 12:10:20 +01:00
|
|
|
var RED = require("../../red/red.js");
|
2015-11-12 09:12:14 +00:00
|
|
|
var redNodes = require("../../red/runtime/nodes");
|
|
|
|
var flows = require("../../red/runtime/nodes/flows");
|
|
|
|
var credentials = require("../../red/runtime/nodes/credentials");
|
|
|
|
var comms = require("../../red/api/comms.js");
|
|
|
|
var log = require("../../red/runtime/log.js");
|
2014-07-29 12:10:20 +01:00
|
|
|
|
|
|
|
var http = require('http');
|
|
|
|
var express = require('express');
|
|
|
|
var app = express();
|
|
|
|
|
|
|
|
var address = '127.0.0.1';
|
|
|
|
var listenPort = 0; // use ephemeral port
|
|
|
|
var port;
|
|
|
|
var url;
|
2015-01-29 09:57:09 +00:00
|
|
|
var logSpy;
|
2014-08-01 14:17:32 +01:00
|
|
|
var server;
|
|
|
|
|
2014-07-29 12:10:20 +01:00
|
|
|
function helperNode(n) {
|
|
|
|
RED.nodes.createNode(this, n);
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
2014-09-30 08:01:40 +01:00
|
|
|
load: function(testNode, testFlows, testCredentials, cb) {
|
2015-01-29 09:57:09 +00:00
|
|
|
logSpy = sinon.spy(log,"log");
|
2015-02-03 22:02:26 +00:00
|
|
|
logSpy.FATAL = log.FATAL;
|
|
|
|
logSpy.ERROR = log.ERROR;
|
2015-03-26 15:01:55 +00:00
|
|
|
logSpy.WARN = log.WARN;
|
|
|
|
logSpy.INFO = log.INFO;
|
|
|
|
logSpy.DEBUG = log.DEBUG;
|
|
|
|
logSpy.TRACE = log.TRACE;
|
|
|
|
logSpy.METRIC = log.METRIC;
|
|
|
|
|
2014-09-30 08:01:40 +01:00
|
|
|
if (typeof testCredentials === 'function') {
|
|
|
|
cb = testCredentials;
|
|
|
|
testCredentials = {};
|
|
|
|
}
|
|
|
|
|
2014-07-29 12:10:20 +01:00
|
|
|
var storage = {
|
|
|
|
getFlows: function() {
|
|
|
|
var defer = when.defer();
|
|
|
|
defer.resolve(testFlows);
|
|
|
|
return defer.promise;
|
|
|
|
},
|
|
|
|
getCredentials: function() {
|
|
|
|
var defer = when.defer();
|
2014-09-30 08:01:40 +01:00
|
|
|
defer.resolve(testCredentials);
|
2014-07-29 12:10:20 +01:00
|
|
|
return defer.promise;
|
|
|
|
},
|
2014-09-30 08:01:40 +01:00
|
|
|
saveCredentials: function() {
|
|
|
|
// do nothing
|
|
|
|
},
|
2014-07-29 12:10:20 +01:00
|
|
|
};
|
2016-06-17 08:18:26 +01:00
|
|
|
|
2014-08-28 00:35:07 +01:00
|
|
|
var settings = {
|
|
|
|
available: function() { return false; }
|
2014-10-01 14:35:51 +01:00
|
|
|
};
|
|
|
|
|
2015-05-15 10:29:13 +01:00
|
|
|
var red = {};
|
|
|
|
for (var i in RED) {
|
|
|
|
if (RED.hasOwnProperty(i) && !/^(init|start|stop)$/.test(i)) {
|
|
|
|
var propDescriptor = Object.getOwnPropertyDescriptor(RED,i);
|
|
|
|
Object.defineProperty(red,i,propDescriptor);
|
|
|
|
}
|
|
|
|
}
|
2015-07-22 11:41:58 +01:00
|
|
|
|
2015-05-15 10:29:13 +01:00
|
|
|
red["_"] = function(messageId) {
|
|
|
|
return messageId;
|
|
|
|
};
|
2015-07-22 11:41:58 +01:00
|
|
|
|
2015-11-20 23:01:13 +00:00
|
|
|
redNodes.init({settings:settings, storage:storage});
|
2015-03-16 21:57:05 +00:00
|
|
|
credentials.init(storage,express());
|
2014-07-29 12:10:20 +01:00
|
|
|
RED.nodes.registerType("helper", helperNode);
|
2014-10-22 11:29:54 +01:00
|
|
|
if (Array.isArray(testNode)) {
|
|
|
|
for (var i = 0; i < testNode.length; i++) {
|
2015-05-15 10:29:13 +01:00
|
|
|
testNode[i](red);
|
2014-10-22 11:29:54 +01:00
|
|
|
}
|
|
|
|
} else {
|
2015-05-15 10:29:13 +01:00
|
|
|
testNode(red);
|
2014-10-22 11:29:54 +01:00
|
|
|
}
|
2014-07-29 12:10:20 +01:00
|
|
|
flows.load().then(function() {
|
2015-10-30 12:48:09 +00:00
|
|
|
flows.startFlows();
|
2014-07-29 12:10:20 +01:00
|
|
|
should.deepEqual(testFlows, flows.getFlows());
|
|
|
|
cb();
|
|
|
|
});
|
|
|
|
},
|
2016-06-17 08:18:26 +01:00
|
|
|
|
2014-08-01 22:05:49 +01:00
|
|
|
unload: function() {
|
|
|
|
// TODO: any other state to remove between tests?
|
|
|
|
redNodes.clearRegistry();
|
2015-01-29 09:57:09 +00:00
|
|
|
logSpy.restore();
|
2014-08-27 23:29:26 +01:00
|
|
|
return flows.stopFlows();
|
2014-08-01 22:05:49 +01:00
|
|
|
},
|
2014-07-29 12:10:20 +01:00
|
|
|
|
|
|
|
getNode: function(id) {
|
|
|
|
return flows.get(id);
|
|
|
|
},
|
|
|
|
|
2014-09-30 08:01:40 +01:00
|
|
|
credentials: credentials,
|
|
|
|
|
2014-07-29 12:10:20 +01:00
|
|
|
clearFlows: function() {
|
2015-01-10 22:09:37 +00:00
|
|
|
return flows.stopFlows();
|
2014-07-29 12:10:20 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
request: function() {
|
|
|
|
return request(RED.httpAdmin);
|
|
|
|
},
|
|
|
|
|
|
|
|
startServer: function(done) {
|
2016-06-17 08:18:26 +01:00
|
|
|
server = http.createServer(function(req,res) { app(req,res); });
|
2015-02-04 21:29:11 +00:00
|
|
|
RED.init(server, {
|
2015-07-22 11:41:58 +01:00
|
|
|
SKIP_BUILD_CHECK: true,
|
2015-02-04 21:29:11 +00:00
|
|
|
logging:{console:{level:'off'}}
|
|
|
|
});
|
2014-07-29 12:10:20 +01:00
|
|
|
server.listen(listenPort, address);
|
|
|
|
server.on('listening', function() {
|
|
|
|
port = server.address().port;
|
|
|
|
url = 'http://' + address + ':' + port;
|
|
|
|
comms.start();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
},
|
2016-06-17 08:18:26 +01:00
|
|
|
|
2014-08-01 14:17:32 +01:00
|
|
|
//TODO consider saving TCP handshake/server reinit on start/stop/start sequences
|
2014-08-27 23:29:26 +01:00
|
|
|
stopServer: function(done) {
|
2016-06-17 08:18:26 +01:00
|
|
|
if (server) {
|
2015-03-26 15:01:55 +00:00
|
|
|
try {
|
|
|
|
server.close(done);
|
|
|
|
} catch(e) {
|
|
|
|
done();
|
|
|
|
}
|
2014-08-01 14:17:32 +01:00
|
|
|
}
|
|
|
|
},
|
2014-07-29 12:10:20 +01:00
|
|
|
|
|
|
|
url: function() { return url; },
|
|
|
|
|
2014-10-01 14:35:51 +01:00
|
|
|
nock: nock,
|
2015-03-26 15:01:55 +00:00
|
|
|
|
2015-01-29 09:57:09 +00:00
|
|
|
log: function() { return logSpy;}
|
2014-07-29 12:10:20 +01:00
|
|
|
};
|