/* eslint-env jest */ require('websocket-polyfill') const { SimplePool, generatePrivateKey, getPublicKey, getEventHash, signEvent } = require('./lib/nostr.cjs') let pool = new SimplePool() let relays = [ 'wss://relay.damus.io/', 'wss://relay.nostr.bg/', 'wss://nostr.fmt.wiz.biz/', 'wss://relay.nostr.band/', 'wss://nos.lol/' ] afterAll(() => { pool.close([ ...relays, 'wss://nostr.wine', 'wss://offchain.pub', 'wss://eden.nostr.land' ]) }) test('removing duplicates when querying', async () => { let priv = generatePrivateKey() let pub = getPublicKey(priv) let sub = pool.sub(relays, [{authors: [pub]}]) let received = [] sub.on('event', event => { // this should be called only once even though we're listening // to multiple relays because the events will be catched and // deduplicated efficiently (without even being parsed) received.push(event) }) let event = { pubkey: pub, created_at: Math.round(Date.now() / 1000), content: 'test', kind: 22345, tags: [] } event.id = getEventHash(event) event.sig = signEvent(event, priv) pool.publish(relays, event) await new Promise(resolve => setTimeout(resolve, 1500)) expect(received).toHaveLength(1) }) test('same with double querying', async () => { let priv = generatePrivateKey() let pub = getPublicKey(priv) let sub1 = pool.sub(relays, [{authors: [pub]}]) let sub2 = pool.sub(relays, [{authors: [pub]}]) let received = [] sub1.on('event', event => { received.push(event) }) sub2.on('event', event => { received.push(event) }) let event = { pubkey: pub, created_at: Math.round(Date.now() / 1000), content: 'test2', kind: 22346, tags: [] } event.id = getEventHash(event) event.sig = signEvent(event, priv) pool.publish(relays, event) await new Promise(resolve => setTimeout(resolve, 1500)) expect(received).toHaveLength(2) }) test('get()', async () => { let event = await pool.get(relays, { ids: ['d7dd5eb3ab747e16f8d0212d53032ea2a7cadef53837e5a6c66d42849fcb9027'] }) expect(event).toHaveProperty( 'id', 'd7dd5eb3ab747e16f8d0212d53032ea2a7cadef53837e5a6c66d42849fcb9027' ) }) test('list()', async () => { let events = await pool.list( [...relays, 'wss://offchain.pub', 'wss://eden.nostr.land'], [ { authors: [ '3bf0c63fcb93463407af97a5e5ee64fa883d107ef9e558472c4eb9aaaefa459d' ], kinds: [1], limit: 2 } ] ) // the actual received number will be greater than 2, but there will be no duplicates expect(events.length).toEqual( events .map(evt => evt.id) .reduce((acc, n) => (acc.indexOf(n) !== -1 ? acc : [...acc, n]), []) .length ) let relaysForAllEvents = events .map(event => pool.seenOn(event.id)) .reduce((acc, n) => acc.concat(n), []) expect(relaysForAllEvents.length).toBeGreaterThanOrEqual(events.length) })