From 67fe07447166040c78cbb6a98e6c02bd943174e9 Mon Sep 17 00:00:00 2001 From: Arseniy Klempner Date: Fri, 26 Jul 2024 13:15:54 -0700 Subject: [PATCH] feat: record light push errors in dogfooding (#79) --- examples/dogfooding/src/index.ts | 33 ++++++++++++++------- examples/dogfooding/src/telemetry_client.ts | 19 ++++++++++++ 2 files changed, 42 insertions(+), 10 deletions(-) diff --git a/examples/dogfooding/src/index.ts b/examples/dogfooding/src/index.ts index fa4e171..1ed625f 100644 --- a/examples/dogfooding/src/index.ts +++ b/examples/dogfooding/src/index.ts @@ -11,13 +11,15 @@ import { import { Type, Field } from "protobufjs"; import { TelemetryClient, + TelemetryPushError, TelemetryPushFilter, TelemetryType, } from "./telemetry_client"; import { generateRandomNumber, hashNumber } from "./util"; const DEFAULT_CONTENT_TOPIC = "/js-waku-examples/1/message-ratio/utf8"; -const TELEMETRY_URL = process.env.TELEMETRY_URL || "http://localhost:8080/waku-metrics"; +const TELEMETRY_URL = + process.env.TELEMETRY_URL || "http://localhost:8080/waku-metrics"; const ProtoSequencedMessage = new Type("SequencedMessage") .add(new Field("hash", 1, "string")) @@ -42,9 +44,13 @@ export async function app(telemetryClient: TelemetryClient) { // TODO: https://github.com/waku-org/js-waku/issues/2079 // Dialing bootstrap peers right on start in order to have Filter subscription initiated properly await node.dial("/dns4/node-01.do-ams3.waku.test.status.im/tcp/8000/wss"); - await node.dial("/dns4/node-01.ac-cn-hongkong-c.waku.test.status.im/tcp/8000/wss"); - await node.dial("/dns4/node-01.gc-us-central1-a.waku.test.status.im/tcp/8000/wss"); - + await node.dial( + "/dns4/node-01.ac-cn-hongkong-c.waku.test.status.im/tcp/8000/wss" + ); + await node.dial( + "/dns4/node-01.gc-us-central1-a.waku.test.status.im/tcp/8000/wss" + ); + await waitForRemotePeer(node); const peerId = node.libp2p.peerId.toString(); @@ -107,7 +113,17 @@ export async function app(telemetryClient: TelemetryClient) { sequenceIndex++; } if (result.failures.length > 0) { - console.error("Failed to send message", result.failures); + telemetryClient.push( + result.failures.map((failure) => ({ + messageType: TelemetryType.LIGHT_PUSH_ERROR, + timestamp: Math.floor(new Date().getTime() / 1000), + peerId: peerId, + peerIdRemote: failure.peerId?.toString(), + errorMessage: failure.error.toString(), + contentTopic: DEFAULT_CONTENT_TOPIC, + pubsubTopic: DefaultPubsubTopic, + })) + ); } if (sequenceIndex < sequenceTotal) { setTimeout(sendMessage, period); // Schedule the next send @@ -166,10 +182,7 @@ export async function app(telemetryClient: TelemetryClient) { } (async () => { - const telemetryClient = new TelemetryClient( - TELEMETRY_URL, - 5000 - ); + const telemetryClient = new TelemetryClient(TELEMETRY_URL, 5000); const { node, startLightPushSequence, startFilterSubscription } = await app( telemetryClient ); @@ -198,4 +211,4 @@ export async function app(telemetryClient: TelemetryClient) { document.addEventListener(sequenceCompletedEvent.type, () => startSequence()); startSequence(); -})(); \ No newline at end of file +})(); diff --git a/examples/dogfooding/src/telemetry_client.ts b/examples/dogfooding/src/telemetry_client.ts index bb8a4ea..588c926 100644 --- a/examples/dogfooding/src/telemetry_client.ts +++ b/examples/dogfooding/src/telemetry_client.ts @@ -1,5 +1,7 @@ export enum TelemetryType { LIGHT_PUSH_FILTER = "LightPushFilter", + LIGHT_PUSH_ERROR = "LightPushError", + GENERIC = "Generic" } // Top level structure of a telemetry request @@ -25,6 +27,23 @@ export interface TelemetryPushFilter extends TelemetryMessage { pubsubTopic: string; } +export interface TelemetryPushError extends TelemetryMessage { + peerId: string; + errorMessage: string; + peerIdRemote?: string; + contentTopic?: string; + pubsubTopic?: string; +} + +export interface TelemetryGeneric extends TelemetryMessage { + peerId: string; + metricType: string; + contentTopic?: string; + pubsubTopic?: string; + genericData?: string; + errorMessage?: string; +} + export class TelemetryClient { constructor(