201 lines
5.6 KiB
Go
201 lines
5.6 KiB
Go
package store
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/alecthomas/assert/v2"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
visedb "git.defalsify.org/vise.git/db"
|
|
memdb "git.defalsify.org/vise.git/db/mem"
|
|
storedb "git.grassecon.net/grassrootseconomics/sarafu-vise/store/db"
|
|
dataserviceapi "github.com/grassrootseconomics/ussd-data-service/pkg/api"
|
|
)
|
|
|
|
// InitializeTestDb sets up and returns an in-memory database and store.
|
|
func InitializeTestDb(t *testing.T) (context.Context, *UserDataStore) {
|
|
ctx := context.Background()
|
|
|
|
// Initialize memDb
|
|
db := memdb.NewMemDb()
|
|
err := db.Connect(ctx, "")
|
|
require.NoError(t, err, "Failed to connect to memDb")
|
|
|
|
// Create UserDataStore with memDb
|
|
store := &UserDataStore{Db: db}
|
|
|
|
t.Cleanup(func() {
|
|
db.Close() // Ensure the DB is closed after each test
|
|
})
|
|
|
|
return ctx, store
|
|
}
|
|
|
|
func TestMatchVoucher(t *testing.T) {
|
|
symbols := "1:SRF\n2:MILO"
|
|
balances := "1:100\n2:200"
|
|
decimals := "1:6\n2:4"
|
|
addresses := "1:0xd4c288865Ce\n2:0x41c188d63Qa"
|
|
|
|
// Test for valid voucher
|
|
symbol, balance, decimal, address := MatchVoucher("2", symbols, balances, decimals, addresses)
|
|
|
|
// Assertions for valid voucher
|
|
assert.Equal(t, "MILO", symbol)
|
|
assert.Equal(t, "200", balance)
|
|
assert.Equal(t, "4", decimal)
|
|
assert.Equal(t, "0x41c188d63Qa", address)
|
|
|
|
// Test for non-existent voucher
|
|
symbol, balance, decimal, address = MatchVoucher("3", symbols, balances, decimals, addresses)
|
|
|
|
// Assertions for non-match
|
|
assert.Equal(t, "", symbol)
|
|
assert.Equal(t, "", balance)
|
|
assert.Equal(t, "", decimal)
|
|
assert.Equal(t, "", address)
|
|
}
|
|
|
|
func TestProcessVouchers(t *testing.T) {
|
|
holdings := []dataserviceapi.TokenHoldings{
|
|
{ContractAddress: "0xd4c288865Ce", TokenSymbol: "SRF", TokenDecimals: "6", Balance: "100000000"},
|
|
{ContractAddress: "0x41c188d63Qa", TokenSymbol: "MILO", TokenDecimals: "4", Balance: "200000000"},
|
|
}
|
|
|
|
expectedResult := VoucherMetadata{
|
|
Symbols: "1:SRF\n2:MILO",
|
|
Balances: "1:100\n2:20000",
|
|
Decimals: "1:6\n2:4",
|
|
Addresses: "1:0xd4c288865Ce\n2:0x41c188d63Qa",
|
|
}
|
|
|
|
result := ProcessVouchers(holdings)
|
|
|
|
assert.Equal(t, expectedResult, result)
|
|
}
|
|
|
|
func TestGetVoucherData(t *testing.T) {
|
|
ctx := context.Background()
|
|
|
|
db := memdb.NewMemDb()
|
|
err := db.Connect(ctx, "")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
prefix := storedb.ToBytes(visedb.DATATYPE_USERDATA)
|
|
spdb := storedb.NewSubPrefixDb(db, prefix)
|
|
|
|
// Test voucher data
|
|
mockData := map[storedb.DataTyp][]byte{
|
|
storedb.DATA_VOUCHER_SYMBOLS: []byte("1:SRF\n2:MILO"),
|
|
storedb.DATA_VOUCHER_BALANCES: []byte("1:100\n2:200"),
|
|
storedb.DATA_VOUCHER_DECIMALS: []byte("1:6\n2:4"),
|
|
storedb.DATA_VOUCHER_ADDRESSES: []byte("1:0xd4c288865Ce\n2:0x41c188d63Qa"),
|
|
}
|
|
|
|
// Put the data
|
|
for key, value := range mockData {
|
|
err = spdb.Put(ctx, []byte(storedb.ToBytes(key)), []byte(value))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
result, err := GetVoucherData(ctx, spdb, "1")
|
|
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, "SRF", result.TokenSymbol)
|
|
assert.Equal(t, "100", result.Balance)
|
|
assert.Equal(t, "6", result.TokenDecimals)
|
|
assert.Equal(t, "0xd4c288865Ce", result.ContractAddress)
|
|
}
|
|
|
|
func TestStoreTemporaryVoucher(t *testing.T) {
|
|
ctx, store := InitializeTestDb(t)
|
|
sessionId := "session123"
|
|
|
|
// Test data
|
|
voucherData := &dataserviceapi.TokenHoldings{
|
|
TokenSymbol: "SRF",
|
|
Balance: "200",
|
|
TokenDecimals: "6",
|
|
ContractAddress: "0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9",
|
|
}
|
|
|
|
// Execute the function being tested
|
|
err := StoreTemporaryVoucher(ctx, store, sessionId, voucherData)
|
|
require.NoError(t, err)
|
|
|
|
// Verify stored data
|
|
expectedData := fmt.Sprintf("%s,%s,%s,%s", "SRF", "200", "6", "0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9")
|
|
|
|
storedValue, err := store.ReadEntry(ctx, sessionId, storedb.DATA_TEMPORARY_VALUE)
|
|
require.NoError(t, err)
|
|
require.Equal(t, expectedData, string(storedValue), "Mismatch for key %v", storedb.DATA_TEMPORARY_VALUE)
|
|
}
|
|
|
|
func TestGetTemporaryVoucherData(t *testing.T) {
|
|
ctx, store := InitializeTestDb(t)
|
|
sessionId := "session123"
|
|
|
|
// Test voucher data
|
|
tempData := &dataserviceapi.TokenHoldings{
|
|
TokenSymbol: "SRF",
|
|
Balance: "200",
|
|
TokenDecimals: "6",
|
|
ContractAddress: "0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9",
|
|
}
|
|
|
|
// Store the data
|
|
err := StoreTemporaryVoucher(ctx, store, sessionId, tempData)
|
|
require.NoError(t, err)
|
|
|
|
// Execute the function being tested
|
|
data, err := GetTemporaryVoucherData(ctx, store, sessionId)
|
|
require.NoError(t, err)
|
|
require.Equal(t, tempData, data)
|
|
}
|
|
|
|
func TestUpdateVoucherData(t *testing.T) {
|
|
ctx, store := InitializeTestDb(t)
|
|
sessionId := "session123"
|
|
|
|
// New voucher data
|
|
newData := &dataserviceapi.TokenHoldings{
|
|
TokenSymbol: "SRF",
|
|
Balance: "200",
|
|
TokenDecimals: "6",
|
|
ContractAddress: "0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9",
|
|
}
|
|
|
|
// Old temporary data
|
|
tempData := &dataserviceapi.TokenHoldings{
|
|
TokenSymbol: "OLD",
|
|
Balance: "100",
|
|
TokenDecimals: "8",
|
|
ContractAddress: "0xold",
|
|
}
|
|
require.NoError(t, StoreTemporaryVoucher(ctx, store, sessionId, tempData))
|
|
|
|
// Execute update
|
|
err := UpdateVoucherData(ctx, store, sessionId, newData)
|
|
require.NoError(t, err)
|
|
|
|
// Verify active data was stored correctly
|
|
activeEntries := map[storedb.DataTyp][]byte{
|
|
storedb.DATA_ACTIVE_SYM: []byte(newData.TokenSymbol),
|
|
storedb.DATA_ACTIVE_BAL: []byte(newData.Balance),
|
|
storedb.DATA_ACTIVE_DECIMAL: []byte(newData.TokenDecimals),
|
|
storedb.DATA_ACTIVE_ADDRESS: []byte(newData.ContractAddress),
|
|
}
|
|
|
|
for key, expectedValue := range activeEntries {
|
|
storedValue, err := store.ReadEntry(ctx, sessionId, key)
|
|
require.NoError(t, err)
|
|
require.Equal(t, expectedValue, storedValue, "Active data mismatch for key %v", key)
|
|
}
|
|
}
|