diff --git a/lib/rpc/SingleJsonRpcProvider.ts b/lib/rpc/SingleJsonRpcProvider.ts index a0e52efcc1..ae086b5f1e 100644 --- a/lib/rpc/SingleJsonRpcProvider.ts +++ b/lib/rpc/SingleJsonRpcProvider.ts @@ -178,25 +178,12 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { } } - async evaluateLatency(latency: number, methodName: string, ...args: any[]) { + async evaluateLatency(methodName: string, ...args: any[]) { this.log.debug(`${this.url}: Evaluate for latency... methodName: ${methodName}`) this.logEvaluateLatency() this.evaluatingLatency = true try { - switch (methodName) { - case CALL_METHOD_NAME: - const transaction: Deferrable = args[0] - const blockTag: BlockTag | Promise = args[1] - - return await this.call_EvaluateLatency(transaction, blockTag, latency) - case SEND_METHOD_NAME: - const underlyingMethodName = args[0] - const params: Array = args.splice(1) - - return await this.send_EvaluateLatency(underlyingMethodName, params, latency) - default: - return await (this as any)[`${methodName}_EvaluateLatency`](...args) - } + return await (this as any)[`${methodName}_EvaluateLatency`](...args) } catch (error: any) { this.log.error({ error }, `Encounter error for shadow evaluate latency call: ${JSON.stringify(error)}`) // Swallow the error. @@ -277,7 +264,6 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { callType: CallType, fnName: string, fn: (...args: any[]) => Promise, - latency?: number, ...args: any[] ): Promise { this.log.debug( @@ -298,20 +284,6 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { const result = await fn(...args) perf.latencyInMs = Date.now() - perf.startTimestampInMs - // The provider latency we evaluate against should always be faster than the provider we are using in prod currently. - // If that's not the case, we need to log the RPC request payload to help debugging. - if (latency && perf.latencyInMs > latency) { - const evaluatedLatency = perf.latencyInMs - this.log.error( - { latency, evaluatedLatency }, - `Slower evaluated latency for provider ${ - this.providerName - }. SingleJsonRpcProvider: wrappedFunctionCall: callType: ${callType}, provider: ${ - this.url - }, fnName: ${fnName}, fn: ${fn}, args: ${JSON.stringify([...args])}` - ) - } - return result } catch (error: any) { perf.succeed = false @@ -374,7 +346,7 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { ///////////////////// Begin of override functions ///////////////////// override getBlockNumber(): Promise { - return this.wrappedFunctionCall(CallType.NORMAL, 'getBlockNumber', this._getBlockNumber.bind(this), undefined) + return this.wrappedFunctionCall(CallType.NORMAL, 'getBlockNumber', this._getBlockNumber.bind(this)) } override getBlockWithTransactions( @@ -384,28 +356,20 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { CallType.NORMAL, 'getBlockWithTransactions', super.getBlockWithTransactions.bind(this), - undefined, blockHashOrBlockTag ) } override getCode(addressOrName: string | Promise, blockTag?: BlockTag | Promise): Promise { - return this.wrappedFunctionCall( - CallType.NORMAL, - 'getCode', - super.getCode.bind(this), - undefined, - addressOrName, - blockTag - ) + return this.wrappedFunctionCall(CallType.NORMAL, 'getCode', super.getCode.bind(this), addressOrName, blockTag) } override getGasPrice(): Promise { - return this.wrappedFunctionCall(CallType.NORMAL, 'getGasPrice', super.getGasPrice.bind(this), undefined) + return this.wrappedFunctionCall(CallType.NORMAL, 'getGasPrice', super.getGasPrice.bind(this)) } override getLogs(filter: Filter): Promise> { - return this.wrappedFunctionCall(CallType.NORMAL, 'getLogs', super.getLogs.bind(this), undefined, filter) + return this.wrappedFunctionCall(CallType.NORMAL, 'getLogs', super.getLogs.bind(this), filter) } override getStorageAt( @@ -417,7 +381,6 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { CallType.NORMAL, 'getStorageAt', super.getStorageAt.bind(this), - undefined, addressOrName, position, blockTag @@ -425,13 +388,7 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { } override getTransaction(transactionHash: string | Promise): Promise { - return this.wrappedFunctionCall( - CallType.NORMAL, - 'getTransaction', - super.getTransaction.bind(this), - undefined, - transactionHash - ) + return this.wrappedFunctionCall(CallType.NORMAL, 'getTransaction', super.getTransaction.bind(this), transactionHash) } override getTransactionCount( @@ -442,7 +399,6 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { CallType.NORMAL, 'getTransactionCount', super.getTransactionCount.bind(this), - undefined, addressOrName, blockTag ) @@ -453,23 +409,16 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { CallType.NORMAL, 'getTransactionReceipt', super.getTransactionReceipt.bind(this), - undefined, transactionHash ) } override lookupAddress(address: string | Promise): Promise { - return this.wrappedFunctionCall( - CallType.NORMAL, - 'lookupAddress', - super.lookupAddress.bind(this), - undefined, - address - ) + return this.wrappedFunctionCall(CallType.NORMAL, 'lookupAddress', super.lookupAddress.bind(this), address) } override resolveName(name: string | Promise): Promise { - return this.wrappedFunctionCall(CallType.NORMAL, 'resolveName', super.resolveName.bind(this), undefined, name) + return this.wrappedFunctionCall(CallType.NORMAL, 'resolveName', super.resolveName.bind(this), name) } override sendTransaction(signedTransaction: string | Promise): Promise { @@ -477,7 +426,6 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { CallType.NORMAL, 'sendTransaction', super.sendTransaction.bind(this), - undefined, signedTransaction ) } @@ -491,7 +439,6 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { CallType.NORMAL, 'waitForTransaction', super.waitForTransaction.bind(this), - undefined, transactionHash, confirmations, timeout @@ -499,12 +446,12 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { } override call(transaction: Deferrable, blockTag?: BlockTag | Promise): Promise { - return this.wrappedFunctionCall(CallType.NORMAL, 'call', super.call.bind(this), undefined, transaction, blockTag) + return this.wrappedFunctionCall(CallType.NORMAL, 'call', super.call.bind(this), transaction, blockTag) } override send(method: string, params: Array): Promise { this.logSendMetrod(method) - return this.wrappedFunctionCall(CallType.NORMAL, 'send', super.send.bind(this), undefined, method, params) + return this.wrappedFunctionCall(CallType.NORMAL, 'send', super.send.bind(this), method, params) } ///////////////////// Begin of special functions ///////////////////// @@ -516,37 +463,24 @@ export class SingleJsonRpcProvider extends StaticJsonRpcProvider { } private getBlockNumber_EvaluateHealthiness(): Promise { - return this.wrappedFunctionCall(CallType.HEALTH_CHECK, 'getBlockNumber', this._getBlockNumber.bind(this), undefined) + return this.wrappedFunctionCall(CallType.HEALTH_CHECK, 'getBlockNumber', this._getBlockNumber.bind(this)) } // @ts-ignore private getBlockNumber_EvaluateLatency(): Promise { - return this.wrappedFunctionCall( - CallType.LATENCY_EVALUATION, - 'getBlockNumber', - this._getBlockNumber.bind(this), - undefined - ) + return this.wrappedFunctionCall(CallType.LATENCY_EVALUATION, 'getBlockNumber', this._getBlockNumber.bind(this)) } // @ts-ignore private call_EvaluateLatency( transaction: Deferrable, - blockTag?: BlockTag | Promise, - latency?: number + blockTag?: BlockTag | Promise ): Promise { - return this.wrappedFunctionCall( - CallType.LATENCY_EVALUATION, - 'call', - super.call.bind(this), - latency, - transaction, - blockTag - ) + return this.wrappedFunctionCall(CallType.LATENCY_EVALUATION, 'call', super.call.bind(this), transaction, blockTag) } // @ts-ignore - private send_EvaluateLatency(method: string, params: Array, latency?: number): Promise { - return this.wrappedFunctionCall(CallType.LATENCY_EVALUATION, 'send', super.send.bind(this), latency, method, params) + private send_EvaluateLatency(method: string, params: Array): Promise { + return this.wrappedFunctionCall(CallType.LATENCY_EVALUATION, 'send', super.send.bind(this), method, params) } } diff --git a/lib/rpc/UniJsonRpcProvider.ts b/lib/rpc/UniJsonRpcProvider.ts index bbc8897efa..ff7e5add54 100644 --- a/lib/rpc/UniJsonRpcProvider.ts +++ b/lib/rpc/UniJsonRpcProvider.ts @@ -239,7 +239,7 @@ export class UniJsonRpcProvider extends StaticJsonRpcProvider { // Within each provider latency shadow evaluation, we should do block I/O, // because NodeJS runs in single thread, so it's important to make sure // we benchmark the latencies correctly based on the single-threaded sequential evaluation. - const evaluatedProviderResponse = await provider[`evaluateLatency`](latency, methodName, ...args) + const evaluatedProviderResponse = await provider[`evaluateLatency`](methodName, ...args) // below invocation does not make the call/send RPC return the correct data // both call and send will return "0x" for some reason // I have to change to above invocation to make call/send return geniun RPC response diff --git a/test/mocha/unit/rpc/UniJsonRpcProvider.test.ts b/test/mocha/unit/rpc/UniJsonRpcProvider.test.ts index c7d1bf085d..4d61316aff 100644 --- a/test/mocha/unit/rpc/UniJsonRpcProvider.test.ts +++ b/test/mocha/unit/rpc/UniJsonRpcProvider.test.ts @@ -704,9 +704,9 @@ describe('UniJsonRpcProvider', () => { // Shadow evaluate call should be made expect(spy0.callCount).to.equal(0) expect(spy1.callCount).to.equal(1) - expect(spy1.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy1.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(spy2.callCount).to.equal(1) - expect(spy2.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy2.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(uniProvider['providers'][1]['lastLatencyEvaluationTimestampInMs']).equals(timestamp) expect(uniProvider['providers'][2]['lastLatencyEvaluationTimestampInMs']).equals(timestamp) @@ -746,9 +746,9 @@ describe('UniJsonRpcProvider', () => { // Shadow evaluate call should be made expect(spy0.callCount).to.equal(0) expect(spy1.callCount).to.equal(1) - expect(spy1.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy1.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(spy2.callCount).to.equal(1) - expect(spy2.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy2.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(uniProvider['providers'][1]['lastLatencyEvaluationTimestampInMs']).equals(timestamp) expect(uniProvider['providers'][2]['lastLatencyEvaluationTimestampInMs']).equals(timestamp) @@ -774,10 +774,10 @@ describe('UniJsonRpcProvider', () => { await uniProvider.getBlockNumber('sessionId') expect(spy1.callCount).to.equal(1) - expect(spy1.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy1.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(uniProvider['providers'][1]['lastLatencyEvaluationTimestampInMs']).equals(timestamp + 16000) expect(spy2.callCount).to.equal(1) - expect(spy2.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy2.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(uniProvider['providers'][2]['lastLatencyEvaluationTimestampInMs']).equals(timestamp + 16000) }) @@ -822,9 +822,9 @@ describe('UniJsonRpcProvider', () => { expect(spy0.callCount).to.equal(0) expect(spy1.callCount).to.equal(5) - expect(spy1.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy1.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(spy2.callCount).to.equal(5) - expect(spy2.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy2.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(uniProvider['providers'][1]['lastLatencyEvaluationTimestampInMs']).equals(timestamp) expect(uniProvider['providers'][2]['lastLatencyEvaluationTimestampInMs']).equals(timestamp) @@ -946,9 +946,9 @@ describe('UniJsonRpcProvider', () => { // 0.4 < 0.5, Shadow evaluate call should be made expect(spy0.callCount).to.equal(0) expect(spy1.callCount).to.equal(1) - expect(spy1.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy1.getCalls()[0].firstArg).to.equal('getBlockNumber') expect(spy2.callCount).to.equal(1) - expect(spy2.getCalls()[0].lastArg).to.equal('getBlockNumber') + expect(spy2.getCalls()[0].firstArg).to.equal('getBlockNumber') }) it('Test use of healthCheckSampleProb', async () => {