Skip to content

Commit

Permalink
Add support for removing doc handle from handleCache
Browse files Browse the repository at this point in the history
  • Loading branch information
George Su committed Aug 28, 2024
1 parent 7c486df commit 148b8a4
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 1 deletion.
30 changes: 29 additions & 1 deletion packages/automerge-repo/src/Repo.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,14 @@ import {
interpretAsDocumentId,
parseAutomergeUrl,
} from "./AutomergeUrl.js"
import { DocHandle, DocHandleEncodedChangePayload } from "./DocHandle.js"
import {
DELETED,
DocHandle,
DocHandleEncodedChangePayload,
READY,
UNAVAILABLE,
UNLOADED,
} from "./DocHandle.js"
import { RemoteHeadsSubscriptions } from "./RemoteHeadsSubscriptions.js"
import { headsAreSame } from "./helpers/headsAreSame.js"
import { throttle } from "./helpers/throttle.js"
Expand Down Expand Up @@ -539,6 +546,27 @@ export class Repo extends EventEmitter<RepoEvents> {
)
}

async removeFromCache(documentId: DocumentId) {
const handle = this.#getHandle({ documentId })
const doc = await handle.doc([READY, UNLOADED, DELETED, UNAVAILABLE])
if (doc) {
if (handle.isReady()) {
handle.unload()
} else {
this.#log(
`WARN: removeFromCache called but handle for documentId: ${documentId} in unexpected state: ${handle.state}`
)
}
delete this.#handleCache[documentId]
// TODO: remove document from synchronizer when removeDocument is implemented
// this.synchronizer.removeDocument(documentId)
} else {
this.#log(
`WARN: removeFromCache called but doc undefined for documentId: ${documentId}`
)
}
}

shutdown(): Promise<void> {
this.networkSubsystem.adapters.forEach(adapter => {
adapter.disconnect()
Expand Down
25 changes: 25 additions & 0 deletions packages/automerge-repo/test/Repo.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -486,6 +486,31 @@ describe("Repo", () => {
const doc = await handle.doc()
expect(doc).toEqual({})
})

describe("handle cache", () => {
it("contains doc handle", async () => {
const { repo } = setup()
const handle = repo.create({ foo: "bar" })
await handle.doc()
assert(repo.handles[handle.documentId])
})

it("delete removes doc handle", async () => {
const { repo } = setup()
const handle = repo.create({ foo: "bar" })
await handle.doc()
await repo.delete(handle.documentId)
assert(repo.handles[handle.documentId] === undefined)
})

it("removeFromCache removes doc handle", async () => {
const { repo } = setup()
const handle = repo.create({ foo: "bar" })
await handle.doc()
await repo.removeFromCache(handle.documentId)
assert(repo.handles[handle.documentId] === undefined)
})
})
})

describe("flush behaviour", () => {
Expand Down

0 comments on commit 148b8a4

Please sign in to comment.