2023-02-21 13:35:26 +01:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"crypto/ecdsa"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
|
|
|
gethbridge "github.com/status-im/status-go/eth-node/bridge/geth"
|
|
|
|
"github.com/status-im/status-go/eth-node/crypto"
|
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
2023-05-16 12:50:04 +02:00
|
|
|
"github.com/status-im/status-go/multiaccounts/accounts"
|
2023-02-21 13:35:26 +01:00
|
|
|
"github.com/status-im/status-go/protocol/encryption/multidevice"
|
|
|
|
"github.com/status-im/status-go/protocol/tt"
|
|
|
|
"github.com/status-im/status-go/waku"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestMessengerSyncKeycardChangeSuite(t *testing.T) {
|
|
|
|
suite.Run(t, new(MessengerSyncKeycardChangeSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type MessengerSyncKeycardChangeSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
main *Messenger // main instance of Messenger paired with `other`
|
|
|
|
other *Messenger
|
|
|
|
privateKey *ecdsa.PrivateKey // private key for the main instance of Messenger
|
|
|
|
|
|
|
|
// If one wants to send messages between different instances of Messenger,
|
|
|
|
// a single Waku service should be shared.
|
|
|
|
shh types.Waku
|
|
|
|
|
|
|
|
logger *zap.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) SetupTest() {
|
|
|
|
s.logger = tt.MustCreateTestLogger()
|
|
|
|
|
|
|
|
config := waku.DefaultConfig
|
|
|
|
config.MinimumAcceptedPoW = 0
|
|
|
|
shh := waku.New(&config, s.logger)
|
|
|
|
s.shh = gethbridge.NewGethWakuWrapper(shh)
|
|
|
|
s.Require().NoError(shh.Start())
|
|
|
|
|
|
|
|
s.main = s.newMessenger(s.shh)
|
|
|
|
s.privateKey = s.main.identity
|
|
|
|
// Start the main messenger in order to receive installations
|
|
|
|
_, err := s.main.Start()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Create new device and add main account to
|
|
|
|
s.other, err = newMessengerWithKey(s.shh, s.main.identity, s.logger, nil)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Pair devices (main and other)
|
|
|
|
imOther := &multidevice.InstallationMetadata{
|
|
|
|
Name: "other-device",
|
|
|
|
DeviceType: "other-device-type",
|
|
|
|
}
|
|
|
|
err = s.other.SetInstallationMetadata(s.other.installationID, imOther)
|
|
|
|
s.Require().NoError(err)
|
2023-02-28 20:32:45 +08:00
|
|
|
response, err := s.other.SendPairInstallation(context.Background(), nil)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().NotNil(response)
|
|
|
|
|
|
|
|
// Wait for the message to reach its destination
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.main,
|
|
|
|
func(r *MessengerResponse) bool { return len(r.Installations) > 0 },
|
|
|
|
"installation not received",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
err = s.main.EnableInstallation(s.other.installationID)
|
|
|
|
s.Require().NoError(err)
|
2023-05-16 12:50:04 +02:00
|
|
|
|
|
|
|
// Pre-condition - both sides have to know about keypairs migrated to a keycards
|
2023-05-24 16:40:40 +02:00
|
|
|
kp1 := accounts.GetProfileKeypairForTest(true, true, true)
|
2023-05-16 12:50:04 +02:00
|
|
|
kp2 := accounts.GetSeedImportedKeypair1ForTest()
|
|
|
|
// kp3 := accounts.GetSeedImportedKeypair2ForTest()
|
|
|
|
|
|
|
|
err = s.main.settings.SaveOrUpdateKeypair(kp1)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
err = s.main.settings.SaveOrUpdateKeypair(kp2)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
// err = s.main.settings.SaveOrUpdateKeypair(kp3)
|
|
|
|
// s.Require().NoError(err)
|
|
|
|
dbKeypairs, err := s.main.settings.GetKeypairs()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(2, len(dbKeypairs))
|
|
|
|
|
|
|
|
err = s.other.SaveOrUpdateKeypair(kp1)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
err = s.other.SaveOrUpdateKeypair(kp2)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
// err = s.other.SaveOrUpdateKeypair(kp3)
|
|
|
|
// s.Require().NoError(err)
|
|
|
|
dbKeypairs, err = s.other.settings.GetKeypairs()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(2, len(dbKeypairs))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TearDownTest() {
|
|
|
|
s.Require().NoError(s.other.Shutdown())
|
|
|
|
s.Require().NoError(s.main.Shutdown())
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) newMessenger(shh types.Waku) *Messenger {
|
|
|
|
privateKey, err := crypto.GenerateKey()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
messenger, err := newMessengerWithKey(s.shh, privateKey, s.logger, nil)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
return messenger
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestAddingNewKeycards() {
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
|
|
|
// Add key cards on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
|
|
|
keycard2 := accounts.GetKeycardForSeedImportedKeypair1ForTest()
|
|
|
|
|
|
|
|
added, err := s.main.AddKeycardOrAddAccountsIfKeycardIsAdded(context.Background(), keycard1)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, added)
|
|
|
|
|
|
|
|
added, err = s.main.AddKeycardOrAddAccountsIfKeycardIsAdded(context.Background(), keycard2)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, added)
|
2023-02-21 13:35:26 +01:00
|
|
|
|
|
|
|
// Wait for the response
|
2023-05-16 12:50:04 +02:00
|
|
|
_, err = WaitOnMessengerResponse(
|
2023-02-21 13:35:26 +01:00
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
2023-05-16 12:50:04 +02:00
|
|
|
return len(r.KeycardActions()) == 2
|
2023-02-21 13:35:26 +01:00
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := s.main.settings.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(2, len(senderKeycards))
|
|
|
|
s.Require().True(contains(senderKeycards, keycard1, accounts.SameKeycards))
|
|
|
|
s.Require().True(contains(senderKeycards, keycard2, accounts.SameKeycards))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().Equal(2, len(syncedKeycards))
|
|
|
|
s.Require().True(contains(syncedKeycards, keycard1, accounts.SameKeycards))
|
|
|
|
s.Require().True(contains(syncedKeycards, keycard2, accounts.SameKeycards))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestAddingAccountsToKeycard() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
|
|
|
keycard2 := accounts.GetKeycardForSeedImportedKeypair1ForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add additional accounts to sender
|
2023-05-16 12:50:04 +02:00
|
|
|
added, err := s.main.AddKeycardOrAddAccountsIfKeycardIsAdded(context.Background(), keycard2)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, added)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(2, len(senderKeycards))
|
|
|
|
s.Require().True(contains(senderKeycards, keycard1, accounts.SameKeycards))
|
|
|
|
s.Require().True(contains(senderKeycards, keycard2, accounts.SameKeycards))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().Equal(2, len(syncedKeycards))
|
|
|
|
s.Require().True(contains(syncedKeycards, keycard1, accounts.SameKeycards))
|
|
|
|
s.Require().True(contains(syncedKeycards, keycard2, accounts.SameKeycards))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestRemovingAccountsFromKeycard() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.AccountsAddresses = updatedKeycard1.AccountsAddresses[2:]
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Remove accounts from sender
|
|
|
|
err = s.main.RemoveMigratedAccountsForKeycard(context.Background(), keycard1.KeycardUID,
|
|
|
|
keycard1.AccountsAddresses[:2], updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(contains(senderKeycards, updatedKeycard1, accounts.SameKeycards))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(contains(syncedKeycards, updatedKeycard1, accounts.SameKeycards))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestRemovingAllAccountsFromKeycard() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Remove all accounts from sender
|
2023-05-16 12:50:04 +02:00
|
|
|
err = s.main.RemoveMigratedAccountsForKeycard(context.Background(), keycard1.KeycardUID,
|
|
|
|
keycard1.AccountsAddresses, keycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(0, len(senderKeycards))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(0, len(syncedKeycards))
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestDeleteKeycard() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Remove keycard from sender
|
2023-05-16 12:50:04 +02:00
|
|
|
err = s.main.DeleteKeycard(context.Background(), keycard1.KeycardUID, keycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(0, len(senderKeycards))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(0, len(syncedKeycards))
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestSettingKeycardName() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.KeycardName = "New Keycard Name"
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Set new keycard name to sender
|
|
|
|
err = s.main.SetKeycardName(context.Background(), updatedKeycard1.KeycardUID, updatedKeycard1.KeycardName,
|
|
|
|
updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(accounts.SameKeycards(updatedKeycard1, senderKeycards[0]))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(accounts.SameKeycards(updatedKeycard1, syncedKeycards[0]))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestSettingKeycardNameWithOlderClock() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.KeycardName = "New Keycard Name"
|
|
|
|
updatedKeycard1.LastUpdateClock = updatedKeycard1.LastUpdateClock - 1
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Set new keycard name to sender
|
|
|
|
err = s.main.SetKeycardName(context.Background(), updatedKeycard1.KeycardUID, updatedKeycard1.KeycardName,
|
|
|
|
updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(accounts.SameKeycards(keycard1, senderKeycards[0]))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(accounts.SameKeycards(keycard1, syncedKeycards[0]))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestSettingKeycardLocked() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.KeycardLocked = true
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
err = s.main.KeycardLocked(context.Background(), updatedKeycard1.KeycardUID, updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(accounts.SameKeycards(updatedKeycard1, senderKeycards[0]))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(accounts.SameKeycards(updatedKeycard1, syncedKeycards[0]))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestSettingKeycardLockedOlderClock() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.KeycardLocked = true
|
|
|
|
updatedKeycard1.LastUpdateClock = updatedKeycard1.LastUpdateClock - 1
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
err = s.main.KeycardLocked(context.Background(), updatedKeycard1.KeycardUID, updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(accounts.SameKeycards(keycard1, senderKeycards[0]))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(accounts.SameKeycards(keycard1, syncedKeycards[0]))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestSettingKeycardUnlocked() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
keycard1.KeycardLocked = true
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.KeycardLocked = false
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
err = s.main.KeycardUnlocked(context.Background(), updatedKeycard1.KeycardUID, updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(accounts.SameKeycards(updatedKeycard1, senderKeycards[0]))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(accounts.SameKeycards(updatedKeycard1, syncedKeycards[0]))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestSettingKeycardUnlockedOlderClock() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
keycard1.KeycardLocked = true
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.KeycardLocked = false
|
|
|
|
updatedKeycard1.LastUpdateClock = updatedKeycard1.LastUpdateClock - 1
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
err = s.main.KeycardUnlocked(context.Background(), updatedKeycard1.KeycardUID, updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(accounts.SameKeycards(keycard1, senderKeycards[0]))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(accounts.SameKeycards(keycard1, syncedKeycards[0]))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestUpdatingKeycardUid() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.KeycardUID = "00000000000000000000000000000000"
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Update keycard uid on sender
|
|
|
|
err = s.main.UpdateKeycardUID(context.Background(), keycard1.KeycardUID, updatedKeycard1.KeycardUID,
|
|
|
|
updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(accounts.SameKeycards(updatedKeycard1, senderKeycards[0]))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(accounts.SameKeycards(updatedKeycard1, syncedKeycards[0]))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerSyncKeycardChangeSuite) TestUpdatingKeycardUidOldClock() {
|
|
|
|
senderDb := s.main.settings
|
|
|
|
dbOnReceiver := s.other.settings
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
keycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
// Add keycard on sender
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err := senderDb.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
|
|
|
// Add the same keycard on receiver
|
2023-05-16 12:50:04 +02:00
|
|
|
addedKc, addedAccs, err = dbOnReceiver.AddKeycardOrAddAccountsIfKeycardIsAdded(*keycard1)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(true, addedKc)
|
|
|
|
s.Require().Equal(false, addedAccs)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Prepare expected keycard for comparison
|
|
|
|
updatedKeycard1 := accounts.GetProfileKeycardForTest()
|
|
|
|
updatedKeycard1.KeycardUID = "00000000000000000000000000000000"
|
|
|
|
updatedKeycard1.LastUpdateClock = updatedKeycard1.LastUpdateClock - 1
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
// Update keycard uid on sender
|
|
|
|
err = s.main.UpdateKeycardUID(context.Background(), keycard1.KeycardUID, updatedKeycard1.KeycardUID,
|
|
|
|
updatedKeycard1.LastUpdateClock)
|
2023-02-21 13:35:26 +01:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Wait for the response
|
|
|
|
_, err = WaitOnMessengerResponse(
|
|
|
|
s.other,
|
|
|
|
func(r *MessengerResponse) bool {
|
|
|
|
return len(r.KeycardActions()) == 1
|
|
|
|
},
|
|
|
|
"expected to receive keycard activities",
|
|
|
|
)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-05-16 12:50:04 +02:00
|
|
|
senderKeycards, err := senderDb.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(senderKeycards))
|
|
|
|
s.Require().True(accounts.SameKeycards(keycard1, senderKeycards[0]))
|
|
|
|
|
2023-02-21 13:35:26 +01:00
|
|
|
syncedKeycards, err := dbOnReceiver.GetAllKnownKeycards()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Equal(1, len(syncedKeycards))
|
2023-05-16 12:50:04 +02:00
|
|
|
s.Require().True(accounts.SameKeycards(keycard1, syncedKeycards[0]))
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|