mirror of
https://github.com/status-im/status-go.git
synced 2025-01-27 23:18:40 +00:00
061f10e58d
As part of a performance profiling of mailserver we noticed that most of the resources on a query are spend decoding the whisper envelope. This PR changes the way we store envelopes encoding the Topic into the database key, so we can check that and we are able to publish the envelope rawValue if it matches. The change is backward compatible as only newly added envelopes will have the new key, while old ones will have to be unmarshaled.
20 lines
935 B
Go
20 lines
935 B
Go
package mailserver
|
|
|
|
import (
|
|
"github.com/ethereum/go-ethereum/common"
|
|
whisper "github.com/status-im/whisper/whisperv6"
|
|
"github.com/stretchr/testify/require"
|
|
"testing"
|
|
)
|
|
|
|
func TestNewDBKey(t *testing.T) {
|
|
topic := whisper.BytesToTopic([]byte{0x01, 0x02, 0x03, 0x04})
|
|
|
|
hash := common.BytesToHash([]byte{0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28, 0x29, 0x30, 0x31, 0x32})
|
|
dbKey := NewDBKey(0xabcdef12, topic, hash)
|
|
expected := []byte{0xab, 0xcd, 0xef, 0x12, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28, 0x29, 0x30, 0x31, 0x32, 0x01, 0x02, 0x03, 0x04}
|
|
require.Equal(t, expected, dbKey.Bytes())
|
|
require.Equal(t, topic, dbKey.Topic())
|
|
require.Equal(t, hash, dbKey.EnvelopeHash())
|
|
}
|