mirror of
https://github.com/status-im/status-go.git
synced 2025-01-09 22:26:30 +00:00
809db97e54
* mailserver sends envelopes in descending order * add limit value in mailserver request payload * mailserver sends messages up to the limit specified in the request * update Archive method to return key and error * processRequest returns the next page cursor * add cursor to mailserver request * add limit and cursor to request payload * fix request limit encoding * wait for request completed event in TrackerSuite/TestRequestCompleted * add cursor to mailserver response * fix cursor position in payload * add e2e test for mail server pagination * validate mail server response size * remove old limitReached var * fix lint warnings * add whisper patch * fix tests after rebase * check all return values to avoid lint warnings * check that all messages have been retrieved after 2 paginated requests * fix lint warnings * rename geth patch * merge mailserver patches into one * add last envelope hash to mailserver response and EventEnvelopeAvailable event * update whisper patch * add docs to MailServerResponse * update whisper patch * fix tests and lint warnings * send mailserver response data on EventMailServerRequestCompleted signal * update tracker tests * optimise pagination test waiting for mailserver to archive only before requesting * rollback mailserver interface changes * refactoring and docs changes * fix payload size check to determine if a limit is specified * add more docs to the processRequest method * add constants for request payload field lengths * add const noLimits to specify that limit=0 means no limits
67 lines
1.7 KiB
Go
67 lines
1.7 KiB
Go
package mailserver
|
|
|
|
import (
|
|
"testing"
|
|
|
|
whisper "github.com/ethereum/go-ethereum/whisper/whisperv6"
|
|
"github.com/stretchr/testify/suite"
|
|
"github.com/syndtr/goleveldb/leveldb"
|
|
"github.com/syndtr/goleveldb/leveldb/iterator"
|
|
"github.com/syndtr/goleveldb/leveldb/opt"
|
|
"github.com/syndtr/goleveldb/leveldb/util"
|
|
)
|
|
|
|
type panicDB struct{}
|
|
|
|
func (db *panicDB) Close() error {
|
|
panic("panicDB panic on Close")
|
|
}
|
|
|
|
func (db *panicDB) Write(b *leveldb.Batch, opts *opt.WriteOptions) error {
|
|
panic("panicDB panic on Write")
|
|
}
|
|
|
|
func (db *panicDB) Put(k []byte, v []byte, opts *opt.WriteOptions) error {
|
|
panic("panicDB panic on Put")
|
|
}
|
|
|
|
func (db *panicDB) Get(k []byte, opts *opt.ReadOptions) ([]byte, error) {
|
|
panic("panicDB panic on Get")
|
|
}
|
|
|
|
func (db *panicDB) NewIterator(r *util.Range, opts *opt.ReadOptions) iterator.Iterator {
|
|
panic("panicDB panic on NewIterator")
|
|
}
|
|
|
|
func TestMailServerDBPanicSuite(t *testing.T) {
|
|
suite.Run(t, new(MailServerDBPanicSuite))
|
|
}
|
|
|
|
type MailServerDBPanicSuite struct {
|
|
suite.Suite
|
|
server *WMailServer
|
|
}
|
|
|
|
func (s *MailServerDBPanicSuite) SetupTest() {
|
|
s.server = &WMailServer{}
|
|
s.server.db = &panicDB{}
|
|
}
|
|
|
|
func (s *MailServerDBPanicSuite) TestArchive() {
|
|
defer s.testPanicRecover("Archive")
|
|
s.server.Archive(&whisper.Envelope{})
|
|
}
|
|
|
|
func (s *MailServerDBPanicSuite) TestDeliverMail() {
|
|
defer s.testPanicRecover("DeliverMail")
|
|
_, _, _, err := s.server.processRequest(nil, 10, 20, []byte{}, 0, nil)
|
|
s.Error(err)
|
|
s.Equal("recovered from panic in processRequest: panicDB panic on NewIterator", err.Error())
|
|
}
|
|
|
|
func (s *MailServerDBPanicSuite) testPanicRecover(method string) {
|
|
if r := recover(); r != nil {
|
|
s.Failf("error recovering panic", "expected recover to return nil, got: %+v", r)
|
|
}
|
|
}
|