zerorpc
Version:
A port of ZeroRPC to node.js
68 lines (62 loc) • 2.18 kB
JavaScript
// Open Source Initiative OSI - The MIT License (MIT):Licensing
//
// The MIT License (MIT)
// Copyright (c) 2015 François-Xavier Bourlet (bombela+zerorpc@gmail.com)
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
var zerorpc = require(".."),
tutil = require("./lib/testutil");
module.exports = {
setUp: function(cb) {
var endpoint = tutil.random_ipc_endpoint();
this.srv = new zerorpc.Server({
iter: function(from, to, step, reply) {
for(var i=from; i<to; i+=step) {
reply(null, i, true);
}
reply();
}
});
this.srv.bind(endpoint);
this.cli = new zerorpc.Client({ timeout: 5 });
this.cli.connect(endpoint);
cb();
},
tearDown: function(cb) {
this.cli.close();
this.srv.close();
cb();
},
testStreamingMethodWithBufferResets: function(test) {
test.expect(3000);
var nextExpected = 1;
this.cli.invoke("iter", 1, 1000, 1, function(error, res, more) {
test.ifError(error);
if(nextExpected == 1000) {
test.equal(res, undefined);
test.equal(more, false);
test.done();
} else {
test.equal(res, nextExpected);
test.equal(more, true);
nextExpected += 1;
}
});
}
};