From be66d556563f61d31246f0ae7ce75ec26fbf5499 Mon Sep 17 00:00:00 2001 From: Teo Gebhard Date: Thu, 24 Oct 2024 14:49:57 +0300 Subject: [PATCH] test: Wait for The Graph before starting the crawl (#23) The end-to-end.test.ts was flaky because it started crawling too early. Now we wait for The Graph to index the new streams before starting the crawl. --- test/end-to-end.test.ts | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/test/end-to-end.test.ts b/test/end-to-end.test.ts index 1b911ec..7a519aa 100644 --- a/test/end-to-end.test.ts +++ b/test/end-to-end.test.ts @@ -3,7 +3,7 @@ import 'reflect-metadata' import { DhtAddress, NodeType, createRandomDhtAddress, getDhtAddressFromRaw, getRawFromDhtAddress } from '@streamr/dht' import StreamrClient, { CONFIG_TEST, NetworkNodeType, PeerDescriptor, StreamID, StreamPermission, StreamrClientConfig } from '@streamr/sdk' import { NetworkNode, createNetworkNode } from '@streamr/trackerless-network' -import { StreamPartID, setAbortableInterval, toStreamPartID, waitForCondition } from '@streamr/utils' +import { StreamPartID, collect, setAbortableInterval, toStreamPartID, waitForCondition } from '@streamr/utils' import { sample, uniq, without } from 'lodash' import Container from 'typedi' import { CONFIG_TOKEN } from '../src/Config' @@ -65,11 +65,9 @@ const createClientConfig = (entryPointPeerDescriptor: PeerDescriptor): StreamrCl } } -const createClient = (privateKey: string, entryPointPeerDescriptor: PeerDescriptor) => { +const createClient = (privateKey: string | undefined, entryPointPeerDescriptor: PeerDescriptor) => { return new StreamrClient({ - auth: { - privateKey - }, + auth: (privateKey !== undefined) ? { privateKey } : undefined, ...createClientConfig(entryPointPeerDescriptor) }) } @@ -179,6 +177,16 @@ describe('end-to-end', () => { })) } + const waitForTheGraphToIndex = async (streamIds: StreamID[]): Promise => { + const client = createClient(undefined, entryPoint.getPeerDescriptor()) + for (const streamId of streamIds) { + await waitForCondition(async () => { + const streams = await collect(client.searchStreams(streamId, undefined)) + return streams.length > 0 + }, 5000, 500) + } + } + beforeAll(async () => { entryPoint = await startEntryPoint() const config = { @@ -223,6 +231,7 @@ describe('end-to-end', () => { await startPublisherAndSubscriberForStream(privateStream.id, publishingAbortControler.signal) const publicStream = await createTestStream(true) await startPublisherAndSubscriberForStream(publicStream.id, publishingAbortControler.signal) + await waitForTheGraphToIndex([privateStream.id, publicStream.id]) crawler = Container.get(Crawler) await crawler.start(1)