mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-11 18:16:24 +05:00
Fix multiple connections handling in session manager
This commit is contained in:
@@ -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()
|
||||
|
||||
@@ -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)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user