/* Real-time Online/Offline Charging System (OCS) for Telecom & ISP environments Copyright (C) ITsysCOM GmbH This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see */ package config import ( "reflect" "testing" "github.com/cgrates/cgrates/utils" ) func TestDataDbCfgloadFromJsonCfg(t *testing.T) { var dbcfg, expected DataDbCfg if err := dbcfg.loadFromJsonCfg(nil); err != nil { t.Error(err) } else if !reflect.DeepEqual(dbcfg, expected) { t.Errorf("Expected: %+v ,recived: %+v", expected, dbcfg) } if err := dbcfg.loadFromJsonCfg(new(DbJsonCfg)); err != nil { t.Error(err) } else if !reflect.DeepEqual(dbcfg, expected) { t.Errorf("Expected: %+v ,recived: %+v", expected, dbcfg) } cfgJSONStr := `{ "data_db": { // database used to store runtime data (eg: accounts, cdr stats) "db_type": "*redis", // data_db type: <*redis|*mongo|*internal> "db_host": "127.0.0.1", // data_db host address "db_port": -1, // data_db port to reach the database "db_name": "10", // data_db database name to connect to "db_user": "cgrates", // username to use when connecting to data_db "db_password": "password", // password to use when connecting to data_db "redis_sentinel":"sentinel", // redis_sentinel is the name of sentinel } }` expected = DataDbCfg{ DataDbType: "redis", DataDbHost: "127.0.0.1", DataDbPort: "6379", DataDbName: "10", DataDbUser: "cgrates", DataDbPass: "password", DataDbSentinelName: "sentinel", } if jsnCfg, err := NewCgrJsonCfgFromBytes([]byte(cfgJSONStr)); err != nil { t.Error(err) } else if jsnDataDbCfg, err := jsnCfg.DbJsonCfg(DATADB_JSN); err != nil { t.Error(err) } else if err = dbcfg.loadFromJsonCfg(jsnDataDbCfg); err != nil { t.Error(err) } else if !reflect.DeepEqual(expected, dbcfg) { t.Errorf("Expected: %+v , recived: %+v", expected, dbcfg) } } func TestDataDbCfgloadFromJsonCfgPort(t *testing.T) { var dbcfg DataDbCfg cfgJSONStr := `{ "data_db": { "db_type": "mongo", } }` expected := DataDbCfg{ DataDbType: "mongo", } if jsnCfg, err := NewCgrJsonCfgFromBytes([]byte(cfgJSONStr)); err != nil { t.Error(err) } else if jsnDataDbCfg, err := jsnCfg.DbJsonCfg(DATADB_JSN); err != nil { t.Error(err) } else if err = dbcfg.loadFromJsonCfg(jsnDataDbCfg); err != nil { t.Error(err) } else if !reflect.DeepEqual(expected, dbcfg) { t.Errorf("Expected: %+v , recived: %+v", expected, dbcfg) } cfgJSONStr = `{ "data_db": { "db_type": "mongo", "db_port": -1, } }` expected = DataDbCfg{ DataDbType: "mongo", DataDbPort: "27017", } if jsnCfg, err := NewCgrJsonCfgFromBytes([]byte(cfgJSONStr)); err != nil { t.Error(err) } else if jsnDataDbCfg, err := jsnCfg.DbJsonCfg(DATADB_JSN); err != nil { t.Error(err) } else if err = dbcfg.loadFromJsonCfg(jsnDataDbCfg); err != nil { t.Error(err) } else if !reflect.DeepEqual(expected, dbcfg) { t.Errorf("Expected: %+v , recived: %+v", expected, dbcfg) } cfgJSONStr = `{ "data_db": { "db_type": "*internal", "db_port": -1, } }` expected = DataDbCfg{ DataDbType: "internal", DataDbPort: "internal", } if jsnCfg, err := NewCgrJsonCfgFromBytes([]byte(cfgJSONStr)); err != nil { t.Error(err) } else if jsnDataDbCfg, err := jsnCfg.DbJsonCfg(DATADB_JSN); err != nil { t.Error(err) } else if err = dbcfg.loadFromJsonCfg(jsnDataDbCfg); err != nil { t.Error(err) } else if !reflect.DeepEqual(expected, dbcfg) { t.Errorf("Expected: %+v , recived: %+v", expected, dbcfg) } } func TestDataDBRemoteReplication(t *testing.T) { var dbcfg, expected DataDbCfg cfgJSONStr := `{ "data_db": { // database used to store runtime data (eg: accounts, cdr stats) "db_type": "*redis", // data_db type: <*redis|*mongo|*internal> "db_host": "127.0.0.1", // data_db host address "db_port": -1, // data_db port to reach the database "db_name": "10", // data_db database name to connect to "db_user": "cgrates", // username to use when connecting to data_db "db_password": "password", // password to use when connecting to data_db "redis_sentinel":"sentinel", // redis_sentinel is the name of sentinel "remote_conns":[ {"address": "127.0.0.1:2022","transport":"*json"}, ], } }` expected = DataDbCfg{ DataDbType: "redis", DataDbHost: "127.0.0.1", DataDbPort: "6379", DataDbName: "10", DataDbUser: "cgrates", DataDbPass: "password", DataDbSentinelName: "sentinel", RmtConns: []*RemoteHost{ &RemoteHost{ Address: "127.0.0.1:2022", Transport: "*json", }, }, } if jsnCfg, err := NewCgrJsonCfgFromBytes([]byte(cfgJSONStr)); err != nil { t.Error(err) } else if jsnDataDbCfg, err := jsnCfg.DbJsonCfg(DATADB_JSN); err != nil { t.Error(err) } else if err = dbcfg.loadFromJsonCfg(jsnDataDbCfg); err != nil { t.Error(err) } else if !reflect.DeepEqual(expected, dbcfg) { t.Errorf("Expected: %+v ,\n recived: %+v", utils.ToJSON(expected), utils.ToJSON(dbcfg)) } cfgJSONStr = `{ "data_db": { // database used to store runtime data (eg: accounts, cdr stats) "db_type": "*internal", // data_db type: <*redis|*mongo|*internal> "remote_conns":[ {"address": "127.0.0.1:2022","transport":"*json"}, ], "replication_conns":[ {"address": "127.0.0.1:2022","transport":"*json"}, ], } }` expected = DataDbCfg{ DataDbType: utils.INTERNAL, DataDbHost: "127.0.0.1", DataDbPort: "6379", DataDbName: "10", DataDbUser: "cgrates", DataDbPass: "password", DataDbSentinelName: "sentinel", RmtConns: []*RemoteHost{ &RemoteHost{ Address: "127.0.0.1:2022", Transport: "*json", }, }, RplConns: []*RemoteHost{ &RemoteHost{ Address: "127.0.0.1:2022", Transport: "*json", }, }, } if jsnCfg, err := NewCgrJsonCfgFromBytes([]byte(cfgJSONStr)); err != nil { t.Error(err) } else if jsnDataDbCfg, err := jsnCfg.DbJsonCfg(DATADB_JSN); err != nil { t.Error(err) } else if err = dbcfg.loadFromJsonCfg(jsnDataDbCfg); err != nil { t.Error(err) } else if !reflect.DeepEqual(expected, dbcfg) { t.Errorf("Expected: %+v ,\n recived: %+v", utils.ToJSON(expected), utils.ToJSON(dbcfg)) } cfgJSONStr = `{ "data_db": { // database used to store runtime data (eg: accounts, cdr stats) "db_type": "*internal", // data_db type: <*redis|*mongo|*internal> "remote_conns":[ {"address": "127.0.0.1:2032","transport":"*json"}, {"address": "127.0.0.1:2042","transport":"*json"}, {"address": "127.0.0.1:2052","transport":"*json"}, ], "replication_conns":[ {"address": "127.0.0.1:2032","transport":"*json"}, {"address": "127.0.0.1:2042","transport":"*json"}, {"address": "127.0.0.1:2052","transport":"*json"}, ], } }` expected = DataDbCfg{ DataDbType: utils.INTERNAL, DataDbHost: "127.0.0.1", DataDbPort: "6379", DataDbName: "10", DataDbUser: "cgrates", DataDbPass: "password", DataDbSentinelName: "sentinel", RmtConns: []*RemoteHost{ &RemoteHost{ Address: "127.0.0.1:2032", Transport: "*json", }, &RemoteHost{ Address: "127.0.0.1:2042", Transport: "*json", }, &RemoteHost{ Address: "127.0.0.1:2052", Transport: "*json", }, }, RplConns: []*RemoteHost{ &RemoteHost{ Address: "127.0.0.1:2032", Transport: "*json", }, &RemoteHost{ Address: "127.0.0.1:2042", Transport: "*json", }, &RemoteHost{ Address: "127.0.0.1:2052", Transport: "*json", }, }, } if jsnCfg, err := NewCgrJsonCfgFromBytes([]byte(cfgJSONStr)); err != nil { t.Error(err) } else if jsnDataDbCfg, err := jsnCfg.DbJsonCfg(DATADB_JSN); err != nil { t.Error(err) } else if err = dbcfg.loadFromJsonCfg(jsnDataDbCfg); err != nil { t.Error(err) } else if !reflect.DeepEqual(expected, dbcfg) { t.Errorf("Expected: %+v ,\n recived: %+v", utils.ToJSON(expected), utils.ToJSON(dbcfg)) } }