mirror of https://github.com/grpc/grpc-node.git
Added failing tests for server bad argument handling
This commit is contained in:
parent
b0390c4af8
commit
06ddb92e9c
|
@ -47,6 +47,8 @@ var mathService = math_proto.lookup('math.Math');
|
|||
|
||||
var capitalize = require('underscore.string/capitalize');
|
||||
|
||||
var _ = require('underscore');
|
||||
|
||||
describe('File loader', function() {
|
||||
it('Should load a proto file by default', function() {
|
||||
assert.doesNotThrow(function() {
|
||||
|
@ -178,9 +180,10 @@ describe('Generic client and server', function() {
|
|||
});
|
||||
});
|
||||
});
|
||||
describe('Trailing metadata', function() {
|
||||
describe('Other conditions', function() {
|
||||
var client;
|
||||
var server;
|
||||
var port;
|
||||
before(function() {
|
||||
var test_proto = ProtoBuf.loadProtoFile(__dirname + '/test_service.proto');
|
||||
var test_service = test_proto.lookup('TestService');
|
||||
|
@ -189,6 +192,7 @@ describe('Trailing metadata', function() {
|
|||
TestService: {
|
||||
unary: function(call, cb) {
|
||||
var req = call.request;
|
||||
debugger;
|
||||
if (req.error) {
|
||||
cb(new Error('Requested error'), null, {metadata: ['yes']});
|
||||
} else {
|
||||
|
@ -246,7 +250,7 @@ describe('Trailing metadata', function() {
|
|||
}
|
||||
}
|
||||
});
|
||||
var port = server.bind('localhost:0');
|
||||
port = server.bind('localhost:0');
|
||||
var Client = surface_client.makeProtobufClientConstructor(test_service);
|
||||
client = new Client('localhost:' + port);
|
||||
server.listen();
|
||||
|
@ -254,6 +258,82 @@ describe('Trailing metadata', function() {
|
|||
after(function() {
|
||||
server.shutdown();
|
||||
});
|
||||
describe('Server recieving bad input', function() {
|
||||
var misbehavingClient;
|
||||
var badArg = new Buffer([0xFF]);
|
||||
before(function() {
|
||||
var test_service_attrs = {
|
||||
unary: {
|
||||
path: '/TestService/Unary',
|
||||
requestStream: false,
|
||||
responseStream: false,
|
||||
requestSerialize: _.identity,
|
||||
responseDeserialize: _.identity
|
||||
},
|
||||
clientStream: {
|
||||
path: '/TestService/ClientStream',
|
||||
requestStream: true,
|
||||
responseStream: false,
|
||||
requestSerialize: _.identity,
|
||||
responseDeserialize: _.identity
|
||||
},
|
||||
serverStream: {
|
||||
path: '/TestService/ServerStream',
|
||||
requestStream: false,
|
||||
responseStream: true,
|
||||
requestSerialize: _.identity,
|
||||
responseDeserialize: _.identity
|
||||
},
|
||||
bidiStream: {
|
||||
path: '/TestService/BidiStream',
|
||||
requestStream: true,
|
||||
responseStream: true,
|
||||
requestSerialize: _.identity,
|
||||
responseDeserialize: _.identity
|
||||
}
|
||||
};
|
||||
var Client = surface_client.makeClientConstructor(test_service_attrs,
|
||||
'TestService');
|
||||
misbehavingClient = new Client('localhost:' + port);
|
||||
});
|
||||
it('should respond correctly to a unary call', function(done) {
|
||||
var call = misbehavingClient.unary(badArg, function(err, data) {
|
||||
assert(err);
|
||||
assert.strictEqual(err.code, grpc.status.INVALID_ARGUMENT);
|
||||
done();
|
||||
});
|
||||
});
|
||||
it('should respond correctly to a client stream', function(done) {
|
||||
var call = misbehavingClient.clientStream(function(err, data) {
|
||||
assert(err);
|
||||
assert.strictEqual(err.code, grpc.status.INVALID_ARGUMENT);
|
||||
done();
|
||||
});
|
||||
call.write(badArg);
|
||||
});
|
||||
it('should respond correctly to a server stream', function(done) {
|
||||
var call = misbehavingClient.serverStream(badArg);
|
||||
call.on('data', function(data) {
|
||||
assert.fail(data, null, 'Unexpected data', '!=');
|
||||
});
|
||||
call.on('error', function(err) {
|
||||
assert.strictEqual(err.code, grpc.status.INVALID_ARGUMENT);
|
||||
done();
|
||||
});
|
||||
});
|
||||
it('should respond correctly to a bidi stream', function(done) {
|
||||
var call = misbehavingClient.bidiStream();
|
||||
call.on('data', function(data) {
|
||||
assert.fail(data, null, 'Unexpected data', '!=');
|
||||
});
|
||||
call.on('error', function(err) {
|
||||
assert.strictEqual(err.code, grpc.status.INVALID_ARGUMENT);
|
||||
done();
|
||||
});
|
||||
call.write(badArg);
|
||||
});
|
||||
});
|
||||
describe('Trailing metadata', function() {
|
||||
it('should be present when a unary call succeeds', function(done) {
|
||||
var call = client.unary({error: false}, function(err, data) {
|
||||
assert.ifError(err);
|
||||
|
@ -337,6 +417,7 @@ describe('Trailing metadata', function() {
|
|||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
describe('Cancelling surface client', function() {
|
||||
var client;
|
||||
var server;
|
||||
|
|
Loading…
Reference in New Issue