Compare commits

...

1 Commits

Author SHA1 Message Date
96130ddc8d TestService: wait for OnConnect and OnDisconnect 2023-12-01 13:56:15 -06:00

View File

@ -72,15 +72,25 @@ func TestService(t *testing.T) {
return nil return nil
}) })
// wait for all dummy peers to connect and disconnect
wg.Add(maxDummyPeers)
srvc.OnConnect = func(peer *protocol.CNPeer) {
wg.Done()
}
wg.Add(maxDummyPeers)
srvc.OnDisconnect = func(peer *protocol.CNPeer) {
wg.Done()
}
// run service // run service
go func() { go func() {
err := srvc.Start() is.NoErr(srvc.Start()) // srvc.Start error
is.NoErr(err) // srvc.Start error
}() }()
is.True(selectWithTimeout(srvc.Started(), timeout)) // wait for service to start with timeout is.True(selectWithTimeout(srvc.Started(), timeout)) // wait for service to start with timeout
wg.Add(maxDummyPeers * 3) // 2 wg.Done() calls per dummy peer wg.Add(maxDummyPeers * 3) // 3 wg.Done() calls per dummy peer. 2 per peer for receiving packets, 1 for Handler() exit
for i := 0; i < maxDummyPeers; i++ { for i := 0; i < maxDummyPeers; i++ {
go func() { go func() {
// make dummy client // make dummy client
@ -93,8 +103,7 @@ func TestService(t *testing.T) {
// send dummy packets // send dummy packets
for i := 0; i < 2; i++ { for i := 0; i < 2; i++ {
err := peer.Send(0x1234) is.NoErr(peer.Send(0x1234)) // peer.Send error
is.NoErr(err) // peer.Send error
} }
}() }()