/* 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" "time" "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":[ { "db_host": "0.0.0.0", // data_db host address "db_port": 1234, // data_db port to reach the database "db_name": "1", // data_db database name to connect to "db_user": "cgrates", // username to use when connecting to data_db }, ], } }` expected = DataDbCfg{ DataDbType: "redis", DataDbHost: "127.0.0.1", DataDbPort: "6379", DataDbName: "10", DataDbUser: "cgrates", DataDbPass: "password", DataDbSentinelName: "sentinel", RmtDataDBCfgs: []*DataDbCfg{ &DataDbCfg{ DataDbType: utils.REDIS, DataDbHost: "0.0.0.0", DataDbPort: "1234", DataDbName: "1", DataDbUser: "cgrates", DataDbPass: "", QueryTimeout: 10 * time.Second, RmtDataDBCfgs: nil, RplDataDBCfgs: nil, }, }, } 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":[ { "db_host": "0.0.0.0", // data_db host address "db_port": 1234, // data_db port to reach the database "db_name": "1", // data_db database name to connect to "db_user": "cgrates", // username to use when connecting to data_db }, ], "replication_conns":[ { "db_type": "*mongo", "db_host": "1.1.1.1", // data_db host address "db_port": 1234, // data_db port to reach the database "db_name": "test", // data_db database name to connect to "db_user": "user", // username to use when connecting to data_db "db_password": "pass", }, ], } }` expected = DataDbCfg{ DataDbType: utils.INTERNAL, DataDbHost: "127.0.0.1", DataDbPort: "6379", DataDbName: "10", DataDbUser: "cgrates", DataDbPass: "password", DataDbSentinelName: "sentinel", RmtDataDBCfgs: []*DataDbCfg{ &DataDbCfg{ DataDbType: utils.REDIS, DataDbHost: "0.0.0.0", DataDbPort: "1234", DataDbName: "1", DataDbUser: "cgrates", DataDbPass: "", QueryTimeout: 10 * time.Second, }, }, RplDataDBCfgs: []*DataDbCfg{ &DataDbCfg{ DataDbType: utils.MONGO, DataDbHost: "1.1.1.1", DataDbPort: "1234", DataDbName: "test", DataDbUser: "user", DataDbPass: "pass", QueryTimeout: 10 * time.Second, }, }, } 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":[ { "db_host": "0.0.0.0", // data_db host address "db_port": 1234, // data_db port to reach the database "db_name": "1", // data_db database name to connect to "db_user": "cgrates", // username to use when connecting to data_db }, { "db_type": "*mongo", "db_host": "1.2.3.4", // data_db host address "db_port": 1235, // data_db port to reach the database "db_name": "remote_mongo", // data_db database name to connect to "db_user": "remote_mongo_user", // username to use when connecting to data_db }, ], "replication_conns":[ { "db_type": "*mongo", "db_host": "1.1.1.1", // data_db host address "db_port": 1234, // data_db port to reach the database "db_name": "replication_mongo", // data_db database name to connect to "db_user": "user", // username to use when connecting to data_db "db_password": "pass", }, { "db_host": "127.0.0.1", // data_db host address "db_port": 8888, // data_db port to reach the database "db_name": "15", // data_db database name to connect to }, ], } }` expected = DataDbCfg{ DataDbType: utils.INTERNAL, DataDbHost: "127.0.0.1", DataDbPort: "6379", DataDbName: "10", DataDbUser: "cgrates", DataDbPass: "password", DataDbSentinelName: "sentinel", RmtDataDBCfgs: []*DataDbCfg{ &DataDbCfg{ DataDbType: utils.REDIS, DataDbHost: "0.0.0.0", DataDbPort: "1234", DataDbName: "1", DataDbUser: "cgrates", DataDbPass: "", QueryTimeout: 10 * time.Second, }, &DataDbCfg{ DataDbType: utils.MONGO, DataDbHost: "1.2.3.4", DataDbPort: "1235", DataDbName: "remote_mongo", DataDbUser: "remote_mongo_user", DataDbPass: "", QueryTimeout: 10 * time.Second, }, }, RplDataDBCfgs: []*DataDbCfg{ &DataDbCfg{ DataDbType: utils.MONGO, DataDbHost: "1.1.1.1", DataDbPort: "1234", DataDbName: "replication_mongo", DataDbUser: "user", DataDbPass: "pass", QueryTimeout: 10 * time.Second, }, &DataDbCfg{ DataDbType: utils.REDIS, DataDbHost: "127.0.0.1", DataDbPort: "8888", DataDbName: "15", DataDbUser: "cgrates", DataDbPass: "", QueryTimeout: 10 * time.Second, }, }, } 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)) } }