From b1381032a6f2598f654f0e4268233b21d1a3378b Mon Sep 17 00:00:00 2001 From: shinyoshiaki Date: Fri, 2 Aug 2024 16:24:54 +0900 Subject: [PATCH] timeout handling --- packages/rtc-rpc-api-client/src/rpc.ts | 70 ++++++++++++++++---------- 1 file changed, 43 insertions(+), 27 deletions(-) diff --git a/packages/rtc-rpc-api-client/src/rpc.ts b/packages/rtc-rpc-api-client/src/rpc.ts index 7db6414..c5909ff 100644 --- a/packages/rtc-rpc-api-client/src/rpc.ts +++ b/packages/rtc-rpc-api-client/src/rpc.ts @@ -264,8 +264,10 @@ export class RPC { handleMessage(), // 返信待ち中に接続が切れた場合 (async (): Promise => { - await this.onDisconnected.asPromise(rpcTimeout + 100); - if (promiseResolved || this.closed) { + const timeout = await this.onDisconnected + .asPromise(rpcTimeout + 100) + .catch((e) => e as Error); + if ((promiseResolved || this.closed) && timeout) { return {} as any; } @@ -287,31 +289,45 @@ export class RPC { }); } })(), - this.onFatalError.asPromise(rpcTimeout + 100).then((e) => { - if (promiseResolved || this.closed) { - return {} as any; - } - throw createError({ - operationName: 'RPC.request', - info: { - ...errors.internalError, - detail: 'onFatalError while requesting', - }, - path: log.prefix, - error: e, - }); - }), - this.onClosed.asPromise(rpcTimeout + 100).then(() => { - if (promiseResolved || this.closed) { - return {} as any; - } - throw createError({ - operationName: 'RPC.request', - info: errors.onClosedWhileRequesting, - path: log.prefix, - payload: { method, params }, - }); - }), + this.onFatalError + .asPromise(rpcTimeout + 100) + .then((e) => { + if (promiseResolved || this.closed) { + return {} as any; + } + throw createError({ + operationName: 'RPC.request', + info: { + ...errors.internalError, + detail: 'onFatalError while requesting', + }, + path: log.prefix, + error: e, + }); + }) + .catch(() => { + if (promiseResolved || this.closed) { + return {} as any; + } + }), + this.onClosed + .asPromise(rpcTimeout + 100) + .then(() => { + if (promiseResolved || this.closed) { + return {} as any; + } + throw createError({ + operationName: 'RPC.request', + info: errors.onClosedWhileRequesting, + path: log.prefix, + payload: { method, params }, + }); + }) + .catch(() => { + if (promiseResolved || this.closed) { + return {} as any; + } + }), ]); promiseResolved = true; } else {