mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-11 18:16:24 +05:00
1312 lines
39 KiB
Go
1312 lines
39 KiB
Go
/*
|
|
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 <http://www.gnu.org/licenses/>
|
|
*/
|
|
package engine
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/cgrates/cgrates/config"
|
|
"github.com/cgrates/cgrates/utils"
|
|
"github.com/cgrates/rpcclient"
|
|
)
|
|
|
|
func TestDmGetDestinationRemote(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RmtConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RmtConnID = "rmt"
|
|
cfg.GeneralCfg().NodeID = "node"
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheDestinations: {
|
|
Limit: 3,
|
|
Remote: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1GetDestination: func(args, reply interface{}) error {
|
|
rpl := &Destination{
|
|
Id: "nat", Prefixes: []string{"0257", "0256", "0723"},
|
|
}
|
|
*reply.(**Destination) = rpl
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
exp := &Destination{
|
|
Id: "nat", Prefixes: []string{"0257", "0256", "0723"},
|
|
}
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
if val, err := dm.GetDestination("key", false, true, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(val, exp) {
|
|
t.Errorf("expected %+v,received %+v", utils.ToJSON(exp), utils.ToJSON(val))
|
|
}
|
|
}
|
|
|
|
func TestDmGetAccountRemote(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RmtConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RmtConnID = "rmt"
|
|
cfg.GeneralCfg().NodeID = "node"
|
|
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheAccounts: {
|
|
Limit: 3,
|
|
Remote: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1GetAccount: func(args, reply interface{}) error {
|
|
rpl := &Account{
|
|
ID: "cgrates.org:exp",
|
|
UpdateTime: time.Now(),
|
|
}
|
|
*reply.(**Account) = rpl
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
exp := &Account{
|
|
ID: "cgrates.org:exp",
|
|
UpdateTime: time.Now(),
|
|
}
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
if val, err := dm.GetAccount("id"); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(val.ID, exp.ID) {
|
|
t.Errorf("expected %+v,received %+v", utils.ToJSON(exp), utils.ToJSON(val))
|
|
}
|
|
}
|
|
|
|
func TestDmGetFilterRemote(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RmtConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RmtConnID = "rmt"
|
|
cfg.GeneralCfg().NodeID = "node"
|
|
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheFilters: {
|
|
Limit: 3,
|
|
Remote: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1GetFilter: func(args, reply interface{}) error {
|
|
rpl := &Filter{
|
|
Tenant: "cgrates.org",
|
|
ID: "Filter1",
|
|
Rules: []*FilterRule{
|
|
{
|
|
Element: "~*req.Account",
|
|
Type: utils.MetaString,
|
|
Values: []string{"1001", "1002"},
|
|
},
|
|
},
|
|
ActivationInterval: &utils.ActivationInterval{
|
|
ActivationTime: time.Date(2014, 7, 14, 14, 25, 0, 0, time.UTC),
|
|
ExpiryTime: time.Date(2014, 7, 14, 14, 25, 0, 0, time.UTC),
|
|
},
|
|
}
|
|
*reply.(**Filter) = rpl
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
exp := &Filter{
|
|
Tenant: "cgrates.org",
|
|
ID: "Filter1",
|
|
Rules: []*FilterRule{
|
|
{
|
|
Element: "~*req.Account",
|
|
Type: utils.MetaString,
|
|
Values: []string{"1001", "1002"},
|
|
},
|
|
},
|
|
ActivationInterval: &utils.ActivationInterval{
|
|
ActivationTime: time.Date(2014, 7, 14, 14, 25, 0, 0, time.UTC),
|
|
ExpiryTime: time.Date(2014, 7, 14, 14, 25, 0, 0, time.UTC),
|
|
},
|
|
}
|
|
if val, err := dm.GetFilter("cgrates", "id2", false, true, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(exp.ID, val.ID) {
|
|
t.Errorf("expected %+v,received %+v", utils.ToJSON(exp), utils.ToJSON(val))
|
|
}
|
|
}
|
|
|
|
func TestDMGetThresholdRemote(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RmtConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RmtConnID = "rmt"
|
|
cfg.GeneralCfg().NodeID = "node"
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheThresholds: {
|
|
Limit: 3,
|
|
Remote: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1GetThreshold: func(args, reply interface{}) error {
|
|
rpl := &Threshold{
|
|
Tenant: "cgrates.org",
|
|
ID: "THD_ACNT_1001",
|
|
Hits: 0,
|
|
}
|
|
*reply.(**Threshold) = rpl
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
exp := &Threshold{
|
|
Tenant: "cgrates.org",
|
|
ID: "THD_ACNT_1001",
|
|
Hits: 0,
|
|
}
|
|
if val, err := dm.GetThreshold("cgrates", "id2", false, true, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(exp, val) {
|
|
t.Errorf("expected %+v,received %+v", utils.ToJSON(exp), utils.ToJSON(val))
|
|
}
|
|
}
|
|
func TestDMGetThresholdProfileRemote(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RmtConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RmtConnID = "rmt"
|
|
cfg.GeneralCfg().NodeID = "node"
|
|
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheThresholdProfiles: {
|
|
Limit: 3,
|
|
Remote: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1GetThresholdProfile: func(args, reply interface{}) error {
|
|
rpl := &ThresholdProfile{
|
|
Tenant: "cgrates.org",
|
|
ID: "ID",
|
|
}
|
|
*reply.(**ThresholdProfile) = rpl
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
exp := &ThresholdProfile{
|
|
Tenant: "cgrates.org",
|
|
ID: "ID",
|
|
}
|
|
if val, err := dm.GetThresholdProfile("cgrates", "id2", false, true, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(exp, val) {
|
|
t.Errorf("expected %+v,received %+v", utils.ToJSON(exp), utils.ToJSON(val))
|
|
}
|
|
}
|
|
|
|
func TestDMGetStatQueue(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RmtConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RmtConnID = "rmt"
|
|
cfg.GeneralCfg().NodeID = "node"
|
|
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheStatQueues: {
|
|
Limit: 3,
|
|
Remote: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1GetStatQueue: func(args, reply interface{}) error {
|
|
rpl := &StatQueue{
|
|
Tenant: "cgrates.org",
|
|
ID: "StatsID",
|
|
SQItems: []SQItem{{
|
|
EventID: "ev1",
|
|
}},
|
|
}
|
|
*reply.(**StatQueue) = rpl
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
dm.ms = &JSONMarshaler{}
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
exp := &StatQueue{
|
|
Tenant: "cgrates.org",
|
|
ID: "StatsID",
|
|
SQItems: []SQItem{{
|
|
EventID: "ev1",
|
|
}},
|
|
}
|
|
if val, err := dm.GetStatQueue("cgrates", "id2", false, true, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(exp, val) {
|
|
t.Errorf("expected %+v,received %+v", utils.ToJSON(exp), utils.ToJSON(val))
|
|
}
|
|
}
|
|
|
|
func TestRebuildReverseForPrefix(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheReverseDestinations: {
|
|
Limit: 3,
|
|
Remote: true,
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
dm := NewDataManager(db, cfg.CacheCfg(), nil)
|
|
dm.dataDB = &DataDBMock{}
|
|
db.db.Set(utils.CacheReverseDestinations, utils.ConcatenatedKey(utils.ReverseDestinationPrefix, "item1"), &Destination{}, []string{}, true, utils.NonTransactional)
|
|
if err := dm.RebuildReverseForPrefix(utils.ReverseDestinationPrefix); err == nil || err != utils.ErrNotImplemented {
|
|
t.Error(err)
|
|
}
|
|
dm.dataDB = db
|
|
if err := dm.RebuildReverseForPrefix(utils.ReverseDestinationPrefix); err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
}
|
|
|
|
func TestDMSetAccount(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheAccounts: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
acc := &Account{
|
|
ID: "vdf:broker",
|
|
BalanceMap: map[string]Balances{
|
|
utils.MetaVoice: {
|
|
&Balance{Value: 20 * float64(time.Second),
|
|
DestinationIDs: utils.NewStringMap("NAT"),
|
|
Weight: 10, RatingSubject: "rif"},
|
|
&Balance{Value: 100 * float64(time.Second),
|
|
DestinationIDs: utils.NewStringMap("RET"), Weight: 20},
|
|
}},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetAccount: func(args, reply interface{}) error {
|
|
accApiOpts, cancast := args.(AccountWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.SetAccountDrv(accApiOpts.Account)
|
|
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
dm.ms = &JSONMarshaler{}
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
if err := dm.SetAccount(acc); err != nil {
|
|
t.Error(err)
|
|
}
|
|
var dmnil *DataManager
|
|
if err = dmnil.SetAccount(acc); err == nil || err != utils.ErrNoDatabaseConn {
|
|
t.Error(err)
|
|
}
|
|
dm.dataDB = &DataDBMock{}
|
|
if err = dm.SetAccount(acc); err == nil || err != utils.ErrNotImplemented {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestDMRemoveAccount(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheAccounts: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
acc := &Account{
|
|
ID: "vdf:broker",
|
|
BalanceMap: map[string]Balances{
|
|
utils.MetaVoice: {
|
|
&Balance{Value: 20 * float64(time.Second),
|
|
DestinationIDs: utils.NewStringMap("NAT"),
|
|
Weight: 10, RatingSubject: "rif"},
|
|
&Balance{Value: 100 * float64(time.Second),
|
|
DestinationIDs: utils.NewStringMap("RET"), Weight: 20},
|
|
}},
|
|
}
|
|
if err = dm.dataDB.SetAccountDrv(acc); err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1RemoveAccount: func(args, reply interface{}) error {
|
|
strApiOpts, cancast := args.(utils.StringWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.RemoveAccountDrv(strApiOpts.Arg)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
if err = dm.RemoveAccount(acc.ID); err != nil {
|
|
t.Error(err)
|
|
}
|
|
var dmnil *DataManager
|
|
if err = dmnil.RemoveAccount(acc.ID); err == nil || err != utils.ErrNoDatabaseConn {
|
|
t.Error(err)
|
|
}
|
|
dm.dataDB = &DataDBMock{}
|
|
if err = dm.RemoveAccount(acc.ID); err == nil || err != utils.ErrNotImplemented {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestDmSetFilter(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheFilters: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
filter := &Filter{
|
|
Tenant: config.CgrConfig().GeneralCfg().DefaultTenant,
|
|
ID: "FLTR_CP_1",
|
|
Rules: []*FilterRule{
|
|
{
|
|
Type: utils.MetaString,
|
|
Element: "~*req.Charger",
|
|
Values: []string{"ChargerProfile1"},
|
|
},
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetFilter: func(args, reply interface{}) error {
|
|
fltr, cancast := args.(FilterWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.SetFilterDrv(fltr.Filter)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
if err := dm.SetFilter(filter, false); err != nil {
|
|
t.Error(err)
|
|
}
|
|
var dmnil *DataManager
|
|
if err = dmnil.SetFilter(filter, false); err == nil || err != utils.ErrNoDatabaseConn {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestDMSetThreshold(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheThresholds: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
thS := &Threshold{
|
|
Tenant: "cgrates.org",
|
|
ID: "THD_ACNT_1001",
|
|
Hits: 0,
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetThreshold: func(args, reply interface{}) error {
|
|
thS, cancast := args.(ThresholdWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.SetThresholdDrv(thS.Threshold)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
|
|
if err = dm.SetThreshold(thS); err != nil {
|
|
t.Error(err)
|
|
}
|
|
dm.dataDB = &DataDBMock{}
|
|
if err = dm.SetThreshold(thS); err == nil || err != utils.ErrNotImplemented {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestDmRemoveThreshold(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheThresholds: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
thS := &Threshold{
|
|
Tenant: "cgrates.org",
|
|
ID: "THD_ACNT_1001",
|
|
Hits: 0,
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1RemoveThreshold: func(args, reply interface{}) error {
|
|
tntApiOpts, cancast := args.(utils.TenantIDWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.RemoveThresholdDrv(tntApiOpts.TenantID.Tenant, tntApiOpts.TenantID.ID)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
if err := dm.RemoveThreshold(thS.Tenant, thS.ID); err != nil {
|
|
t.Error(err)
|
|
}
|
|
dm.dataDB = &DataDBMock{}
|
|
if err = dm.RemoveThreshold(thS.Tenant, thS.ID); err == nil || err != utils.ErrNotImplemented {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestDMReverseDestinationRemote(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheReverseDestinations: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetReverseDestination: func(args, reply interface{}) error {
|
|
dest, cancast := args.(Destination)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.SetReverseDestinationDrv(dest.Id, dest.Prefixes, utils.NonTransactional)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
dest := &Destination{
|
|
Id: "nat", Prefixes: []string{"0257", "0256", "0723"},
|
|
}
|
|
if err := dm.SetReverseDestination(dest.Id, dest.Prefixes, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
}
|
|
exp := []string{"nat"}
|
|
for _, prf := range dest.Prefixes {
|
|
if val, err := dm.dataDB.GetReverseDestinationDrv(prf, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(val, exp) {
|
|
t.Errorf("expected %v,received %v", exp, val)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestDMStatQueueRemote(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheStatQueues: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetStatQueue: func(args, reply interface{}) error {
|
|
sqApiOpts, cancast := args.(StatQueueWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.SetStatQueueDrv(nil, sqApiOpts.StatQueue)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1RemoveStatQueue: func(args, reply interface{}) error {
|
|
tntIDApiOpts, cancast := args.(utils.TenantIDWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.RemStatQueueDrv(tntIDApiOpts.Tenant, tntIDApiOpts.ID)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
sq := &StatQueue{
|
|
Tenant: "cgrates.org",
|
|
ID: "SQ1",
|
|
SQItems: []SQItem{},
|
|
SQMetrics: map[string]StatMetric{
|
|
utils.MetaTCD: &StatTCD{
|
|
Events: make(map[string]*DurationWithCompress),
|
|
},
|
|
},
|
|
}
|
|
if err := dm.SetStatQueue(sq); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if val, err := dm.GetStatQueue(sq.Tenant, sq.ID, true, false, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(val, sq) {
|
|
t.Errorf("expected %v,received %v", utils.ToJSON(sq), utils.ToJSON(val))
|
|
}
|
|
if err = dm.RemoveStatQueue(sq.Tenant, sq.ID); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if _, has := db.db.Get(utils.CacheStatQueues, utils.ConcatenatedKey(sq.Tenant, sq.ID)); has {
|
|
t.Error("should been removed")
|
|
}
|
|
}
|
|
|
|
func TestDmTimingR(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheTimings: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetTiming: func(args, reply interface{}) error {
|
|
tpTimingApiOpts, cancast := args.(utils.TPTimingWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().SetTimingDrv(tpTimingApiOpts.TPTiming)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1RemoveTiming: func(args, reply interface{}) error {
|
|
id, cancast := args.(string)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().RemoveTimingDrv(id)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
tp := &utils.TPTiming{
|
|
ID: "MIDNIGHT",
|
|
Years: utils.Years{2020, 2019},
|
|
Months: utils.Months{1, 2, 3, 4},
|
|
MonthDays: utils.MonthDays{5, 6, 7, 8},
|
|
WeekDays: utils.WeekDays{0, 1, 2, 3},
|
|
StartTime: "00:00:00",
|
|
EndTime: "00:00:01",
|
|
}
|
|
if err := dm.SetTiming(tp); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if val, err := dm.GetTiming(tp.ID, false, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(tp, val) {
|
|
t.Errorf("expected %v,received %v", utils.ToJSON(tp), utils.ToJSON(val))
|
|
}
|
|
if err = dm.RemoveTiming(tp.ID, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestDMSetActionTriggers(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheActionTriggers: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetActionTriggers: func(args, reply interface{}) error {
|
|
setActTrgAOpts, cancast := args.(SetActionTriggersArgWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().SetActionTriggersDrv(setActTrgAOpts.Key, setActTrgAOpts.Attrs)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1RemoveActionTriggers: func(args, reply interface{}) error {
|
|
strApiOpts, cancast := args.(utils.StringWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().RemoveActionTriggersDrv(strApiOpts.Arg)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
attrs := ActionTriggers{
|
|
&ActionTrigger{
|
|
Balance: &BalanceFilter{
|
|
Type: utils.StringPointer(utils.MetaMonetary)},
|
|
ThresholdValue: 2, ThresholdType: utils.TriggerMaxEventCounter,
|
|
ActionsID: "TEST_ACTIONS"}}
|
|
if err := dm.SetActionTriggers("act_ID", attrs); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if val, err := dm.GetActionTriggers("act_ID", false, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(attrs, val) {
|
|
t.Errorf("expected %v,received %v", utils.ToJSON(attrs), utils.ToJSON(val))
|
|
}
|
|
|
|
if err = dm.RemoveActionTriggers("act_ID", utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if _, has := db.db.Get(utils.CacheActionTriggers, "act_ID"); has {
|
|
t.Error("should been removed")
|
|
}
|
|
}
|
|
|
|
func TestDMResourceProfileRemote(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheResourceProfiles: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
utils.CacheResources: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetResourceProfile: func(args, reply interface{}) error {
|
|
rscPrflApiOpts, cancast := args.(ResourceProfileWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().SetResourceProfileDrv(rscPrflApiOpts.ResourceProfile)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1SetResource: func(args, reply interface{}) error {
|
|
rscApiOpts, cancast := args.(ResourceWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().SetResourceDrv(rscApiOpts.Resource)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1RemoveResourceProfile: func(args, reply interface{}) error {
|
|
tntApiOpts, cancast := args.(utils.TenantIDWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().RemoveResourceProfileDrv(tntApiOpts.Tenant, tntApiOpts.ID)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
rp := &ResourceProfile{
|
|
Tenant: "cgrates.org",
|
|
ID: "RES_ULTIMITED",
|
|
FilterIDs: []string{"*string:~*req.CustomField:UnlimitedEvent"},
|
|
ActivationInterval: &utils.ActivationInterval{
|
|
ActivationTime: time.Date(2014, 7, 14, 14, 25, 0, 0, time.UTC),
|
|
},
|
|
}
|
|
if err := dm.SetResourceProfile(rp, false); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if val, err := dm.GetResourceProfile(rp.Tenant, rp.ID, true, false, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(rp, val) {
|
|
t.Errorf("expected %v,received %v", utils.ToJSON(rp), utils.ToJSON(val))
|
|
}
|
|
expRes := &Resource{
|
|
Tenant: rp.Tenant,
|
|
ID: rp.ID,
|
|
Usages: map[string]*ResourceUsage{},
|
|
}
|
|
if val, err := dm.GetResource(rp.Tenant, rp.ID, true, false, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(expRes, val) {
|
|
t.Errorf("expected %v,received %v", utils.ToJSON(rp), utils.ToJSON(val))
|
|
}
|
|
if err := dm.RemoveResourceProfile(rp.Tenant, rp.ID, false); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if _, has := db.db.Get(utils.CacheResourceProfiles, utils.ConcatenatedKey(rp.Tenant, rp.ID)); has {
|
|
t.Error("should been removed")
|
|
}
|
|
}
|
|
|
|
func TestDmSharedGroup(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheSharedGroups: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetSharedGroup: func(args, reply interface{}) error {
|
|
shGrpApiOpts, cancast := args.(SharedGroupWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.dataDB.SetSharedGroupDrv(shGrpApiOpts.SharedGroup)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1RemoveSharedGroup: func(args, reply interface{}) error {
|
|
strApiOpts, cancast := args.(utils.StringWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().RemoveSharedGroupDrv(strApiOpts.Arg)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
sg := &SharedGroup{
|
|
Id: "SG2",
|
|
AccountParameters: map[string]*SharingParameters{
|
|
"*any": {
|
|
Strategy: "*lowest",
|
|
RatingSubject: "one",
|
|
},
|
|
},
|
|
}
|
|
if err := dm.SetSharedGroup(sg); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if val, err := dm.GetSharedGroup(sg.Id, false, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(val, sg) {
|
|
t.Errorf("expected %+v,received %+v", utils.ToJSON(sg), utils.ToJSON(val))
|
|
}
|
|
if err := dm.RemoveSharedGroup(sg.Id, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if _, has := db.db.Get(utils.CacheSharedGroups, sg.Id); has {
|
|
t.Error("should been removed")
|
|
}
|
|
}
|
|
|
|
func TestDMThresholdProfile(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheThresholdProfiles: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
utils.CacheThresholds: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetThresholdProfile: func(args, reply interface{}) error {
|
|
thPApiOpts, cancast := args.(ThresholdProfileWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().SetThresholdProfileDrv(thPApiOpts.ThresholdProfile)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1SetThreshold: func(args, reply interface{}) error {
|
|
thApiOpts, cancast := args.(ThresholdWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().SetThresholdDrv(thApiOpts.Threshold)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1RemoveThresholdProfile: func(args, reply interface{}) error {
|
|
tntApiOpts, cancast := args.(utils.TenantIDWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().RemThresholdProfileDrv(tntApiOpts.Tenant, tntApiOpts.ID)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
th := &ThresholdProfile{
|
|
Tenant: "cgrates.org",
|
|
ID: "THD_Test",
|
|
FilterIDs: []string{"*string:Account:test"},
|
|
MaxHits: -1,
|
|
MinSleep: time.Second,
|
|
Blocker: false,
|
|
Weight: 20.0,
|
|
ActionIDs: []string{"ACT_LOG"},
|
|
Async: false,
|
|
}
|
|
if err := dm.SetThresholdProfile(th, false); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if val, err := dm.GetThresholdProfile(th.Tenant, th.ID, true, false, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(th, val) {
|
|
t.Errorf("expected %v,received %v", utils.ToJSON(th), utils.ToJSON(val))
|
|
}
|
|
if err := dm.RemoveThresholdProfile(th.Tenant, th.ID, false); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if _, has := db.db.Get(utils.CacheThresholdProfiles, utils.ConcatenatedKey(th.Tenant, th.ID)); has {
|
|
t.Error("should receive error")
|
|
}
|
|
}
|
|
|
|
func TestDmDispatcherHost(t *testing.T) {
|
|
cfg := config.NewDefaultCGRConfig()
|
|
tmpDm := dm
|
|
tmp := Cache
|
|
defer func() {
|
|
config.SetCgrConfig(config.NewDefaultCGRConfig())
|
|
Cache = tmp
|
|
SetDataStorage(tmpDm)
|
|
}()
|
|
Cache.Clear(nil)
|
|
cfg.DataDbCfg().RplConns = []string{utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1)}
|
|
cfg.DataDbCfg().RplFiltered = true
|
|
cfg.DataDbCfg().Items = map[string]*config.ItemOpt{
|
|
utils.CacheDispatcherHosts: {
|
|
Limit: 3,
|
|
Replicate: true,
|
|
APIKey: "key",
|
|
RouteID: "route",
|
|
},
|
|
}
|
|
clientConn := make(chan rpcclient.ClientConnector, 1)
|
|
clientConn <- &ccMock{
|
|
calls: map[string]func(args interface{}, reply interface{}) error{
|
|
utils.ReplicatorSv1SetDispatcherHost: func(args, reply interface{}) error {
|
|
dspApiOpts, cancast := args.(DispatcherHostWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().SetDispatcherHostDrv(dspApiOpts.DispatcherHost)
|
|
return nil
|
|
},
|
|
utils.ReplicatorSv1RemoveDispatcherHost: func(args, reply interface{}) error {
|
|
tntApiOpts, cancast := args.(utils.TenantIDWithAPIOpts)
|
|
if !cancast {
|
|
return utils.ErrNotConvertible
|
|
}
|
|
dm.DataDB().RemoveDispatcherHostDrv(tntApiOpts.Tenant, tntApiOpts.ID)
|
|
return nil
|
|
},
|
|
},
|
|
}
|
|
db := NewInternalDB(nil, nil, true, cfg.DataDbCfg().Items)
|
|
connMgr := NewConnManager(cfg, map[string]chan rpcclient.ClientConnector{
|
|
utils.ConcatenatedKey(utils.MetaInternal, utils.ReplicatorSv1): clientConn,
|
|
})
|
|
dm := NewDataManager(db, cfg.CacheCfg(), connMgr)
|
|
config.SetCgrConfig(cfg)
|
|
SetDataStorage(dm)
|
|
|
|
dH := &DispatcherHost{
|
|
Tenant: "testTenant",
|
|
RemoteHost: &config.RemoteHost{
|
|
ID: "testID",
|
|
Address: rpcclient.InternalRPC,
|
|
Transport: utils.MetaInternal,
|
|
TLS: false,
|
|
},
|
|
}
|
|
if err := dm.SetDispatcherHost(dH); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if val, err := dm.GetDispatcherHost(dH.Tenant, dH.ID, true, false, utils.NonTransactional); err != nil {
|
|
t.Error(err)
|
|
} else if !reflect.DeepEqual(dH, val) {
|
|
t.Errorf("expected %v,received %v", utils.ToJSON(dH), utils.ToJSON(val))
|
|
}
|
|
if err = dm.RemoveDispatcherHost(dH.Tenant, dH.ID); err != nil {
|
|
t.Error(err)
|
|
}
|
|
if _, has := db.db.Get(utils.CacheDispatcherHosts, utils.ConcatenatedKey(dH.Tenant, dH.ID)); has {
|
|
t.Error("has not been removed from the cache")
|
|
}
|
|
}
|