mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-10 23:06:34 +00:00
605cf1c38c
* feat(rln-relay): group manager api * fix(rln-relay): static gm, method async works now * fix(rln-relay): cb naming, ensure merkle root changed * chore(rln-relay): static group manager fully tested * chore(rln-relay): split ffi into its own module, split conversion_utils * chore(rln-relay): refactor onchain group * fix(rln-relay): throw error if privatekey is malformed * chore(rln-relay): convert methods to procs, remove warnings, formatting * chore(rln-relay): remove comment * style(rln-relay): fmt test * feat(rln-relay): complete onchain group manager. pending tests * fix(rln-relay): onchain implementation works now * fix(rln-relay): reg index * fix(rln): imports * fix(rln-relay): revert method to proc conv * fix(rln-relay): s/ffi/rln * fix(rln-relay): remove rln/ from gitignore * fix(rln-relay): s/ffi/rln
184 lines
5.8 KiB
Nim
184 lines
5.8 KiB
Nim
when (NimMajor, NimMinor) < (1, 4):
|
|
{.push raises: [Defect].}
|
|
else:
|
|
{.push raises: [].}
|
|
|
|
import
|
|
testutils/unittests,
|
|
stew/results,
|
|
options,
|
|
../../waku/v2/protocol/waku_rln_relay/protocol_types,
|
|
../../waku/v2/protocol/waku_rln_relay/rln,
|
|
../../waku/v2/protocol/waku_rln_relay/conversion_utils,
|
|
../../waku/v2/protocol/waku_rln_relay/group_manager/static/group_manager
|
|
|
|
import
|
|
stew/shims/net,
|
|
chronos,
|
|
libp2p/crypto/crypto,
|
|
eth/keys,
|
|
discovery/dnsdisc/builder
|
|
|
|
proc generateCredentials(rlnInstance: ptr RLN): IdentityCredential =
|
|
let credRes = membershipKeyGen(rlnInstance)
|
|
return credRes.get()
|
|
|
|
proc generateCredentials(rlnInstance: ptr RLN, n: int): seq[IdentityCredential] =
|
|
var credentials: seq[IdentityCredential]
|
|
for i in 0 ..< n:
|
|
credentials.add(generateCredentials(rlnInstance))
|
|
return credentials
|
|
|
|
suite "Static group manager":
|
|
setup:
|
|
let rlnInstanceRes = createRlnInstance()
|
|
require:
|
|
rlnInstanceRes.isOk()
|
|
|
|
let rlnInstance = rlnInstanceRes.get()
|
|
let credentials = generateCredentials(rlnInstance, 10)
|
|
|
|
let staticConfig = StaticGroupManagerConfig(groupSize: 10,
|
|
membershipIndex: 5,
|
|
groupKeys: credentials)
|
|
|
|
let manager {.used.} = StaticGroupManager(config: staticConfig,
|
|
rlnInstance: rlnInstance)
|
|
|
|
asyncTest "should initialize successfully":
|
|
let merkleRootBeforeRes = manager.rlnInstance.getMerkleRoot()
|
|
require:
|
|
merkleRootBeforeRes.isOk()
|
|
let merkleRootBefore = merkleRootBeforeRes.get()
|
|
|
|
await manager.init()
|
|
let merkleRootAfterRes = manager.rlnInstance.getMerkleRoot()
|
|
require:
|
|
merkleRootAfterRes.isOk()
|
|
let merkleRootAfter = merkleRootAfterRes.get()
|
|
check:
|
|
manager.idCredentials.isSome()
|
|
manager.config.groupKeys.len == 10
|
|
manager.config.groupSize == 10
|
|
manager.config.membershipIndex == 5
|
|
manager.config.groupKeys[5] == manager.idCredentials.get()
|
|
manager.latestIndex == 9
|
|
merkleRootAfter.inHex() != merkleRootBefore.inHex()
|
|
|
|
asyncTest "startGroupSync: should start group sync":
|
|
await manager.init()
|
|
await manager.startGroupSync()
|
|
|
|
asyncTest "startGroupSync: should guard against uninitialized state":
|
|
let staticConfig = StaticGroupManagerConfig(groupSize: 0,
|
|
membershipIndex: 0,
|
|
groupKeys: @[])
|
|
|
|
let manager = StaticGroupManager(config: staticConfig,
|
|
rlnInstance: rlnInstance)
|
|
|
|
expect(ValueError):
|
|
await manager.startGroupSync()
|
|
|
|
asyncTest "register: should guard against uninitialized state":
|
|
let staticConfig = StaticGroupManagerConfig(groupSize: 0,
|
|
membershipIndex: 0,
|
|
groupKeys: @[])
|
|
|
|
let manager = StaticGroupManager(config: staticConfig,
|
|
rlnInstance: rlnInstance)
|
|
|
|
let dummyCommitment = default(IDCommitment)
|
|
|
|
expect(ValueError):
|
|
await manager.register(dummyCommitment)
|
|
|
|
asyncTest "register: should register successfully":
|
|
await manager.init()
|
|
await manager.startGroupSync()
|
|
|
|
let idCommitment = generateCredentials(manager.rlnInstance).idCommitment
|
|
let merkleRootBeforeRes = manager.rlnInstance.getMerkleRoot()
|
|
require:
|
|
merkleRootBeforeRes.isOk()
|
|
let merkleRootBefore = merkleRootBeforeRes.get()
|
|
await manager.register(idCommitment)
|
|
let merkleRootAfterRes = manager.rlnInstance.getMerkleRoot()
|
|
require:
|
|
merkleRootAfterRes.isOk()
|
|
let merkleRootAfter = merkleRootAfterRes.get()
|
|
check:
|
|
merkleRootAfter.inHex() != merkleRootBefore.inHex()
|
|
manager.latestIndex == 10
|
|
|
|
asyncTest "register: callback is called":
|
|
var callbackCalled = false
|
|
let idCommitment = generateCredentials(manager.rlnInstance).idCommitment
|
|
|
|
let fut = newFuture[void]()
|
|
|
|
proc callback(registrations: seq[Membership]): Future[void] {.async.} =
|
|
require:
|
|
registrations.len == 1
|
|
registrations[0].idCommitment == idCommitment
|
|
registrations[0].index == 10
|
|
callbackCalled = true
|
|
fut.complete()
|
|
|
|
manager.onRegister(callback)
|
|
await manager.init()
|
|
await manager.startGroupSync()
|
|
|
|
await manager.register(idCommitment)
|
|
|
|
await fut
|
|
check:
|
|
callbackCalled
|
|
|
|
asyncTest "withdraw: should guard against uninitialized state":
|
|
let idSecretHash = credentials[0].idSecretHash
|
|
|
|
expect(ValueError):
|
|
await manager.withdraw(idSecretHash)
|
|
|
|
asyncTest "withdraw: should withdraw successfully":
|
|
await manager.init()
|
|
await manager.startGroupSync()
|
|
|
|
let idSecretHash = credentials[0].idSecretHash
|
|
let merkleRootBeforeRes = manager.rlnInstance.getMerkleRoot()
|
|
require:
|
|
merkleRootBeforeRes.isOk()
|
|
let merkleRootBefore = merkleRootBeforeRes.get()
|
|
await manager.withdraw(idSecretHash)
|
|
let merkleRootAfterRes = manager.rlnInstance.getMerkleRoot()
|
|
require:
|
|
merkleRootAfterRes.isOk()
|
|
let merkleRootAfter = merkleRootAfterRes.get()
|
|
check:
|
|
merkleRootAfter.inHex() != merkleRootBefore.inHex()
|
|
|
|
asyncTest "withdraw: callback is called":
|
|
var callbackCalled = false
|
|
let idSecretHash = credentials[0].idSecretHash
|
|
let idCommitment = credentials[0].idCommitment
|
|
let fut = newFuture[void]()
|
|
|
|
proc callback(withdrawals: seq[Membership]): Future[void] {.async.} =
|
|
require:
|
|
withdrawals.len == 1
|
|
withdrawals[0].idCommitment == idCommitment
|
|
withdrawals[0].index == 0
|
|
callbackCalled = true
|
|
fut.complete()
|
|
|
|
manager.onWithdraw(callback)
|
|
await manager.init()
|
|
await manager.startGroupSync()
|
|
|
|
await manager.withdraw(idSecretHash)
|
|
|
|
await fut
|
|
check:
|
|
callbackCalled
|