mirror of
https://github.com/netbirdio/netbird.git
synced 2025-05-29 22:31:50 +02:00
Add account copy test (#549)
This commit is contained in:
parent
270f0e4ce8
commit
1f845f466c
@ -1,8 +1,11 @@
|
|||||||
package server
|
package server
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
|
nbdns "github.com/netbirdio/netbird/dns"
|
||||||
"github.com/netbirdio/netbird/route"
|
"github.com/netbirdio/netbird/route"
|
||||||
"net"
|
"net"
|
||||||
|
"reflect"
|
||||||
"sync"
|
"sync"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
@ -1119,6 +1122,85 @@ func TestAccount_GetPeersRoutes(t *testing.T) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestAccount_Copy(t *testing.T) {
|
||||||
|
account := &Account{
|
||||||
|
Id: "account1",
|
||||||
|
CreatedBy: "tester",
|
||||||
|
Domain: "test.com",
|
||||||
|
DomainCategory: "public",
|
||||||
|
IsDomainPrimaryAccount: true,
|
||||||
|
SetupKeys: map[string]*SetupKey{
|
||||||
|
"setup1": {
|
||||||
|
Id: "setup1",
|
||||||
|
AutoGroups: []string{"group1"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Network: &Network{
|
||||||
|
Id: "net1",
|
||||||
|
},
|
||||||
|
Peers: map[string]*Peer{
|
||||||
|
"peer1": {
|
||||||
|
Key: "key1",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Users: map[string]*User{
|
||||||
|
"user1": {
|
||||||
|
Id: "user1",
|
||||||
|
Role: UserRoleAdmin,
|
||||||
|
AutoGroups: []string{"group1"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Groups: map[string]*Group{
|
||||||
|
"group1": {
|
||||||
|
ID: "group1",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Rules: map[string]*Rule{
|
||||||
|
"rule1": {
|
||||||
|
ID: "rule1",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Routes: map[string]*route.Route{
|
||||||
|
"route1": {
|
||||||
|
ID: "route1",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
NameServerGroups: map[string]*nbdns.NameServerGroup{
|
||||||
|
"nsGroup1": {
|
||||||
|
ID: "nsGroup1",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
err := hasNilField(account)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
accountCopy := account.Copy()
|
||||||
|
assert.Equal(t, account, accountCopy, "account copy returned a different value than expected")
|
||||||
|
}
|
||||||
|
|
||||||
|
// hasNilField validates pointers, maps and slices if they are nil
|
||||||
|
func hasNilField(x interface{}) error {
|
||||||
|
rv := reflect.ValueOf(x)
|
||||||
|
rv = rv.Elem()
|
||||||
|
for i := 0; i < rv.NumField(); i++ {
|
||||||
|
if f := rv.Field(i); f.IsValid() {
|
||||||
|
k := f.Kind()
|
||||||
|
switch k {
|
||||||
|
case reflect.Ptr:
|
||||||
|
if f.IsNil() {
|
||||||
|
return fmt.Errorf("field %s is nil", f.String())
|
||||||
|
}
|
||||||
|
case reflect.Map, reflect.Slice:
|
||||||
|
if f.Len() == 0 || f.IsNil() {
|
||||||
|
return fmt.Errorf("field %s is nil", f.String())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func createManager(t *testing.T) (*DefaultAccountManager, error) {
|
func createManager(t *testing.T) (*DefaultAccountManager, error) {
|
||||||
store, err := createStore(t)
|
store, err := createStore(t)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user