From e35d36c90bea73e77975a300ae1f5dc897d74262 Mon Sep 17 00:00:00 2001 From: Ruben Pollan Date: Sun, 28 Mar 2021 13:00:16 +0200 Subject: Fix the tests --- gui/backend.go | 5 +++- pkg/vpn/bonafide/bonafide.go | 2 +- pkg/vpn/bonafide/gateways.go | 62 +++++++++++++++++++-------------------- pkg/vpn/bonafide/gateways_test.go | 26 ++++++++-------- 4 files changed, 48 insertions(+), 47 deletions(-) diff --git a/gui/backend.go b/gui/backend.go index f693118..d4f5738 100644 --- a/gui/backend.go +++ b/gui/backend.go @@ -32,7 +32,10 @@ func SwitchOff() { //export UseLocation func UseLocation(label string) { - backend.UseLocation(label) + // a bit of a hack to force the compiler to copy the string + // so the original C++ string will not be used as it will be changed down the line + location := string([]byte(label)) + backend.UseLocation(location) } //export UseAutomaticGateway diff --git a/pkg/vpn/bonafide/bonafide.go b/pkg/vpn/bonafide/bonafide.go index 8387873..4e1db74 100644 --- a/pkg/vpn/bonafide/bonafide.go +++ b/pkg/vpn/bonafide/bonafide.go @@ -229,7 +229,7 @@ func (b *Bonafide) ListLocationFullness(transport string) map[string]float64 { } func (b *Bonafide) SetManualGateway(label string) { - b.gateways.setUserChoice([]byte(label)) + b.gateways.setUserChoice(label) } func (b *Bonafide) SetAutomaticGateway() { diff --git a/pkg/vpn/bonafide/gateways.go b/pkg/vpn/bonafide/gateways.go index c848d77..21ed957 100644 --- a/pkg/vpn/bonafide/gateways.go +++ b/pkg/vpn/bonafide/gateways.go @@ -22,8 +22,6 @@ type Load struct { // A Gateway is a representation of gateways that is independent of the api version. // If a given physical location offers different transports, they will appear // as separate gateways, so make sure to filter them. -// TODO We should include also the fullness metric here, so that it's easier to the UI to -// represent them without any extra call. type Gateway struct { Host string IPAddress string @@ -47,10 +45,10 @@ type gatewayPool struct { /* available is the unordered list of gateways from eip-service, we use if as source-of-truth for now. TODO we might want to remove gateways if they are not returned by menshen due to being overloaded */ available []Gateway - userChoice []byte + userChoice string - /* byCity is a map from location to an array of hostnames */ - byCity map[string][]string + /* byLocation is a map from location to an array of hostnames */ + byLocation map[string][]string /* recommended is an array of hostnames, fetched from the old geoip service. * this should be deprecated in favor of recommendedWithLoad when new menshen is deployed */ @@ -67,42 +65,42 @@ type gatewayPool struct { func (p *gatewayPool) populateCityList() { for _, gw := range p.available { loc := gw.Location - gws := p.byCity[loc] + gws := p.byLocation[loc] if len(gws) == 0 { - p.byCity[loc] = []string{gw.Host} + p.byLocation[loc] = []string{gw.Host} } else { - p.byCity[loc] = append(gws, gw.Host) + p.byLocation[loc] = append(gws, gw.Host) } } - log.Println(p.byCity) } -func (p *gatewayPool) getCities() []string { +func (p *gatewayPool) getLocations() []string { c := make([]string, 0) - if p == nil || p.byCity == nil || len(p.byCity) == 0 { + if p == nil || p.byLocation == nil || len(p.byLocation) == 0 { return c } - if len(p.byCity) != 0 { - for city := range p.byCity { + if len(p.byLocation) != 0 { + for city := range p.byLocation { c = append(c, city) } } return c } -func (p *gatewayPool) isValidCity(city string) bool { - cities := p.getCities() - valid := stringInSlice(city, cities) +func (p *gatewayPool) isValidLocation(location string) bool { + locations := p.getLocations() + valid := stringInSlice(location, locations) return valid } /* returns a map of location: fullness for the ui to use */ func (p *gatewayPool) listLocationFullness(transport string) map[string]float64 { - cities := p.getCities() + locations := p.getLocations() cm := make(map[string]float64) - for _, city := range cities { - gw, _ := p.getRandomGatewayByCity(city, transport) - cm[city] = gw.Fullness + for _, location := range locations { + // TODO: we should get the best fullness + gw, _ := p.getRandomGatewayByLocation(location, transport) + cm[location] = gw.Fullness } return cm } @@ -111,13 +109,13 @@ func (p *gatewayPool) listLocationFullness(transport string) map[string]float64 * TODO if we do have an usable menshen list, we can just traverse "recommended" * and return, in order, at most max gateways for the selected location. */ -func (p *gatewayPool) getRandomGatewayByCity(city, transport string) (Gateway, error) { - if !p.isValidCity(city) { - return Gateway{}, errors.New("bonafide: BUG not a valid city: " + city) +func (p *gatewayPool) getRandomGatewayByLocation(location, transport string) (Gateway, error) { + if !p.isValidLocation(location) { + return Gateway{}, errors.New("bonafide: BUG not a valid location: " + location) } - gws := p.byCity[city] + gws := p.byLocation[location] if len(gws) == 0 { - return Gateway{}, errors.New("bonafide: BUG no gw for city " + city) + return Gateway{}, errors.New("bonafide: BUG no gw for location: " + location) } s := rand.NewSource(time.Now().Unix()) r := rand.New(s) @@ -152,15 +150,15 @@ func (p *gatewayPool) getGatewayByIP(ip string) (Gateway, error) { /* this perhaps could be made more explicit */ func (p *gatewayPool) setAutomaticChoice() { - p.userChoice = []byte("") + p.userChoice = "" } /* set a user manual override for gateway location */ -func (p *gatewayPool) setUserChoice(city []byte) error { - if !p.isValidCity(string(city)) { +func (p *gatewayPool) setUserChoice(location string) error { + if !p.isValidLocation(location) { return errors.New("bonafide: not a valid city for gateway choice") } - p.userChoice = city + p.userChoice = location return nil } @@ -189,10 +187,10 @@ func (p *gatewayPool) setRecommendedGateways(hostnames []string) { * doing manual override, and if we got useful info from menshen */ func (p *gatewayPool) getBest(transport string, tz, max int) ([]Gateway, error) { gws := make([]Gateway, 0) - if len(p.userChoice) != 0 { + if p.isManualLocation() { /* FIXME this is random because we still do not get menshen to return us load. after "new" menshen is deployed, we can just get them by the order menshen returned */ - gw, err := p.getRandomGatewayByCity(string(p.userChoice), transport) + gw, err := p.getRandomGatewayByLocation(p.userChoice, transport) gws = append(gws, gw) return gws, err } else if len(p.recommended) != 0 { @@ -269,7 +267,7 @@ func newGatewayPool(eip *eipService) *gatewayPool { p := gatewayPool{} p.available = eip.getGateways() p.locations = eip.Locations - p.byCity = make(map[string][]string) + p.byLocation = make(map[string][]string) p.populateCityList() return &p } diff --git a/pkg/vpn/bonafide/gateways_test.go b/pkg/vpn/bonafide/gateways_test.go index 42a7a95..1266c8f 100644 --- a/pkg/vpn/bonafide/gateways_test.go +++ b/pkg/vpn/bonafide/gateways_test.go @@ -28,33 +28,33 @@ func TestGatewayPool(t *testing.T) { if len(pool.available) != 7 { t.Fatal("Expected 7 initial gateways, got", len(g.available)) } - expectedLabels := []string{"a-1", "a-2", "b-1", "b-2", "b-3", "c-1", "c-2"} + expectedLabels := []string{"a", "b", "c"} sort.Strings(expectedLabels) - labels := pool.getLabels() + labels := pool.getLocations() sort.Strings(labels) if !reflect.DeepEqual(expectedLabels, labels) { t.Fatal("gatewayPool labels not what expected. Got:", labels) } - if pool.userChoice != nil { + if pool.userChoice != "" { t.Fatal("userChoice should be empty by default") } - err = pool.setUserChoice([]byte("foo")) + err = pool.setUserChoice("foo") if err == nil { t.Fatal("gatewayPool should not let you set a foo gateway") } - err = pool.setUserChoice([]byte("a-1")) + err = pool.setUserChoice("a") if err != nil { - t.Fatal("location 'a-1' should be a valid label") + t.Fatal("location 'a' should be a valid label") } - err = pool.setUserChoice([]byte("c-2")) + err = pool.setUserChoice("c") if err != nil { - t.Fatal("location 'c-2' should be a valid label") + t.Fatal("location 'c' should be a valid label") } - if string(pool.userChoice) != "c-2" { - t.Fatal("userChoice should be c-2") + if string(pool.userChoice) != "c" { + t.Fatal("userChoice should be c") } pool.setAutomaticChoice() @@ -62,14 +62,14 @@ func TestGatewayPool(t *testing.T) { t.Fatal("userChoice should be empty after auto selection") } - gw, err := pool.getGatewayByLabel("foo") + gw, err := pool.getRandomGatewayByLocation("foo", "openvpn") if err == nil { t.Fatal("should get an error with invalid label") } - gw, err = pool.getGatewayByLabel("a-1") + gw, err = pool.getRandomGatewayByLocation("a", "openvpn") if gw.IPAddress != "1.1.1.1" { - t.Fatal("expected to get gw 1.1.1.1 with label a-1") + t.Fatal("expected to get gw 1.1.1.1 with label a") } gw, err = pool.getGatewayByIP("1.1.1.1") -- cgit v1.2.3