mirror of https://github.com/grpc/grpc-node.git
Merge branch 'master' into grpc-js_uds_resolver
This commit is contained in:
commit
ce119ead0b
|
@ -0,0 +1,5 @@
|
||||||
|
# How to contribute
|
||||||
|
|
||||||
|
We definitely welcome patches and contributions to grpc-node! Please read the gRPC
|
||||||
|
organization's [governance rules](https://github.com/grpc/grpc-community/blob/master/governance.md)
|
||||||
|
and [contribution guidelines](https://github.com/grpc/grpc-community/blob/master/CONTRIBUTING.md) before proceeding.
|
|
@ -0,0 +1 @@
|
||||||
|
This repository is governed by the gRPC organization's [governance rules](https://github.com/grpc/grpc-community/blob/master/governance.md).
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "@grpc/grpc-js",
|
"name": "@grpc/grpc-js",
|
||||||
"version": "0.6.1",
|
"version": "0.6.2",
|
||||||
"description": "gRPC Library for Node - pure JS implementation",
|
"description": "gRPC Library for Node - pure JS implementation",
|
||||||
"homepage": "https://grpc.io/",
|
"homepage": "https://grpc.io/",
|
||||||
"repository": "https://github.com/grpc/grpc-node/tree/master/packages/grpc-js",
|
"repository": "https://github.com/grpc/grpc-node/tree/master/packages/grpc-js",
|
||||||
|
|
|
@ -329,9 +329,11 @@ export class Http2CallStream extends Duplex implements Call {
|
||||||
switch (stream.rstCode) {
|
switch (stream.rstCode) {
|
||||||
case http2.constants.NGHTTP2_REFUSED_STREAM:
|
case http2.constants.NGHTTP2_REFUSED_STREAM:
|
||||||
code = Status.UNAVAILABLE;
|
code = Status.UNAVAILABLE;
|
||||||
|
details = 'Stream refused by server';
|
||||||
break;
|
break;
|
||||||
case http2.constants.NGHTTP2_CANCEL:
|
case http2.constants.NGHTTP2_CANCEL:
|
||||||
code = Status.CANCELLED;
|
code = Status.CANCELLED;
|
||||||
|
details = 'Call cancelled';
|
||||||
break;
|
break;
|
||||||
case http2.constants.NGHTTP2_ENHANCE_YOUR_CALM:
|
case http2.constants.NGHTTP2_ENHANCE_YOUR_CALM:
|
||||||
code = Status.RESOURCE_EXHAUSTED;
|
code = Status.RESOURCE_EXHAUSTED;
|
||||||
|
|
|
@ -23,6 +23,7 @@ import { ChannelOptions } from './channel-options';
|
||||||
import { PeerCertificate, checkServerIdentity } from 'tls';
|
import { PeerCertificate, checkServerIdentity } from 'tls';
|
||||||
import { ConnectivityState } from './channel';
|
import { ConnectivityState } from './channel';
|
||||||
import { BackoffTimeout } from './backoff-timeout';
|
import { BackoffTimeout } from './backoff-timeout';
|
||||||
|
import { getDefaultAuthority } from './resolver';
|
||||||
|
|
||||||
const { version: clientVersion } = require('../../package.json');
|
const { version: clientVersion } = require('../../package.json');
|
||||||
|
|
||||||
|
@ -230,7 +231,7 @@ export class Subchannel {
|
||||||
};
|
};
|
||||||
connectionOptions.servername = sslTargetNameOverride;
|
connectionOptions.servername = sslTargetNameOverride;
|
||||||
} else {
|
} else {
|
||||||
connectionOptions.servername = this.channelTarget;
|
connectionOptions.servername = getDefaultAuthority(this.channelTarget);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.session = http2.connect(
|
this.session = http2.connect(
|
||||||
|
|
|
@ -22,12 +22,14 @@ import * as resolverManager from '../src/resolver';
|
||||||
import { ServiceConfig } from '../src/service-config';
|
import { ServiceConfig } from '../src/service-config';
|
||||||
import { StatusObject } from '../src/call-stream';
|
import { StatusObject } from '../src/call-stream';
|
||||||
|
|
||||||
describe('Name Resolver', () => {
|
describe('Name Resolver', function() {
|
||||||
describe('DNS Names', () => {
|
describe('DNS Names', function() {
|
||||||
before(() => {
|
// For some reason DNS queries sometimes take a long time on Windows
|
||||||
|
this.timeout(4000);
|
||||||
|
before(function() {
|
||||||
resolverManager.registerAll();
|
resolverManager.registerAll();
|
||||||
});
|
});
|
||||||
it('Should resolve localhost properly', done => {
|
it('Should resolve localhost properly', function(done) {
|
||||||
const target = 'localhost:50051';
|
const target = 'localhost:50051';
|
||||||
const listener: resolverManager.ResolverListener = {
|
const listener: resolverManager.ResolverListener = {
|
||||||
onSuccessfulResolution: (
|
onSuccessfulResolution: (
|
||||||
|
@ -46,7 +48,7 @@ describe('Name Resolver', () => {
|
||||||
const resolver = resolverManager.createResolver(target, listener);
|
const resolver = resolverManager.createResolver(target, listener);
|
||||||
resolver.updateResolution();
|
resolver.updateResolution();
|
||||||
});
|
});
|
||||||
it('Should default to port 443', done => {
|
it('Should default to port 443', function(done) {
|
||||||
const target = 'localhost';
|
const target = 'localhost';
|
||||||
const listener: resolverManager.ResolverListener = {
|
const listener: resolverManager.ResolverListener = {
|
||||||
onSuccessfulResolution: (
|
onSuccessfulResolution: (
|
||||||
|
@ -65,7 +67,7 @@ describe('Name Resolver', () => {
|
||||||
const resolver = resolverManager.createResolver(target, listener);
|
const resolver = resolverManager.createResolver(target, listener);
|
||||||
resolver.updateResolution();
|
resolver.updateResolution();
|
||||||
});
|
});
|
||||||
it('Should resolve a public address', done => {
|
it('Should resolve a public address', function(done) {
|
||||||
const target = 'example.com';
|
const target = 'example.com';
|
||||||
const listener: resolverManager.ResolverListener = {
|
const listener: resolverManager.ResolverListener = {
|
||||||
onSuccessfulResolution: (
|
onSuccessfulResolution: (
|
||||||
|
@ -83,7 +85,7 @@ describe('Name Resolver', () => {
|
||||||
const resolver = resolverManager.createResolver(target, listener);
|
const resolver = resolverManager.createResolver(target, listener);
|
||||||
resolver.updateResolution();
|
resolver.updateResolution();
|
||||||
});
|
});
|
||||||
it('Should resolve a name with multiple dots', done => {
|
it('Should resolve a name with multiple dots', function(done) {
|
||||||
const target = 'loopback4.unittest.grpc.io';
|
const target = 'loopback4.unittest.grpc.io';
|
||||||
const listener: resolverManager.ResolverListener = {
|
const listener: resolverManager.ResolverListener = {
|
||||||
onSuccessfulResolution: (
|
onSuccessfulResolution: (
|
||||||
|
@ -101,7 +103,7 @@ describe('Name Resolver', () => {
|
||||||
const resolver = resolverManager.createResolver(target, listener);
|
const resolver = resolverManager.createResolver(target, listener);
|
||||||
resolver.updateResolution();
|
resolver.updateResolution();
|
||||||
});
|
});
|
||||||
it('Should resolve a name with a hyphen', done => {
|
it('Should resolve a name with a hyphen', function(done) {
|
||||||
/* TODO(murgatroid99): Find or create a better domain name to test this with.
|
/* TODO(murgatroid99): Find or create a better domain name to test this with.
|
||||||
* This is just the first one I found with a hyphen. */
|
* This is just the first one I found with a hyphen. */
|
||||||
const target = 'network-tools.com';
|
const target = 'network-tools.com';
|
||||||
|
@ -121,6 +123,40 @@ describe('Name Resolver', () => {
|
||||||
const resolver = resolverManager.createResolver(target, listener);
|
const resolver = resolverManager.createResolver(target, listener);
|
||||||
resolver.updateResolution();
|
resolver.updateResolution();
|
||||||
});
|
});
|
||||||
|
it('Should resolve gRPC interop servers', function(done) {
|
||||||
|
let completeCount = 0;
|
||||||
|
function done2(error?: Error) {
|
||||||
|
if (error) {
|
||||||
|
done(error);
|
||||||
|
} else {
|
||||||
|
completeCount += 1;
|
||||||
|
if (completeCount === 2) {
|
||||||
|
done();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const target1 = 'grpc-test.sandbox.googleapis.com';
|
||||||
|
const target2 = 'grpc-test4.sandbox.googleapis.com';
|
||||||
|
const listener: resolverManager.ResolverListener = {
|
||||||
|
onSuccessfulResolution: (
|
||||||
|
addressList: string[],
|
||||||
|
serviceConfig: ServiceConfig | null,
|
||||||
|
serviceConfigError: StatusObject | null
|
||||||
|
) => {
|
||||||
|
assert(addressList.length > 0);
|
||||||
|
done2();
|
||||||
|
},
|
||||||
|
onError: (error: StatusObject) => {
|
||||||
|
done2(new Error(`Failed with status ${error.details}`));
|
||||||
|
},
|
||||||
|
};
|
||||||
|
const resolver1 = resolverManager.createResolver(target1, listener);
|
||||||
|
resolver1.updateResolution();
|
||||||
|
const resolver2 = resolverManager.createResolver(target1, listener);
|
||||||
|
resolver2.updateResolution();
|
||||||
|
})
|
||||||
|
});
|
||||||
|
describe('UDS Names', function() {
|
||||||
it('Should handle a relative Unix Domain Socket name', done => {
|
it('Should handle a relative Unix Domain Socket name', done => {
|
||||||
const target = 'unix:socket';
|
const target = 'unix:socket';
|
||||||
const listener: resolverManager.ResolverListener = {
|
const listener: resolverManager.ResolverListener = {
|
||||||
|
|
Loading…
Reference in New Issue