Fix multiple connections handling in session manager

This commit is contained in:
DanB
2015-03-31 21:39:05 +02:00
parent 6efeacf817
commit d3619368fe
3 changed files with 42 additions and 3 deletions

View File

@@ -93,6 +93,16 @@ func NewCGRConfigFromJsonString(cfgJsonStr string) (*CGRConfig, error) {
return cfg, nil
}
func NewCGRConfigFromJsonStringWithDefaults(cfgJsonStr string) (*CGRConfig, error) {
cfg, _ := NewDefaultCGRConfig()
if jsnCfg, err := NewCgrJsonCfgFromReader(strings.NewReader(cfgJsonStr)); err != nil {
return nil, err
} else if err := cfg.loadFromJsonCfg(jsnCfg); err != nil {
return nil, err
}
return cfg, nil
}
// Reads all .json files out of a folder/subfolders and loads them up in lexical order
func NewCGRConfigFromFolder(cfgDir string) (*CGRConfig, error) {
cfg, err := NewDefaultCGRConfig()

View File

@@ -23,11 +23,38 @@ import (
"testing"
)
var cfg *CGRConfig
func TestConfigSharing(t *testing.T) {
cfg, _ := NewDefaultCGRConfig()
cfg, _ = NewDefaultCGRConfig()
SetCgrConfig(cfg)
cfgReturn := CgrConfig()
if !reflect.DeepEqual(cfgReturn, cfg) {
t.Errorf("Retrieved %v, Expected %v", cfgReturn, cfg)
}
}
func TestLoadCgrCfgWithDefaults(t *testing.T) {
JSN_CFG := `
{
"sm_freeswitch": {
"enabled": true, // starts SessionManager service: <true|false>
"connections":[ // instantiate connections to multiple FreeSWITCH servers
{"server": "1.2.3.4:8021", "password": "ClueCon", "reconnects": 3},
{"server": "1.2.3.5:8021", "password": "ClueCon", "reconnects": 5}
],
},
}`
eCgrCfg, _ := NewDefaultCGRConfig()
eCgrCfg.SmFsConfig.Enabled = true
eCgrCfg.SmFsConfig.Connections = []*FsConnConfig{
&FsConnConfig{Server: "1.2.3.4:8021", Password: "ClueCon", Reconnects: 3},
&FsConnConfig{Server: "1.2.3.5:8021", Password: "ClueCon", Reconnects: 5},
}
if cgrCfg, err := NewCGRConfigFromJsonStringWithDefaults(JSN_CFG); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(eCgrCfg.SmFsConfig, cgrCfg.SmFsConfig) {
t.Errorf("Expected: %+v, received: %+v", eCgrCfg.SmFsConfig, cgrCfg.SmFsConfig)
}
}

View File

@@ -28,7 +28,8 @@ func NewDfltFsConnConfig() *FsConnConfig {
if dfltFsConnConfig == nil {
return new(FsConnConfig) // No defaults, most probably we are building the defaults now
}
return dfltFsConnConfig
dfltVal := *dfltFsConnConfig // Copy the value instead of it's pointer
return &dfltVal
}
// One connection to FreeSWITCH server
@@ -136,7 +137,8 @@ func NewDfltKamConnConfig() *KamConnConfig {
if dfltKamConnConfig == nil {
return new(KamConnConfig) // No defaults, most probably we are building the defaults now
}
return dfltKamConnConfig
dfltVal := *dfltKamConnConfig
return &dfltVal
}
// Represents one connection instance towards Kamailio