197 lines
5.4 KiB
Go
197 lines
5.4 KiB
Go
package database
|
|
|
|
import (
|
|
"os"
|
|
"testing"
|
|
)
|
|
|
|
var (
|
|
testDb = "test.db"
|
|
ticket = Ticket{
|
|
Hash: "Hash",
|
|
CommitmentSignature: "CommitmentSignature",
|
|
FeeAddress: "FeeAddress",
|
|
Address: "Address",
|
|
SDiff: 1,
|
|
BlockHeight: 2,
|
|
VoteBits: 3,
|
|
VotingKey: "VotingKey",
|
|
}
|
|
db *VspDatabase
|
|
)
|
|
|
|
// TestDatabase runs all database tests.
|
|
func TestDatabase(t *testing.T) {
|
|
// Ensure we are starting with a clean environment.
|
|
os.Remove(testDb)
|
|
|
|
// All sub-tests to run.
|
|
tests := map[string]func(*testing.T){
|
|
"testInsertFeeAddress": testInsertFeeAddress,
|
|
"testGetFeeAddressByTicketHash": testGetFeeAddressByTicketHash,
|
|
"testGetFeesByFeeAddress": testGetFeesByFeeAddress,
|
|
"testInsertFeeAddressVotingKey": testInsertFeeAddressVotingKey,
|
|
"testGetInactiveFeeAddresses": testGetInactiveFeeAddresses,
|
|
}
|
|
|
|
for testName, test := range tests {
|
|
// Create a new blank database for each sub-test.
|
|
var err error
|
|
db, err = New(testDb)
|
|
if err != nil {
|
|
t.Fatalf("error creating test database: %v", err)
|
|
}
|
|
|
|
// Run the sub-test.
|
|
t.Run(testName, test)
|
|
|
|
// Close and remove test database after each sub-test.
|
|
db.Close()
|
|
os.Remove(testDb)
|
|
}
|
|
}
|
|
|
|
func testInsertFeeAddress(t *testing.T) {
|
|
// Insert a ticket into the database.
|
|
err := db.InsertFeeAddress(ticket)
|
|
if err != nil {
|
|
t.Fatalf("error storing ticket in database: %v", err)
|
|
}
|
|
|
|
// Inserting a ticket with the same hash should fail.
|
|
err = db.InsertFeeAddress(ticket)
|
|
if err == nil {
|
|
t.Fatal("expected an error inserting ticket with duplicate hash")
|
|
}
|
|
}
|
|
|
|
func testGetFeeAddressByTicketHash(t *testing.T) {
|
|
// Insert a ticket into the database.
|
|
err := db.InsertFeeAddress(ticket)
|
|
if err != nil {
|
|
t.Fatalf("error storing ticket in database: %v", err)
|
|
}
|
|
|
|
// Retrieve ticket from database.
|
|
retrieved, err := db.GetFeeAddressByTicketHash(ticket.Hash)
|
|
if err != nil {
|
|
t.Fatalf("error retrieving ticket by ticket hash: %v", err)
|
|
}
|
|
|
|
// Check ticket fields match expected.
|
|
if retrieved.Hash != ticket.Hash ||
|
|
retrieved.CommitmentSignature != ticket.CommitmentSignature ||
|
|
retrieved.FeeAddress != ticket.FeeAddress ||
|
|
retrieved.Address != ticket.Address ||
|
|
retrieved.SDiff != ticket.SDiff ||
|
|
retrieved.BlockHeight != ticket.BlockHeight ||
|
|
retrieved.VoteBits != ticket.VoteBits ||
|
|
retrieved.VotingKey != ticket.VotingKey {
|
|
t.Fatal("retrieved ticket value didnt match expected")
|
|
}
|
|
|
|
// Error if non-existent ticket requested.
|
|
_, err = db.GetFeeAddressByTicketHash("Not a real ticket hash")
|
|
if err == nil {
|
|
t.Fatal("expected an error while retrieving a non-existent ticket")
|
|
}
|
|
}
|
|
|
|
func testGetFeesByFeeAddress(t *testing.T) {
|
|
// Insert a ticket into the database.
|
|
err := db.InsertFeeAddress(ticket)
|
|
if err != nil {
|
|
t.Fatalf("error storing ticket in database: %v", err)
|
|
}
|
|
|
|
// Retrieve ticket using its fee address.
|
|
retrieved, err := db.GetFeesByFeeAddress(ticket.FeeAddress)
|
|
if err != nil {
|
|
t.Fatalf("error retrieving ticket by fee address: %v", err)
|
|
}
|
|
|
|
// Check it is the correct ticket.
|
|
if retrieved.FeeAddress != ticket.FeeAddress {
|
|
t.Fatal("retrieved ticket FeeAddress didnt match expected")
|
|
}
|
|
|
|
// Error if non-existent ticket requested.
|
|
_, err = db.GetFeesByFeeAddress("Not a real fee address")
|
|
if err == nil {
|
|
t.Fatal("expected an error while retrieving a non-existent ticket")
|
|
}
|
|
|
|
// Insert another ticket into the database with the same fee address.
|
|
ticket.Hash = ticket.Hash + "2"
|
|
err = db.InsertFeeAddress(ticket)
|
|
if err != nil {
|
|
t.Fatalf("error storing ticket in database: %v", err)
|
|
}
|
|
|
|
// Error when more than one ticket matches
|
|
_, err = db.GetFeesByFeeAddress(ticket.FeeAddress)
|
|
if err == nil {
|
|
t.Fatal("expected an error when multiple tickets are found")
|
|
}
|
|
}
|
|
|
|
func testInsertFeeAddressVotingKey(t *testing.T) {
|
|
// Insert a ticket into the database.
|
|
err := db.InsertFeeAddress(ticket)
|
|
if err != nil {
|
|
t.Fatalf("error storing ticket in database: %v", err)
|
|
}
|
|
|
|
// Update values.
|
|
newVotingKey := ticket.VotingKey + "2"
|
|
newVoteBits := ticket.VoteBits + 2
|
|
err = db.InsertFeeAddressVotingKey(ticket.Address, newVotingKey, newVoteBits)
|
|
if err != nil {
|
|
t.Fatalf("error updating votingkey and votebits: %v", err)
|
|
}
|
|
|
|
// Retrieve ticket from database.
|
|
retrieved, err := db.GetFeeAddressByTicketHash(ticket.Hash)
|
|
if err != nil {
|
|
t.Fatalf("error retrieving ticket by ticket hash: %v", err)
|
|
}
|
|
|
|
// Check ticket fields match expected.
|
|
if newVoteBits != retrieved.VoteBits ||
|
|
newVotingKey != retrieved.VotingKey {
|
|
t.Fatal("retrieved ticket value didnt match expected")
|
|
}
|
|
}
|
|
|
|
func testGetInactiveFeeAddresses(t *testing.T) {
|
|
// Insert a ticket into the database.
|
|
err := db.InsertFeeAddress(ticket)
|
|
if err != nil {
|
|
t.Fatalf("error storing ticket in database: %v", err)
|
|
}
|
|
|
|
// Insert a ticket with empty voting key into the database.
|
|
ticket.Hash = ticket.Hash + "2"
|
|
newFeeAddr := ticket.FeeAddress + "2"
|
|
ticket.FeeAddress = newFeeAddr
|
|
ticket.VotingKey = ""
|
|
err = db.InsertFeeAddress(ticket)
|
|
if err != nil {
|
|
t.Fatalf("error storing ticket in database: %v", err)
|
|
}
|
|
|
|
// Retrieve unused fee address from database.
|
|
feeAddrs, err := db.GetInactiveFeeAddresses()
|
|
if err != nil {
|
|
t.Fatalf("error retrieving inactive fee addresses: %v", err)
|
|
}
|
|
|
|
// Check we have one value, and its the expected one.
|
|
if len(feeAddrs) != 1 {
|
|
t.Fatal("expected 1 unused fee address")
|
|
}
|
|
if feeAddrs[0] != newFeeAddr {
|
|
t.Fatal("fee address didnt match expected")
|
|
}
|
|
}
|