1
0
mirror of https://github.com/alice-lg/alice-lg.git synced 2024-05-11 05:55:03 +00:00
alice-lg-alice-lg/backend/neighbours_store_test.go
2018-07-06 17:04:09 +02:00

119 lines
2.3 KiB
Go

package main
import (
"github.com/alice-lg/alice-lg/backend/api"
"testing"
)
/*
Start the global neighbours store,
because the route store in the tests have
this as a dependency.
*/
func startTestNeighboursStore() {
store := makeTestNeighboursStore()
AliceNeighboursStore = store
}
/*
Make a store and populate it with data
*/
func makeTestNeighboursStore() *NeighboursStore {
// Populate neighbours
rs1 := NeighboursIndex{
"ID2233_AS2342": &api.Neighbour{
Id: "ID2233_AS2342",
Description: "PEER AS2342 192.9.23.42 Customer Peer 1",
},
"ID2233_AS2343": &api.Neighbour{
Id: "ID2233_AS2343",
Description: "PEER AS2343 192.9.23.43 Different Peer 1",
},
"ID2233_AS2344": &api.Neighbour{
Id: "ID2233_AS2344",
Description: "PEER AS2344 192.9.23.44 3rd Peer from the sun",
},
}
rs2 := NeighboursIndex{
"ID2233_AS2342": &api.Neighbour{
Id: "ID2233_AS2342",
Description: "PEER AS2342 192.9.23.42 Customer Peer 1",
},
"ID2233_AS4223": &api.Neighbour{
Id: "ID2233_AS4223",
Description: "PEER AS4223 192.9.42.23 Cloudfoo Inc.",
},
}
// Create store
store := &NeighboursStore{
neighboursMap: map[int]NeighboursIndex{
1: rs1,
2: rs2,
},
}
return store
}
func TestGetNeighbourAt(t *testing.T) {
store := makeTestNeighboursStore()
neighbour := store.GetNeighbourAt(1, "ID2233_AS2343")
if neighbour.Id != "ID2233_AS2343" {
t.Error("Expected another peer in GetNeighbourAt")
}
}
func TestNeighbourLookupAt(t *testing.T) {
store := makeTestNeighboursStore()
expected := []string{
"ID2233_AS2342",
"ID2233_AS2343",
}
neighbours := store.LookupNeighboursAt(1, "peer 1")
// Make index
index := NeighboursIndex{}
for _, n := range neighbours {
index[n.Id] = n
}
for _, id := range expected {
_, ok := index[id]
if !ok {
t.Error("Expected", id, "to be in result set")
}
}
}
func TestNeighbourLookup(t *testing.T) {
store := makeTestNeighboursStore()
// First result set: "Peer 1"
_ = store
results := store.LookupNeighbours("Cloudfoo")
// Peer should be present at RS2
neighbours, ok := results[2]
if !ok {
t.Error("Lookup on rs2 unsuccessful.")
}
if len(neighbours) > 1 {
t.Error("Lookup should match exact 1 peer.")
}
n := neighbours[0]
if n.Id != "ID2233_AS4223" {
t.Error("Wrong peer in lookup response")
}
}