mirror of
https://github.com/status-im/status-go.git
synced 2025-01-12 07:35:02 +00:00
cc8d57752f
* Refactor of waku.doc.go Moved out all code from docs.go, placed much of the seemingly misc code into much more closely related files, created a dedicated const file for housing all the package consts. * Moved doc_test to message_test * Refactored type collision and check on nil err * message_test.go fmt * Implemented whisper/doc.go refactor * import order change to attempt to please the linter. * Bug fix on whisper_test.go I also spotted a load of redundant type casting and fixed some of them
117 lines
3.4 KiB
Go
117 lines
3.4 KiB
Go
package whisper
|
|
|
|
import (
|
|
"encoding/binary"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
"github.com/syndtr/goleveldb/leveldb/errors"
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
|
)
|
|
|
|
func checkValidErrorPayload(t *testing.T, id []byte, errorMsg string) {
|
|
requestID := common.BytesToHash(id)
|
|
errPayload := CreateMailServerRequestFailedPayload(requestID, errors.New(errorMsg))
|
|
nid := enode.ID{1}
|
|
event, err := CreateMailServerEvent(nid, errPayload)
|
|
|
|
require.NoError(t, err)
|
|
require.NotNil(t, event)
|
|
require.Equal(t, nid, event.Peer)
|
|
require.Equal(t, requestID, event.Hash)
|
|
|
|
eventData, ok := event.Data.(*MailServerResponse)
|
|
if !ok {
|
|
require.FailNow(t, "Unexpected data in event: %v, expected a MailServerResponse", event.Data)
|
|
}
|
|
require.EqualError(t, eventData.Error, errorMsg)
|
|
}
|
|
|
|
func checkValidSuccessPayload(t *testing.T, id []byte, lastHash []byte, timestamp uint32, envHash []byte) {
|
|
requestID := common.BytesToHash(id)
|
|
lastEnvelopeHash := common.BytesToHash(lastHash)
|
|
timestampBytes := make([]byte, 4)
|
|
binary.LittleEndian.PutUint32(timestampBytes, timestamp)
|
|
envelopeHash := common.BytesToHash(envHash)
|
|
cursor := append(timestampBytes, envelopeHash[:]...)
|
|
successPayload := CreateMailServerRequestCompletedPayload(common.BytesToHash(id), lastEnvelopeHash, cursor)
|
|
nid := enode.ID{1}
|
|
event, err := CreateMailServerEvent(nid, successPayload)
|
|
|
|
require.NoError(t, err)
|
|
require.NotNil(t, event)
|
|
require.Equal(t, nid, event.Peer)
|
|
require.Equal(t, requestID, event.Hash)
|
|
|
|
eventData, ok := event.Data.(*MailServerResponse)
|
|
if !ok {
|
|
require.FailNow(t, "Unexpected data in event: %v, expected a MailServerResponse", event.Data)
|
|
}
|
|
require.Equal(t, lastEnvelopeHash, eventData.LastEnvelopeHash)
|
|
require.Equal(t, cursor, eventData.Cursor)
|
|
require.NoError(t, eventData.Error)
|
|
}
|
|
|
|
func TestCreateMailServerEvent(t *testing.T) {
|
|
// valid cases
|
|
longErrorMessage := "longMessage|"
|
|
for i := 0; i < 5; i++ {
|
|
longErrorMessage = longErrorMessage + longErrorMessage
|
|
}
|
|
checkValidErrorPayload(t, []byte{0x01}, "test error 1")
|
|
checkValidErrorPayload(t, []byte{0x02}, "test error 2")
|
|
checkValidErrorPayload(t, []byte{0x02}, "")
|
|
checkValidErrorPayload(t, []byte{0x00}, "test error 3")
|
|
checkValidErrorPayload(t, []byte{}, "test error 4")
|
|
|
|
checkValidSuccessPayload(t, []byte{0x01}, []byte{0x02}, 123, []byte{0x03})
|
|
// invalid payloads
|
|
|
|
// too small
|
|
_, err := CreateMailServerEvent(enode.ID{}, []byte{0x00})
|
|
require.Error(t, err)
|
|
|
|
// too big and not error payload
|
|
payloadTooBig := make([]byte, common.HashLength*2+cursorSize+100)
|
|
_, err = CreateMailServerEvent(enode.ID{}, payloadTooBig)
|
|
require.Error(t, err)
|
|
}
|
|
|
|
func TestSyncMailRequestValidate(t *testing.T) {
|
|
testCases := []struct {
|
|
Name string
|
|
Req SyncMailRequest
|
|
Error string
|
|
}{
|
|
{
|
|
Name: "invalid zero Limit",
|
|
Req: SyncMailRequest{},
|
|
Error: "invalid 'Limit' value, expected value greater than 0",
|
|
},
|
|
{
|
|
Name: "invalid large Limit",
|
|
Req: SyncMailRequest{Limit: 1e6},
|
|
Error: "invalid 'Limit' value, expected value lower than 1000",
|
|
},
|
|
{
|
|
Name: "invalid Lower",
|
|
Req: SyncMailRequest{Limit: 10, Lower: 10, Upper: 5},
|
|
Error: "invalid 'Lower' value, can't be greater than 'Upper'",
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(tc.Name, func(t *testing.T) {
|
|
err := tc.Req.Validate()
|
|
if tc.Error != "" {
|
|
assert.EqualError(t, err, tc.Error)
|
|
} else {
|
|
assert.NoError(t, err)
|
|
}
|
|
})
|
|
}
|
|
}
|