const test = require('tape') const path = require('path') const os = require('os') const rimraf = require('rimraf') const SecretStack = require('secret-stack') const AAOL = require('async-append-only-log') const push = require('push-stream') const caps = require('ssb-caps') const p = require('util').promisify const { generateKeypair } = require('./util') const DIR = path.join(os.tmpdir(), 'ppppp-db-del') rimraf.sync(DIR) test('del', async (t) => { const keys = generateKeypair('alice') const peer = SecretStack({ appKey: caps.shs }) .use(require('../')) .call(null, { keys, path: DIR }) await peer.db.loaded() const msgHashes = [] for (let i = 0; i < 5; i++) { const rec = await p(peer.db.create)({ type: 'post', content: { text: 'm' + i }, }) msgHashes.push(rec.hash) } const before = [] for (const msg of peer.db.msgs()) { if (msg.content) before.push(msg.content.text) } t.deepEqual(before, ['m0', 'm1', 'm2', 'm3', 'm4'], 'msgs before the delete') await p(peer.db.del)(msgHashes[2]) const after = [] for (const msg of peer.db.msgs()) { if (msg.content) after.push(msg.content.text) } t.deepEqual(after, ['m0', 'm1', 'm3', 'm4'], 'msgs after the delete') await p(peer.close)(true) const log = AAOL(path.join(DIR, 'db.bin'), { cacheSize: 1, blockSize: 64 * 1024, codec: { encode(msg) { return Buffer.from(JSON.stringify(msg), 'utf8') }, decode(buf) { return JSON.parse(buf.toString('utf8')) }, }, }) const persistedMsgs = await new Promise((resolve, reject) => { let persistedMsgs = [] log.stream({ offsets: true, values: true, sizes: true }).pipe( push.drain( function drainEach({ offset, value, size }) { if (value) { persistedMsgs.push(value.msg) } }, function drainEnd(err) { if (err) return reject(err) resolve(persistedMsgs) } ) ) }) t.deepEqual( persistedMsgs.filter((msg) => msg.content).map((msg) => msg.content.text), ['m0', 'm1', 'm3', 'm4'], 'msgs in disk after the delete' ) })