/* * * Copyright 2015 gRPC authors. * * 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. * */ 'use strict'; var assert = require('assert'); var grpc = require('../src/grpc_extension'); /** * This is used for testing functions with multiple asynchronous calls that * can happen in different orders. This should be passed the number of async * function invocations that can occur last, and each of those should call this * function's return value * @param {function()} done The function that should be called when a test is * complete. * @param {number} count The number of calls to the resulting function if the * test passes. * @return {function()} The function that should be called at the end of each * sequence of asynchronous functions. */ function multiDone(done, count) { return function() { count -= 1; if (count <= 0) { done(); } }; } var insecureCreds = grpc.ChannelCredentials.createInsecure(); describe('channel', function() { describe('constructor', function() { it('should require a string for the first argument', function() { assert.doesNotThrow(function() { new grpc.Channel('hostname', insecureCreds); }); assert.throws(function() { new grpc.Channel(); }, TypeError); assert.throws(function() { new grpc.Channel(5); }); }); it('should require a credential for the second argument', function() { assert.doesNotThrow(function() { new grpc.Channel('hostname', insecureCreds); }); assert.throws(function() { new grpc.Channel('hostname', 5); }); assert.throws(function() { new grpc.Channel('hostname'); }); }); it('should accept an object for the third argument', function() { assert.doesNotThrow(function() { new grpc.Channel('hostname', insecureCreds, {}); }); assert.throws(function() { new grpc.Channel('hostname', insecureCreds, 'abc'); }); }); it('should only accept objects with string or int values', function() { assert.doesNotThrow(function() { new grpc.Channel('hostname', insecureCreds,{'key' : 'value'}); }); assert.doesNotThrow(function() { new grpc.Channel('hostname', insecureCreds, {'key' : 5}); }); assert.throws(function() { new grpc.Channel('hostname', insecureCreds, {'key' : null}); }); assert.throws(function() { new grpc.Channel('hostname', insecureCreds, {'key' : new Date()}); }); }); it('should succeed without the new keyword', function() { assert.doesNotThrow(function() { var channel = grpc.Channel('hostname', insecureCreds); assert(channel instanceof grpc.Channel); }); }); }); describe('close', function() { var channel; beforeEach(function() { channel = new grpc.Channel('hostname', insecureCreds, {}); }); it('should succeed silently', function() { assert.doesNotThrow(function() { channel.close(); }); }); it('should be idempotent', function() { assert.doesNotThrow(function() { channel.close(); channel.close(); }); }); }); describe('getTarget', function() { var channel; beforeEach(function() { channel = new grpc.Channel('hostname', insecureCreds, {}); }); it('should return a string', function() { assert.strictEqual(typeof channel.getTarget(), 'string'); }); }); describe('getConnectivityState', function() { var channel; beforeEach(function() { channel = new grpc.Channel('hostname', insecureCreds, {}); }); it('should return IDLE for a new channel', function() { assert.strictEqual(channel.getConnectivityState(), grpc.connectivityState.IDLE); }); }); describe('watchConnectivityState', function() { var channel; beforeEach(function() { channel = new grpc.Channel('localhost', insecureCreds, {}); }); afterEach(function() { channel.close(); }); it('should time out if called alone', function(done) { var old_state = channel.getConnectivityState(); var deadline = new Date(); deadline.setSeconds(deadline.getSeconds() + 1); channel.watchConnectivityState(old_state, deadline, function(err, value) { assert(err); done(); }); }); it('should complete if a connection attempt is forced', function(done) { var old_state = channel.getConnectivityState(); var deadline = new Date(); deadline.setSeconds(deadline.getSeconds() + 1); channel.watchConnectivityState(old_state, deadline, function(err, value) { assert.ifError(err); assert.notEqual(value.new_state, old_state); done(); }); channel.getConnectivityState(true); }); it('should complete twice if called twice', function(done) { done = multiDone(done, 2); var old_state = channel.getConnectivityState(); var deadline = new Date(); deadline.setSeconds(deadline.getSeconds() + 1); channel.watchConnectivityState(old_state, deadline, function(err, value) { assert.ifError(err); assert.notEqual(value.new_state, old_state); done(); }); channel.watchConnectivityState(old_state, deadline, function(err, value) { assert.ifError(err); assert.notEqual(value.new_state, old_state); done(); }); channel.getConnectivityState(true); }); }); });