mirror of
https://github.com/status-im/status-go.git
synced 2025-01-18 18:55:47 +00:00
53423e58ba
- use `appdatabse.DbInitializer{}` in tests to ensure consistent migrations - remove protocol's open database functions due to improper initialization caused by missing node config migration - introduce `PushNotificationServerConfig` to resolve cyclic dependency issues
97 lines
2.7 KiB
Go
97 lines
2.7 KiB
Go
package pushnotificationserver
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/golang/protobuf/proto"
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"github.com/status-im/status-go/appdatabase"
|
|
"github.com/status-im/status-go/eth-node/crypto"
|
|
"github.com/status-im/status-go/protocol/common"
|
|
"github.com/status-im/status-go/protocol/protobuf"
|
|
"github.com/status-im/status-go/protocol/sqlite"
|
|
"github.com/status-im/status-go/t/helpers"
|
|
)
|
|
|
|
func TestSQLitePersistenceSuite(t *testing.T) {
|
|
suite.Run(t, new(SQLitePersistenceSuite))
|
|
}
|
|
|
|
type SQLitePersistenceSuite struct {
|
|
suite.Suite
|
|
persistence Persistence
|
|
}
|
|
|
|
func (s *SQLitePersistenceSuite) SetupTest() {
|
|
db, err := helpers.SetupTestMemorySQLDB(appdatabase.DbInitializer{})
|
|
s.Require().NoError(err)
|
|
err = sqlite.Migrate(db)
|
|
s.Require().NoError(err)
|
|
|
|
s.persistence = NewSQLitePersistence(db)
|
|
}
|
|
|
|
func (s *SQLitePersistenceSuite) TestSaveAndRetrieve() {
|
|
key, err := crypto.GenerateKey()
|
|
s.Require().NoError(err)
|
|
installationID := "54242d02-bb92-11ea-b3de-0242ac130004"
|
|
|
|
registration := &protobuf.PushNotificationRegistration{
|
|
InstallationId: installationID,
|
|
Version: 5,
|
|
}
|
|
|
|
s.Require().NoError(s.persistence.SavePushNotificationRegistration(common.HashPublicKey(&key.PublicKey), registration))
|
|
|
|
retrievedRegistration, err := s.persistence.GetPushNotificationRegistrationByPublicKeyAndInstallationID(common.HashPublicKey(&key.PublicKey), installationID)
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().True(proto.Equal(registration, retrievedRegistration))
|
|
}
|
|
|
|
func (s *SQLitePersistenceSuite) TestSaveAndRetrieveIdentity() {
|
|
retrievedKey, err := s.persistence.GetIdentity()
|
|
s.Require().NoError(err)
|
|
s.Require().Nil(retrievedKey)
|
|
|
|
key, err := crypto.GenerateKey()
|
|
s.Require().NoError(err)
|
|
s.Require().NoError(s.persistence.SaveIdentity(key))
|
|
|
|
retrievedKey, err = s.persistence.GetIdentity()
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(key, retrievedKey)
|
|
}
|
|
|
|
func (s *SQLitePersistenceSuite) TestSaveDifferentIdenities() {
|
|
key1, err := crypto.GenerateKey()
|
|
s.Require().NoError(err)
|
|
key2, err := crypto.GenerateKey()
|
|
s.Require().NoError(err)
|
|
|
|
// First one should be successul, second should fail
|
|
s.Require().NoError(s.persistence.SaveIdentity(key1))
|
|
s.Require().Error(s.persistence.SaveIdentity(key2))
|
|
}
|
|
|
|
func (s *SQLitePersistenceSuite) TestExists() {
|
|
messageID1 := []byte("1")
|
|
messageID2 := []byte("2")
|
|
|
|
result, err := s.persistence.PushNotificationExists(messageID1)
|
|
s.Require().NoError(err)
|
|
s.Require().False(result)
|
|
|
|
result, err = s.persistence.PushNotificationExists(messageID1)
|
|
s.Require().NoError(err)
|
|
|
|
s.Require()
|
|
s.Require().True(result)
|
|
|
|
result, err = s.persistence.PushNotificationExists(messageID2)
|
|
s.Require().NoError(err)
|
|
s.Require().False(result)
|
|
}
|