Skip to content

Commit

Permalink
Merge pull request #2597 from murgatroid99/grpc-js_server_deprecate_s…
Browse files Browse the repository at this point in the history
…tart

grpc-js: Deprecate Server#start
  • Loading branch information
murgatroid99 authored Oct 17, 2023
2 parents 4342f60 + 9765673 commit 779e970
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 37 deletions.
36 changes: 20 additions & 16 deletions packages/grpc-js/src/server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
*/

import * as http2 from 'http2';
import * as util from 'util';
import { AddressInfo } from 'net';

import { ServiceError } from './call';
Expand Down Expand Up @@ -89,6 +90,17 @@ interface BindResult {

function noop(): void {}

/**
* Decorator to wrap a class method with util.deprecate
* @param message The message to output if the deprecated method is called
* @returns
*/
function deprecate(message: string) {
return function <This, Args extends any[], Return>(target: (this: This, ...args: Args) => Return, context: ClassMethodDecoratorContext<This, (this: This, ...args: Args) => Return>) {
return util.deprecate(target, message);
}
}

function getUnimplementedStatusResponse(
methodName: string
): Partial<ServiceError> {
Expand Down Expand Up @@ -160,6 +172,10 @@ export class Server {
UntypedHandler
>();
private sessions = new Map<http2.ServerHttp2Session, ChannelzSessionInfo>();
/**
* This field only exists to ensure that the start method throws an error if
* it is called twice, as it did previously.
*/
private started = false;
private options: ChannelOptions;
private serverAddressString = 'null';
Expand Down Expand Up @@ -371,10 +387,6 @@ export class Server {
creds: ServerCredentials,
callback: (error: Error | null, port: number) => void
): void {
if (this.started === true) {
throw new Error('server is already started');
}

if (typeof port !== 'string') {
throw new TypeError('port must be a string');
}
Expand Down Expand Up @@ -709,8 +721,6 @@ export class Server {
}
}

this.started = false;

// Always destroy any available sessions. It's possible that one or more
// tryShutdown() calls are in progress. Don't wait on them to finish.
this.sessions.forEach((channelzInfo, session) => {
Expand Down Expand Up @@ -750,6 +760,10 @@ export class Server {
return this.handlers.delete(name);
}

/**
* @deprecated No longer needed as of version 1.10.x
*/
@deprecate('Calling start() is no longer necessary. It can be safely omitted.')
start(): void {
if (
this.http2ServerList.length === 0 ||
Expand All @@ -763,9 +777,6 @@ export class Server {
if (this.started === true) {
throw new Error('server is already started');
}
if (this.channelzEnabled) {
this.channelzTrace.addTrace('CT_INFO', 'Starting');
}
this.started = true;
}

Expand All @@ -786,9 +797,6 @@ export class Server {
}
}

// Close the server if necessary.
this.started = false;

for (const { server: http2Server, channelzRef: ref } of this
.http2ServerList) {
if (http2Server.listening) {
Expand Down Expand Up @@ -1053,10 +1061,6 @@ export class Server {

http2Server.on('stream', handler.bind(this));
http2Server.on('session', session => {
if (!this.started) {
session.destroy();
return;
}

const channelzRef = registerChannelzSocket(
session.socket.remoteAddress ?? 'unknown',
Expand Down
21 changes: 0 additions & 21 deletions packages/grpc-js/test/test-server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -113,27 +113,6 @@ describe('Server', () => {
});
});

it('throws if bind is called after the server is started', done => {
const server = new Server();

server.bindAsync(
'localhost:0',
ServerCredentials.createInsecure(),
(err, port) => {
assert.ifError(err);
server.start();
assert.throws(() => {
server.bindAsync(
'localhost:0',
ServerCredentials.createInsecure(),
noop
);
}, /server is already started/);
server.tryShutdown(done);
}
);
});

it('throws on invalid inputs', () => {
const server = new Server();

Expand Down

0 comments on commit 779e970

Please sign in to comment.