package channeldb import ( "testing" "time" "github.com/lightningnetwork/lnd/routing/route" "github.com/stretchr/testify/require" ) // TestFlapCount tests lookup and writing of flap count to disk. func TestFlapCount(t *testing.T) { db, cleanup, err := MakeTestDB() require.NoError(t, err) defer cleanup() // Try to read flap count for a peer that we have no records for. _, err = db.ReadFlapCount(testPub) require.Equal(t, ErrNoPeerBucket, err) var ( testPub2 = route.Vertex{2, 2, 2} peer1FlapCount = &FlapCount{ Count: 20, LastFlap: time.Unix(100, 23), } peer2FlapCount = &FlapCount{ Count: 39, LastFlap: time.Unix(200, 23), } ) peers := map[route.Vertex]*FlapCount{ testPub: peer1FlapCount, testPub2: peer2FlapCount, } err = db.WriteFlapCounts(peers) require.NoError(t, err) // Lookup flap count for our first pubkey. count, err := db.ReadFlapCount(testPub) require.NoError(t, err) require.Equal(t, peer1FlapCount, count) // Lookup our flap count for the second peer. count, err = db.ReadFlapCount(testPub2) require.NoError(t, err) require.Equal(t, peer2FlapCount, count) }