Cover funcs in engine/chargers.go

This commit is contained in:
ionutboangiu
2021-04-19 17:22:30 +03:00
committed by Dan Christian Bogos
parent 7548952a79
commit 4dbfb82084
3 changed files with 160 additions and 54 deletions

View File

@@ -486,3 +486,146 @@ func TestChargerProcessEvent(t *testing.T) {
t.Errorf("Expecting: %+v, received: %+v ", utils.ToJSON(rpl[0]), utils.ToJSON(rcv[0]))
}
}
func TestChargersmatchingChargerProfilesForEventChargerProfileNotFound(t *testing.T) {
defaultCfg := config.NewDefaultCGRConfig()
defaultCfg.ChargerSCfg().StringIndexedFields = &[]string{
"string",
}
defaultCfg.ChargerSCfg().PrefixIndexedFields = &[]string{"prefix"}
defaultCfg.ChargerSCfg().SuffixIndexedFields = &[]string{"suffix"}
defaultCfg.ChargerSCfg().IndexedSelects = false
defaultCfg.ChargerSCfg().NestedFields = false
dataDB := NewInternalDB(nil, nil, true)
dmCharger := NewDataManager(dataDB, config.CgrConfig().CacheCfg(), nil)
cS := &ChargerService{
dm: dmCharger,
filterS: &FilterS{
dm: dmCharger,
cfg: defaultCfg,
},
cfg: defaultCfg,
}
cgrEv := &utils.CGREvent{
Tenant: config.CgrConfig().GeneralCfg().DefaultTenant,
ID: "cgrEvID",
Event: map[string]interface{}{
"Charger": "ChargerProfile1",
utils.AnswerTime: time.Date(2021, 4, 1, 10, 0, 0, 0, time.UTC),
"UsageInterval": "1s",
utils.Weight: "10.0",
},
APIOpts: map[string]interface{}{
utils.Subsys: utils.MetaChargers,
},
}
experr := utils.ErrNotFound
rcv, err := cS.matchingChargerProfilesForEvent("tnt", cgrEv)
if err == nil || err != experr {
t.Fatalf("\nexpected: <%+v>, \nreceived: <%+v>", experr, err)
}
if rcv != nil {
t.Errorf("\nexpected: <%+v>, \nreceived: <%+v>", nil, rcv)
}
}
func TestChargersmatchingChargerProfilesForEventDoesNotPass(t *testing.T) {
defaultCfg := config.NewDefaultCGRConfig()
defaultCfg.ChargerSCfg().StringIndexedFields = &[]string{
"string",
}
defaultCfg.ChargerSCfg().PrefixIndexedFields = &[]string{"prefix"}
defaultCfg.ChargerSCfg().SuffixIndexedFields = &[]string{"suffix"}
defaultCfg.ChargerSCfg().IndexedSelects = false
defaultCfg.ChargerSCfg().NestedFields = false
dataDB := NewInternalDB(nil, nil, true)
dmCharger := NewDataManager(dataDB, config.CgrConfig().CacheCfg(), nil)
cS := &ChargerService{
dm: dmCharger,
filterS: &FilterS{
dm: dmCharger,
cfg: defaultCfg,
},
cfg: defaultCfg,
}
cgrEv := &utils.CGREvent{
Tenant: config.CgrConfig().GeneralCfg().DefaultTenant,
ID: "cgrEvID",
Event: map[string]interface{}{
"Charger": "ChargerProfile1",
utils.AnswerTime: time.Date(2021, 4, 1, 10, 0, 0, 0, time.UTC),
"UsageInterval": "1s",
utils.Weight: "10.0",
},
APIOpts: map[string]interface{}{
utils.Subsys: utils.MetaChargers,
},
}
experr := utils.ErrNotFound
rcv, err := cS.matchingChargerProfilesForEvent(cgrEv.Tenant, cgrEv)
if err == nil || err != experr {
t.Fatalf("\nexpected: <%+v>, \nreceived: <%+v>", experr, err)
}
if rcv != nil {
t.Errorf("\nexpected: <%+v>, \nreceived: <%+v>", nil, rcv)
}
}
func TestChargersmatchingChargerProfilesForEventErrGetChPrf(t *testing.T) {
defaultCfg := config.NewDefaultCGRConfig()
defaultCfg.ChargerSCfg().StringIndexedFields = &[]string{
"string",
}
defaultCfg.ChargerSCfg().PrefixIndexedFields = &[]string{"prefix"}
defaultCfg.ChargerSCfg().SuffixIndexedFields = &[]string{"suffix"}
defaultCfg.ChargerSCfg().IndexedSelects = false
defaultCfg.ChargerSCfg().NestedFields = false
dbm := &DataDBMock{
GetKeysForPrefixF: func(s string) ([]string, error) {
return []string{":"}, nil
},
}
dmCharger := NewDataManager(dbm, defaultCfg.CacheCfg(), nil)
cS := &ChargerService{
dm: dmCharger,
filterS: &FilterS{
dm: dmCharger,
cfg: defaultCfg,
},
cfg: defaultCfg,
}
cgrEv := &utils.CGREvent{
Tenant: config.CgrConfig().GeneralCfg().DefaultTenant,
ID: "cgrEvID",
Event: map[string]interface{}{
"Charger": "ChargerProfile1",
utils.AnswerTime: time.Date(2021, 4, 1, 10, 0, 0, 0, time.UTC),
"UsageInterval": "1s",
utils.Weight: "10.0",
},
APIOpts: map[string]interface{}{
utils.Subsys: utils.MetaChargers,
},
}
experr := utils.ErrNotImplemented
rcv, err := cS.matchingChargerProfilesForEvent(cgrEv.Tenant, cgrEv)
if err == nil || err != experr {
t.Fatalf("\nexpected: <%+v>, \nreceived: <%+v>", experr, err)
}
if rcv != nil {
t.Errorf("\nexpected: <%+v>, \nreceived: <%+v>", nil, rcv)
}
}

View File

@@ -22,7 +22,11 @@ import (
"github.com/cgrates/cgrates/utils"
)
type DataDBMock struct{}
type DataDBMock struct {
GetKeysForPrefixF func(string) ([]string, error)
GetChargerProfileDrvF func(string, string) (*ChargerProfile, error)
GetFilterDrvF func(string, string) (*Filter, error)
}
//Storage methods
func (dbM *DataDBMock) Close() {}
@@ -31,7 +35,10 @@ func (dbM *DataDBMock) Flush(string) error {
return utils.ErrNotImplemented
}
func (dbM *DataDBMock) GetKeysForPrefix(string) ([]string, error) {
func (dbM *DataDBMock) GetKeysForPrefix(prf string) ([]string, error) {
if dbM.GetKeysForPrefixF != nil {
return dbM.GetKeysForPrefixF(prf)
}
return nil, utils.ErrNotImplemented
}
@@ -298,7 +305,10 @@ func (dbM *DataDBMock) RemoveThresholdDrv(string, string) error {
return utils.ErrNotImplemented
}
func (dbM *DataDBMock) GetFilterDrv(string, string) (*Filter, error) {
func (dbM *DataDBMock) GetFilterDrv(tnt string, id string) (*Filter, error) {
if dbM.GetFilterDrvF != nil {
return dbM.GetFilterDrvF(tnt, id)
}
return nil, utils.ErrNotImplemented
}
@@ -334,7 +344,10 @@ func (dbM *DataDBMock) RemoveAttributeProfileDrv(string, string) error {
return utils.ErrNotImplemented
}
func (dbM *DataDBMock) GetChargerProfileDrv(string, string) (*ChargerProfile, error) {
func (dbM *DataDBMock) GetChargerProfileDrv(tnt string, id string) (*ChargerProfile, error) {
if dbM.GetChargerProfileDrvF != nil {
return dbM.GetChargerProfileDrvF(tnt, id)
}
return nil, utils.ErrNotImplemented
}

View File

@@ -4524,41 +4524,6 @@ func TestECTrimFailDetectLastActiveChargingInterval(t *testing.T) {
}
}
// func TestECTrim2(t *testing.T) {
// ec := &EventCost{
// Usage: utils.DurationPointer(30 * time.Second),
// AccountSummary: &AccountSummary{},
// Charges: []*ChargingInterval{
// {
// RatingID: "RT_ID1",
// cost: utils.Float64Pointer(10),
// ecUsageIdx: utils.DurationPointer(12 * time.Second),
// CompressFactor: 0,
// usage: utils.DurationPointer(45 * time.Second),
// },
// {
// RatingID: "RT_ID2",
// cost: utils.Float64Pointer(10),
// ecUsageIdx: utils.DurationPointer(8 * time.Second),
// CompressFactor: 0,
// usage: utils.DurationPointer(45 * time.Second),
// },
// },
// }
// atUsage := 13 * time.Second
// experr := "failed detecting last active ChargingInterval"
// rcv, err := ec.Trim(atUsage)
// if err == nil || err.Error() != experr {
// t.Fatalf("\nexpected: <%+v>, \nreceived: <%+v>", experr, err)
// }
// if rcv != nil {
// t.Errorf("\nexpected: <%+v>, \nreceived: <%+v>", nil, rcv)
// }
// }
func TestECFieldAsInterfaceEmptyFieldPath(t *testing.T) {
ec := &EventCost{}
fldPath := []string{}
@@ -4604,18 +4569,3 @@ func TestECfieldAsInterfaceNilECCost(t *testing.T) {
t.Errorf("\nexpected: <%+v>, \nreceived: <%+v>", nil, rcv)
}
}
// func TestECfieldAsInterfaceUnsupportedField(t *testing.T) {
// ec := &EventCost{}
// fldPath := []string{utils.Charges}
// rcv, err := ec.fieldAsInterface(fldPath)
// if err != nil {
// t.Fatalf("\nexpected: <%+v>, \nreceived: <%+v>", nil, err)
// }
// if rcv != nil {
// t.Errorf("\nexpected: <%+v>, \nreceived: <%+v>", nil, rcv)
// }
// }