Improvement to getting multiaccounts with images

This commit is contained in:
Samuel Hawksby-Robinson 2020-12-01 18:15:53 +00:00 committed by Andrea Maria Piana
parent d07ec1a98f
commit 30dc634951
2 changed files with 50 additions and 16 deletions

View File

@ -48,10 +48,9 @@ func (db *Database) GetAccounts() ([]Account, error) {
defer rows.Close()
var rst []Account
accs := map[string]*Account{}
accLoginTimestamp := sql.NullInt64{}
for rows.Next() {
acc := Account{}
accLoginTimestamp := sql.NullInt64{}
accIdenticon := sql.NullString{}
ii := &images.IdentityImage{}
iiName := sql.NullString{}
@ -91,22 +90,24 @@ func (db *Database) GetAccounts() ([]Account, error) {
ii = nil
}
// Last index
li := len(rst) - 1
// Don't process nil identity images
if ii != nil {
a, ok := accs[acc.Name]
if ok {
a.Images = append(a.Images, *ii)
// attach the identity image to a previously created account if present, check keyUID matches
if len(rst) > 0 && rst[li].KeyUID == acc.KeyUID {
rst[li].Images = append(rst[li].Images, *ii)
// else attach the identity image to the newly created account
} else {
acc.Images = append(acc.Images, *ii)
}
}
accs[acc.Name] = &acc
}
// Yes, I know, I'm converting a map into a slice, this is to maintain the function signature and API behaviour and
// not need to loop through the slice searching for an account with a given keyUID
for _, a := range accs {
rst = append(rst, *a)
// Append newly created account only if this is the first loop or the keyUID doesn't match
if len(rst) == 0 || rst[li].KeyUID != acc.KeyUID {
rst = append(rst, acc)
}
}
return rst, nil

View File

@ -70,7 +70,7 @@ var (
keyUID2 = "0x1337beef"
)
func seedTestDB(t *testing.T, db *Database) {
func seedTestDBWithIdentityImages(t *testing.T, db *Database, keyUID string) {
iis := images.SampleIdentityImages()
require.NoError(t, db.StoreIdentityImages(keyUID, iis))
}
@ -78,7 +78,7 @@ func seedTestDB(t *testing.T, db *Database) {
func TestDatabase_GetIdentityImages(t *testing.T) {
db, stop := setupTestDB(t)
defer stop()
seedTestDB(t, db)
seedTestDBWithIdentityImages(t, db, keyUID)
expected := `[{"keyUid":"0xdeadbeef","type":"large","uri":"","width":240,"height":300,"fileSize":1024,"resizeTarget":240},{"keyUid":"0xdeadbeef","type":"thumbnail","uri":"","width":80,"height":80,"fileSize":256,"resizeTarget":80}]`
@ -98,7 +98,7 @@ func TestDatabase_GetIdentityImages(t *testing.T) {
func TestDatabase_GetIdentityImage(t *testing.T) {
db, stop := setupTestDB(t)
defer stop()
seedTestDB(t, db)
seedTestDBWithIdentityImages(t, db, keyUID)
cs := []struct {
KeyUID string
@ -135,7 +135,7 @@ func TestDatabase_GetIdentityImage(t *testing.T) {
func TestDatabase_DeleteIdentityImage(t *testing.T) {
db, stop := setupTestDB(t)
defer stop()
seedTestDB(t, db)
seedTestDBWithIdentityImages(t, db, keyUID)
require.NoError(t, db.DeleteIdentityImage(keyUID))
@ -143,3 +143,36 @@ func TestDatabase_DeleteIdentityImage(t *testing.T) {
require.NoError(t, err)
require.Empty(t, oii)
}
func TestDatabase_GetAccountsWithIdentityImages(t *testing.T) {
db, stop := setupTestDB(t)
defer stop()
testAccs := []Account{
{Name: "string", KeyUID: keyUID, Identicon: "data"},
{Name: "string", KeyUID: keyUID2},
{Name: "string", KeyUID: keyUID2 + "2"},
{Name: "string", KeyUID: keyUID2 + "3"},
}
expected := `[{"name":"string","timestamp":100,"identicon":"data","keycard-pairing":"","key-uid":"0xdeadbeef","images":[{"keyUid":"0xdeadbeef","type":"large","uri":"","width":240,"height":300,"fileSize":1024,"resizeTarget":240},{"keyUid":"0xdeadbeef","type":"thumbnail","uri":"","width":80,"height":80,"fileSize":256,"resizeTarget":80}]},{"name":"string","timestamp":10,"identicon":"","keycard-pairing":"","key-uid":"0x1337beef","images":null},{"name":"string","timestamp":0,"identicon":"","keycard-pairing":"","key-uid":"0x1337beef2","images":null},{"name":"string","timestamp":0,"identicon":"","keycard-pairing":"","key-uid":"0x1337beef3","images":[{"keyUid":"0x1337beef3","type":"large","uri":"","width":240,"height":300,"fileSize":1024,"resizeTarget":240},{"keyUid":"0x1337beef3","type":"thumbnail","uri":"","width":80,"height":80,"fileSize":256,"resizeTarget":80}]}]`
for _, a := range testAccs {
require.NoError(t, db.SaveAccount(a))
}
seedTestDBWithIdentityImages(t, db, keyUID)
seedTestDBWithIdentityImages(t, db, keyUID2 + "3")
err := db.UpdateAccountTimestamp(keyUID, 100)
require.NoError(t, err)
err = db.UpdateAccountTimestamp(keyUID2, 10)
require.NoError(t, err)
accs, err := db.GetAccounts()
require.NoError(t, err)
accJson, err := json.Marshal(accs)
require.NoError(t, err)
require.Exactly(t, expected, string(accJson))
}