2019-02-20 06:57:57 +00:00
|
|
|
package shhext
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2019-11-23 17:57:05 +00:00
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
2019-02-20 06:57:57 +00:00
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2019-11-23 17:57:05 +00:00
|
|
|
testHash = types.Hash{0x01}
|
2019-02-20 06:57:57 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestMailRequestMonitorSuite(t *testing.T) {
|
|
|
|
suite.Run(t, new(MailRequestMonitorSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type MailRequestMonitorSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
|
|
|
|
monitor *MailRequestMonitor
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MailRequestMonitorSuite) SetupTest() {
|
|
|
|
s.monitor = &MailRequestMonitor{
|
2019-11-23 17:57:05 +00:00
|
|
|
cache: map[types.Hash]EnvelopeState{},
|
2019-02-20 06:57:57 +00:00
|
|
|
requestsRegistry: NewRequestsRegistry(0),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MailRequestMonitorSuite) TestRequestCompleted() {
|
|
|
|
mock := newHandlerMock(1)
|
|
|
|
s.monitor.handler = mock
|
|
|
|
s.monitor.cache[testHash] = MailServerRequestSent
|
2019-11-23 17:57:05 +00:00
|
|
|
s.monitor.handleEvent(types.EnvelopeEvent{
|
|
|
|
Event: types.EventMailServerRequestCompleted,
|
2019-02-20 06:57:57 +00:00
|
|
|
Hash: testHash,
|
2019-11-23 17:57:05 +00:00
|
|
|
Data: &types.MailServerResponse{},
|
2019-02-20 06:57:57 +00:00
|
|
|
})
|
|
|
|
select {
|
|
|
|
case requestID := <-mock.requestsCompleted:
|
|
|
|
s.Equal(testHash, requestID)
|
|
|
|
s.NotContains(s.monitor.cache, testHash)
|
|
|
|
case <-time.After(10 * time.Second):
|
|
|
|
s.Fail("timed out while waiting for a request to be completed")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MailRequestMonitorSuite) TestRequestFailed() {
|
|
|
|
mock := newHandlerMock(1)
|
|
|
|
s.monitor.handler = mock
|
|
|
|
s.monitor.cache[testHash] = MailServerRequestSent
|
2019-11-23 17:57:05 +00:00
|
|
|
s.monitor.handleEvent(types.EnvelopeEvent{
|
|
|
|
Event: types.EventMailServerRequestCompleted,
|
2019-02-20 06:57:57 +00:00
|
|
|
Hash: testHash,
|
2019-11-23 17:57:05 +00:00
|
|
|
Data: &types.MailServerResponse{Error: errors.New("test error")},
|
2019-02-20 06:57:57 +00:00
|
|
|
})
|
|
|
|
select {
|
|
|
|
case requestID := <-mock.requestsFailed:
|
|
|
|
s.Equal(testHash, requestID)
|
|
|
|
s.NotContains(s.monitor.cache, testHash)
|
|
|
|
case <-time.After(10 * time.Second):
|
|
|
|
s.Fail("timed out while waiting for a request to be failed")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MailRequestMonitorSuite) TestRequestExpiration() {
|
|
|
|
mock := newHandlerMock(1)
|
|
|
|
s.monitor.handler = mock
|
|
|
|
s.monitor.cache[testHash] = MailServerRequestSent
|
2019-11-23 17:57:05 +00:00
|
|
|
s.monitor.handleEvent(types.EnvelopeEvent{
|
|
|
|
Event: types.EventMailServerRequestExpired,
|
2019-02-20 06:57:57 +00:00
|
|
|
Hash: testHash,
|
|
|
|
})
|
|
|
|
select {
|
|
|
|
case requestID := <-mock.requestsExpired:
|
|
|
|
s.Equal(testHash, requestID)
|
|
|
|
s.NotContains(s.monitor.cache, testHash)
|
|
|
|
case <-time.After(10 * time.Second):
|
|
|
|
s.Fail("timed out while waiting for request expiration")
|
|
|
|
}
|
|
|
|
}
|