From 871655515cc89af3eacad855db475d3f1ada2005 Mon Sep 17 00:00:00 2001 From: Chad Nehemiah Date: Mon, 14 Aug 2023 16:52:25 -0500 Subject: [PATCH] fix(@libp2p/protocol-perf): ensure only client calls measure performance (#1960) --- packages/protocol-perf/package.json | 1 - packages/protocol-perf/src/main.ts | 26 +++++++------------------- 2 files changed, 7 insertions(+), 20 deletions(-) diff --git a/packages/protocol-perf/package.json b/packages/protocol-perf/package.json index b420211831..69597e47e6 100644 --- a/packages/protocol-perf/package.json +++ b/packages/protocol-perf/package.json @@ -58,7 +58,6 @@ "@libp2p/tcp": "^8.0.3", "@multiformats/multiaddr": "^12.1.5", "libp2p": "^0.46.4", - "p-wait-for": "^5.0.2", "uint8arrays": "^4.0.6", "yargs": "^17.7.2" }, diff --git a/packages/protocol-perf/src/main.ts b/packages/protocol-perf/src/main.ts index 33c96e6a92..f994fdc015 100644 --- a/packages/protocol-perf/src/main.ts +++ b/packages/protocol-perf/src/main.ts @@ -5,12 +5,10 @@ import { tcp } from '@libp2p/tcp' import { multiaddr } from '@multiformats/multiaddr' import { createLibp2p } from 'libp2p' import { plaintext } from 'libp2p/insecure' -import pWaitFor from 'p-wait-for' import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string' import yargs from 'yargs' import { hideBin } from 'yargs/helpers' import { defaultInit, perfService } from '../src/index.js' -import type { Connection } from '@libp2p/interface/connection' const argv = yargs(hideBin(process.argv)) .options({ @@ -89,24 +87,14 @@ export async function main (runServer: boolean, serverIpAddress: string, transpo const startTime = Date.now() - let connection: any = null - - if (runServer) { - node.addEventListener('connection:open', (eventInfo) => { - connection = eventInfo.detail - }) - } else { - connection = await node.dial(multiaddr(tcpMultiaddrAddress)) + if (!runServer) { + const connection = await node.dial(multiaddr(tcpMultiaddrAddress)) + const duration = await node.services.perf.measurePerformance(startTime, connection, BigInt(uploadBytes), BigInt(downloadBytes)) + // Output latency to stdout in seconds + // eslint-disable-next-line no-console + console.log(JSON.stringify({ latency: duration / 1000 })) + await node.stop() } - - await pWaitFor(() => connection != null) - - const duration = await node.services.perf.measurePerformance(startTime, connection as Connection, BigInt(uploadBytes), BigInt(downloadBytes)) - - await node.stop() - - // eslint-disable-next-line no-console - console.log('latency: ' + JSON.stringify({ latency: duration })) } function splitHostPort (address: string): { host: string, port?: string } {