Improvement to getting multiaccounts with images
This commit is contained in:
parent
d07ec1a98f
commit
30dc634951
|
@ -48,10 +48,9 @@ func (db *Database) GetAccounts() ([]Account, error) {
|
||||||
defer rows.Close()
|
defer rows.Close()
|
||||||
|
|
||||||
var rst []Account
|
var rst []Account
|
||||||
accs := map[string]*Account{}
|
|
||||||
accLoginTimestamp := sql.NullInt64{}
|
|
||||||
for rows.Next() {
|
for rows.Next() {
|
||||||
acc := Account{}
|
acc := Account{}
|
||||||
|
accLoginTimestamp := sql.NullInt64{}
|
||||||
accIdenticon := sql.NullString{}
|
accIdenticon := sql.NullString{}
|
||||||
ii := &images.IdentityImage{}
|
ii := &images.IdentityImage{}
|
||||||
iiName := sql.NullString{}
|
iiName := sql.NullString{}
|
||||||
|
@ -91,22 +90,24 @@ func (db *Database) GetAccounts() ([]Account, error) {
|
||||||
ii = nil
|
ii = nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Last index
|
||||||
|
li := len(rst) - 1
|
||||||
|
|
||||||
|
// Don't process nil identity images
|
||||||
if ii != nil {
|
if ii != nil {
|
||||||
a, ok := accs[acc.Name]
|
// attach the identity image to a previously created account if present, check keyUID matches
|
||||||
if ok {
|
if len(rst) > 0 && rst[li].KeyUID == acc.KeyUID {
|
||||||
a.Images = append(a.Images, *ii)
|
rst[li].Images = append(rst[li].Images, *ii)
|
||||||
|
// else attach the identity image to the newly created account
|
||||||
} else {
|
} else {
|
||||||
acc.Images = append(acc.Images, *ii)
|
acc.Images = append(acc.Images, *ii)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
accs[acc.Name] = &acc
|
// 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)
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return rst, nil
|
return rst, nil
|
||||||
|
|
|
@ -70,7 +70,7 @@ var (
|
||||||
keyUID2 = "0x1337beef"
|
keyUID2 = "0x1337beef"
|
||||||
)
|
)
|
||||||
|
|
||||||
func seedTestDB(t *testing.T, db *Database) {
|
func seedTestDBWithIdentityImages(t *testing.T, db *Database, keyUID string) {
|
||||||
iis := images.SampleIdentityImages()
|
iis := images.SampleIdentityImages()
|
||||||
require.NoError(t, db.StoreIdentityImages(keyUID, iis))
|
require.NoError(t, db.StoreIdentityImages(keyUID, iis))
|
||||||
}
|
}
|
||||||
|
@ -78,7 +78,7 @@ func seedTestDB(t *testing.T, db *Database) {
|
||||||
func TestDatabase_GetIdentityImages(t *testing.T) {
|
func TestDatabase_GetIdentityImages(t *testing.T) {
|
||||||
db, stop := setupTestDB(t)
|
db, stop := setupTestDB(t)
|
||||||
defer stop()
|
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}]`
|
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) {
|
func TestDatabase_GetIdentityImage(t *testing.T) {
|
||||||
db, stop := setupTestDB(t)
|
db, stop := setupTestDB(t)
|
||||||
defer stop()
|
defer stop()
|
||||||
seedTestDB(t, db)
|
seedTestDBWithIdentityImages(t, db, keyUID)
|
||||||
|
|
||||||
cs := []struct {
|
cs := []struct {
|
||||||
KeyUID string
|
KeyUID string
|
||||||
|
@ -135,7 +135,7 @@ func TestDatabase_GetIdentityImage(t *testing.T) {
|
||||||
func TestDatabase_DeleteIdentityImage(t *testing.T) {
|
func TestDatabase_DeleteIdentityImage(t *testing.T) {
|
||||||
db, stop := setupTestDB(t)
|
db, stop := setupTestDB(t)
|
||||||
defer stop()
|
defer stop()
|
||||||
seedTestDB(t, db)
|
seedTestDBWithIdentityImages(t, db, keyUID)
|
||||||
|
|
||||||
require.NoError(t, db.DeleteIdentityImage(keyUID))
|
require.NoError(t, db.DeleteIdentityImage(keyUID))
|
||||||
|
|
||||||
|
@ -143,3 +143,36 @@ func TestDatabase_DeleteIdentityImage(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Empty(t, oii)
|
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))
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue