alice-lg/pkg/store/routes_store_test.go
2024-01-30 10:52:51 +01:00

187 lines
3.8 KiB
Go

package store
import (
"context"
"log"
"strings"
"testing"
"github.com/alice-lg/alice-lg/pkg/api"
"github.com/alice-lg/alice-lg/pkg/config"
"github.com/alice-lg/alice-lg/pkg/pools"
"github.com/alice-lg/alice-lg/pkg/store/backends/memory"
"github.com/alice-lg/alice-lg/pkg/store/testdata"
)
func importRoutes(
s *RoutesStore,
src *config.SourceConfig,
res *api.RoutesResponse,
) error {
ctx := context.Background()
// Prepare imported routes for lookup
neighbors := map[string]*api.Neighbor{
"ID163_AS31078": {
ID: "ID163_AS31078",
},
"ID7254_AS31334": {
ID: "ID7254_AS31334",
},
}
srcRS := &api.LookupRouteServer{
ID: pools.RouteServers.Acquire(src.ID),
Name: src.Name,
}
imported := res.Imported.ToLookupRoutes("imported", srcRS, neighbors)
filtered := res.Filtered.ToLookupRoutes("filtered", srcRS, neighbors)
lookupRoutes := append(imported, filtered...)
if err := s.backend.SetRoutes(ctx, src.ID, lookupRoutes); err != nil {
return err
}
return s.sources.RefreshSuccess(src.ID)
}
// Route Store Tests
func makeTestRoutesStore() *RoutesStore {
neighborsStore := makeTestNeighborsStore()
be := memory.NewRoutesBackend()
cfg := &config.Config{
Server: config.ServerConfig{
RoutesStoreRefreshInterval: 1,
},
Sources: []*config.SourceConfig{
{
ID: "rs1",
Name: "rs1",
},
{
ID: "rs2",
Name: "rs2",
},
},
}
rs1 := testdata.RoutesResponse()
s := NewRoutesStore(neighborsStore, cfg, be)
if err := importRoutes(s, cfg.Sources[0], rs1); err != nil {
log.Panic(err)
}
return s
}
// Check for presence of network in result set
func testCheckPrefixesPresence(prefixes, resultset []string, t *testing.T) {
// Check prefixes
presence := map[string]bool{}
for _, prefix := range prefixes {
presence[prefix] = false
}
for _, prefix := range resultset {
// Check if prefixes are all accounted for
for net := range presence {
if prefix == net {
presence[net] = true
}
}
}
for net, present := range presence {
if present == false {
t.Error(net, "not found in result set")
}
}
}
func TestRoutesStoreStats(t *testing.T) {
store := makeTestRoutesStore()
stats := store.Stats(context.Background())
// Check total routes
// There should be 8 imported, and 1 filtered route
if stats.TotalRoutes.Imported != 8 {
t.Error(
"expected 8 imported routes, got:",
stats.TotalRoutes.Imported,
)
}
if stats.TotalRoutes.Filtered != 1 {
t.Error(
"expected 1 filtered route, got:",
stats.TotalRoutes.Filtered,
)
}
}
func TestLookupPrefix(t *testing.T) {
store := makeTestRoutesStore()
query := "193.200."
results, err := store.LookupPrefix(
context.Background(),
query,
api.NewSearchFilters())
if err != nil {
t.Fatal(err)
}
if len(results) == 0 {
t.Error("Expected lookup results. None present.")
return
}
// Check results
for _, prefix := range results {
if strings.HasPrefix(prefix.Network, query) == false {
t.Error(
"All network addresses should start with the",
"queried prefix",
)
}
}
}
func TestLookupPrefixForNeighbors(t *testing.T) {
// Construct a neighbors lookup result
neighbors := api.NeighborsLookupResults{
"rs1": api.Neighbors{
&api.Neighbor{
ID: "ID163_AS31078",
},
},
}
pools.Neighbors.Acquire("ID163_AS31078")
store := makeTestRoutesStore()
// Query
results, err := store.LookupPrefixForNeighbors(
context.Background(),
neighbors,
api.NewSearchFilters())
if err != nil {
t.Fatal(err)
}
// We should have retrieved 8 prefixes,
if len(results) != 8 {
t.Error("Expected result length: 8, got:", len(results))
}
presence := []string{
"193.200.230.0/24", "193.34.24.0/22", "31.220.136.0/21",
}
resultset := []string{}
for _, prefix := range results {
resultset = append(resultset, prefix.Network)
}
testCheckPrefixesPresence(presence, resultset, t)
}