Get realtime partial to work with initial post

This commit is contained in:
Jacob Karlsson 2024-06-28 17:28:49 +02:00
parent 043faed836
commit 451975eca4
3 changed files with 26 additions and 17 deletions

View File

@ -2,6 +2,7 @@ const makeDebug = require('debug')
const MsgV4 = require('pzp-db/msg-v4') const MsgV4 = require('pzp-db/msg-v4')
/** /**
* @typedef {import('pzp-db').RecPresent} Rec
* @typedef {ReturnType<import('pzp-db').init>} PZPDB * @typedef {ReturnType<import('pzp-db').init>} PZPDB
* @typedef {ReturnType<import('pzp-goals').init>} PZPGoal * @typedef {ReturnType<import('pzp-goals').init>} PZPGoal
* @typedef {import('pzp-goals').GoalDSL} GoalDSL * @typedef {import('pzp-goals').GoalDSL} GoalDSL
@ -276,6 +277,10 @@ function initConductor(peer, config) {
peer.gc.start(maxBytes) peer.gc.start(maxBytes)
peer.sync.start() peer.sync.start()
peer.db.onRecordAdded((/** @type {Rec} */ { id: msgID, msg }) => {
peer.sync.start()
})
cb() cb()
}) })
} }

View File

@ -31,17 +31,17 @@
"bs58": "^5.0.0", "bs58": "^5.0.0",
"c8": "7", "c8": "7",
"pzp-caps": "^1.0.0", "pzp-caps": "^1.0.0",
"pzp-db": "^1.0.1", "pzp-db": "^1.0.4",
"pzp-dict": "^1.0.0", "pzp-dict": "^1.0.1",
"pzp-gc": "^1.0.0", "pzp-gc": "^1.0.0",
"pzp-goals": "^1.0.0", "pzp-goals": "^1.0.1",
"pzp-keypair": "^1.0.0", "pzp-keypair": "^1.0.0",
"pzp-set": "^1.0.0", "pzp-set": "^1.0.1",
"pzp-sync": "^1.0.0", "pzp-sync": "^1.0.4",
"prettier": "^2.6.2", "prettier": "^2.6.2",
"pretty-quick": "^3.1.3", "pretty-quick": "^3.1.3",
"rimraf": "^4.4.0", "rimraf": "^4.4.0",
"secret-handshake-ext": "~0.0.11", "secret-handshake-ext": "~0.0.12",
"secret-stack": "~8.1.0", "secret-stack": "~8.1.0",
"ssb-box": "^1.0.1", "ssb-box": "^1.0.1",
"typescript": "^5.4.5" "typescript": "^5.4.5"

View File

@ -39,6 +39,13 @@ test('create 200 messages that manage to replicate with low "newest" goals', asy
assert.deepEqual(arr, [], 'alice has no posts from bob') assert.deepEqual(arr, [], 'alice has no posts from bob')
} }
// TODO: make things work with this first, then add another test without this?
await p(bob.db.feed.publish)({
account: bobID,
domain: 'post',
data: { text: `${n}` },
})
const confirmed = [] const confirmed = []
// for keeping track of which msgs have arrived // for keeping track of which msgs have arrived
for (let i = 0; i < n; i++) { for (let i = 0; i < n; i++) {
@ -47,6 +54,7 @@ test('create 200 messages that manage to replicate with low "newest" goals', asy
alice.db.onRecordAdded(rec => { alice.db.onRecordAdded(rec => {
if (rec.msg.data?.text) { if (rec.msg.data?.text) {
//console.log('alice received rec', rec)
const num = Number.parseInt(rec.msg.data.text) const num = Number.parseInt(rec.msg.data.text)
confirmed[num] = true confirmed[num] = true
} }
@ -55,20 +63,17 @@ test('create 200 messages that manage to replicate with low "newest" goals', asy
await p(alice.set.load)(aliceID) await p(alice.set.load)(aliceID)
await p(bob.set.load)(bobID) await p(bob.set.load)(bobID)
// TODO: do we need to follow each other? // TODO: do we need to follow? probably
assert(await p(alice.set.add)('follows', bobID), 'alice follows bob') assert(await p(alice.set.add)('follows', bobID), 'alice follows bob')
// TODO: remove this one
assert(await p(bob.set.add)('follows', aliceID), 'alice follows bob')
//bob.goals.set(bobPostsID, 'newest-50') await p(alice.conductor.start)(aliceID, [['post@newest-50'], ['post@newest-50']], 64_000_000)
//alice.goals.set(bobPostsID, 'newest-50') await p(bob.conductor.start)(bobID, [['post@newest-50'], ['post@newest-50']], 64_000_000)
// TODO: lower to newest-50, alice then bob
// supposedly [myrules, theirrules], do they need to match?
await p(alice.conductor.start)(aliceID, [['post@all'], ['post@all']], 64_000_000)
await p(bob.conductor.start)(bobID, [['post@all'], ['post@all']], 64_000_000)
const remoteAlice = await p(bob.connect)(alice.getAddress()) const remoteAlice = await p(bob.connect)(alice.getAddress())
assert('alice and bob connected') assert('alice and bob connected')
bob.sync.start()
await p(setTimeout)(1000) await p(setTimeout)(1000)
assert('sync!') assert('sync!')
@ -83,14 +88,13 @@ test('create 200 messages that manage to replicate with low "newest" goals', asy
}))) })))
assert(`bob published ${n} posts in parallel`) assert(`bob published ${n} posts in parallel`)
//let tries = 30 let tries = 30
let tries = 100
// just waiting for them to arrive // just waiting for them to arrive
do { do {
await p(setTimeout)(100) await p(setTimeout)(100)
} while (!confirmed.every(v => v === true) && tries-- > 0) } while (!confirmed.every(v => v === true) && tries-- > 0)
assert.equal(confirmed.filter(v => v === true).length, n, `alice has all of bob's posts`) assert.equal(confirmed.filter(v => v === true).length, n + 1, `alice has all of bob's posts including the initial one`)
await p(remoteAlice.close)(true) await p(remoteAlice.close)(true)
await p(alice.close)(true) await p(alice.close)(true)