This commit is contained in:
@@ -0,0 +1,41 @@
|
||||
import {describe, it, expect} from "vitest"
|
||||
import {makeSecret, RELAY_ADD_MEMBER, RELAY_REMOVE_MEMBER} from "@welshman/util"
|
||||
import type {TrustedEvent} from "@welshman/util"
|
||||
import {Nip01Signer} from "@welshman/signer"
|
||||
import {RelayRemoveMember, RelayRemoveMemberBuilder} from "../src/kinds/RelayRemoveMember"
|
||||
|
||||
const signer = new Nip01Signer(makeSecret())
|
||||
const pubkey = "ee".repeat(32)
|
||||
const a = "aa".repeat(32)
|
||||
|
||||
const makeEvent = (overrides: Partial<TrustedEvent> = {}): TrustedEvent =>
|
||||
({
|
||||
id: "ff".repeat(32),
|
||||
pubkey,
|
||||
created_at: 0,
|
||||
kind: RELAY_REMOVE_MEMBER,
|
||||
tags: [],
|
||||
content: "",
|
||||
sig: "00".repeat(64),
|
||||
...overrides,
|
||||
}) as TrustedEvent
|
||||
|
||||
describe("RelayRemoveMember", () => {
|
||||
it("reads affected pubkeys with the remove kind", async () => {
|
||||
const op = await RelayRemoveMember.fromEvent(makeEvent({tags: [["p", a]]}))
|
||||
|
||||
expect(op.kind).toBe(RELAY_REMOVE_MEMBER)
|
||||
expect(op.pubkeys()).toEqual([a])
|
||||
})
|
||||
|
||||
it("builds fresh with the remove kind", async () => {
|
||||
const tmpl = await new RelayRemoveMemberBuilder().addPubkey(a).toTemplate(signer)
|
||||
|
||||
expect(tmpl.kind).toBe(RELAY_REMOVE_MEMBER)
|
||||
expect(tmpl.tags).toContainEqual(["p", a])
|
||||
})
|
||||
|
||||
it("throws when the add kind is read as a remove", async () => {
|
||||
await expect(RelayRemoveMember.fromEvent(makeEvent({kind: RELAY_ADD_MEMBER}))).rejects.toThrow()
|
||||
})
|
||||
})
|
||||
Reference in New Issue
Block a user