/* 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 sessions import ( "reflect" "testing" "time" "github.com/cgrates/cgrates/engine" "github.com/cgrates/cgrates/utils" ) func TestSessionIDMetaOriginID(t *testing.T) { //empty check sessionID := new(SessionID) rcv := sessionID.OptsOriginID() eOut := "da39a3ee5e6b4b0d3255bfef95601890afd80709" if !reflect.DeepEqual(eOut, rcv) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } //normal check sessionID.OriginHost = "testhost" sessionID.OriginID = "testid" rcv = sessionID.OptsOriginID() eOut = "2aaff7e3e832de08b0604a79a18ccc6bba823360" if !reflect.DeepEqual(eOut, rcv) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } } func TestSessionOriginIDOpts(t *testing.T) { //empty check session := new(Session) rcv := session.originID() eOut := "" if !reflect.DeepEqual(eOut, rcv) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } //normal check session = &Session{ OptsStart: map[string]interface{}{ utils.MetaOriginID: "testID", }, } eOut = "testID" rcv = session.originID() if !reflect.DeepEqual(eOut, rcv) && session.OptsStart[utils.MetaOriginID] == "testID" { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } } func TestSessionClone(t *testing.T) { //empty check session := new(Session) rcv := session.Clone() eOut := new(Session) if !reflect.DeepEqual(eOut, rcv) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } //normal check tTime := time.Now() tTime2 := time.Date(2020, time.April, 18, 23, 0, 0, 0, time.UTC) session = &Session{ Tenant: "cgrates.org", ResourceID: "resourceID", ClientConnID: "ClientConnID", EventStart: engine.NewMapEvent(nil), DebitInterval: 18, SRuns: []*SRun{ {Event: engine.NewMapEvent(nil), ExtraDuration: 1, LastUsage: 2, TotalUsage: 3, NextAutoDebit: &tTime, }, {Event: engine.NewMapEvent(nil), ExtraDuration: 4, LastUsage: 5, TotalUsage: 6, NextAutoDebit: &tTime2, }, }, OptsStart: map[string]interface{}{ utils.MetaOriginID: "originID", }, } eOut = &Session{ Tenant: "cgrates.org", ResourceID: "resourceID", ClientConnID: "ClientConnID", EventStart: engine.NewMapEvent(nil), DebitInterval: 18, SRuns: []*SRun{ {Event: engine.NewMapEvent(nil), ExtraDuration: 1, LastUsage: 2, TotalUsage: 3, NextAutoDebit: &tTime, }, {Event: engine.NewMapEvent(nil), ExtraDuration: 4, LastUsage: 5, TotalUsage: 6, NextAutoDebit: &tTime2, }, }, OptsStart: map[string]interface{}{ utils.MetaOriginID: "originID", }, } rcv = session.Clone() if !reflect.DeepEqual(eOut, rcv) && session.OptsStart[utils.MetaOriginID] == "testID" { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } //check clone rcv.OptsStart = map[string]interface{}{ utils.MetaOriginID: "neworiginID", } if session.OptsStart[utils.MetaOriginID] == "neworiginID" { t.Errorf("Expecting: originID, received: neworiginID") } rcv.SRuns[1].TotalUsage = 10 if session.SRuns[1].TotalUsage == 10 { t.Errorf("Expecting: %s, received: %s", 3*time.Nanosecond, session.SRuns[1].TotalUsage) } tTimeNow := time.Now() *rcv.SRuns[1].NextAutoDebit = tTimeNow if *session.SRuns[1].NextAutoDebit == tTimeNow { t.Errorf("Expecting: %s, received: %s", time.Date(2020, time.April, 18, 23, 0, 0, 0, time.UTC), tTimeNow) } } func TestSessionAsCGREventsRawEvent(t *testing.T) { ev := map[string]interface{}{ utils.EventName: "TEST_EVENT", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.12, } s := &Session{ OptsStart: map[string]interface{}{ utils.MetaOriginID: "RandomoriginID", }, Tenant: "cgrates.org", EventStart: engine.NewMapEvent(ev), } if cgrEvs := s.asCGREvents(); len(cgrEvs) != 0 { t.Errorf("Expecting: 1, received: %+v", len(cgrEvs)) } } func TestSessionAsCGREvents(t *testing.T) { startEv := map[string]interface{}{ utils.EventName: "TEST_EVENT", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.12, } ev := map[string]interface{}{ utils.EventName: "TEST_EVENT2", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.13, } s := &Session{ OptsStart: map[string]interface{}{ utils.MetaOriginID: "RandomoriginID", }, Tenant: "cgrates.org", EventStart: engine.NewMapEvent(startEv), SRuns: []*SRun{{ Event: engine.NewMapEvent(ev), TotalUsage: 2 * time.Second, }}, } //check for some fields if populated correct cgrEvs := s.asCGREvents() if len(cgrEvs) != 1 { t.Errorf("Expecting: 1, received: %+v", len(cgrEvs)) } if cgrEvs[0].Event[utils.RequestType] != utils.MetaPrepaid { t.Errorf("Expecting: %+v, received: %+v", utils.MetaPrepaid, cgrEvs[1].Event[utils.RequestType]) } else if cgrEvs[0].Event[utils.Cost] != 12.13 { t.Errorf("Expecting: %+v, received: %+v", 12.13, cgrEvs[1].Event[utils.Cost]) } } func TestSessionAsExternalSessions(t *testing.T) { startEv := map[string]interface{}{ utils.EventName: "TEST_EVENT", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.12, } ev := map[string]interface{}{ utils.EventName: "TEST_EVENT2", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.MetaRunID: utils.MetaDefault, utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.13, } tTime := time.Date(2020, time.April, 18, 23, 0, 0, 0, time.UTC) s := &Session{ OptsStart: map[string]interface{}{ utils.MetaOriginID: "RandomoriginID", }, Tenant: "cgrates.org", EventStart: engine.NewMapEvent(startEv), DebitInterval: time.Second, SRuns: []*SRun{{ Event: engine.NewMapEvent(ev), TotalUsage: 2 * time.Second, NextAutoDebit: &tTime, }}, } exp := []*ExternalSession{{ //CGRID: "RandomoriginID", ToR: utils.MetaVoice, OriginID: "123451", // OriginHost: s.EventStart.GetStringIgnoreErrors(utils.OriginHost), Source: utils.SessionS + "_" + "TEST_EVENT", RequestType: utils.MetaPrepaid, Tenant: "cgrates.org", Category: "call", Account: "1001", Subject: "1001", Destination: "1004", SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), Usage: 2 * time.Second, ExtraFields: map[string]string{ utils.EventName: "TEST_EVENT2", utils.MetaRunID: utils.MetaDefault}, NodeID: "ALL", DebitInterval: time.Second, NextAutoDebit: tTime, // aSs[i].LoopIndex: sr.CD.LoopIndex, // aSs[i].DurationIndex: sr.CD.DurationIndex, // aSs[i].MaxRate: sr.CD.MaxRate, // aSs[i].MaxRateUnit: sr.CD.MaxRateUnit, // aSs[i].MaxCostSoFar: sr.CD.MaxCostSoFar, }} //check for some fields if populated correct rply := s.AsExternalSessions("", "ALL") if !reflect.DeepEqual(exp, rply) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(exp), utils.ToJSON(rply)) } } /* func TestSessionAsExternalSessions2(t *testing.T) { startEv := map[string]interface{}{ utils.EventName: "TEST_EVENT", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.12, } ev := map[string]interface{}{ utils.EventName: "TEST_EVENT2", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.RunID: utils.MetaDefault, utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.13, } s := &Session{ OptsStart: map[string]interface{}{ utils.MetaOriginID: "RandomoriginID", }, Tenant: "cgrates.org", EventStart: engine.NewMapEvent(startEv), DebitInterval: time.Second, SRuns: []*SRun{{ Event: engine.NewMapEvent(ev), TotalUsage: 2 * time.Second, }}, } exp := []*ExternalSession{{ //CGRID: "RandomCGRID", RunID: utils.MetaDefault, ToR: utils.MetaVoice, OriginID: "123451", // OriginHost: s.EventStart.GetStringIgnoreErrors(utils.OriginHost), Source: utils.SessionS + "_" + "TEST_EVENT", RequestType: utils.MetaPrepaid, Tenant: "cgrates.org", Category: "call", Account: "1001", Subject: "1001", Destination: "1004", SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), Usage: 2 * time.Second, ExtraFields: map[string]string{ utils.EventName: "TEST_EVENT2", }, NodeID: "ALL", DebitInterval: time.Second, LoopIndex: 10, DurationIndex: 3 * time.Second, MaxRate: 11, MaxRateUnit: 30 * time.Second, MaxCostSoFar: 20, }} //check for some fields if populated correct rply := s.AsExternalSessions("", "ALL") if !reflect.DeepEqual(exp, rply) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(exp), utils.ToJSON(rply)) } } func TestSessionAsExternalSessions3(t *testing.T) { startEv := map[string]interface{}{ utils.EventName: "TEST_EVENT", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.12, } ev := map[string]interface{}{ utils.EventName: "TEST_EVENT2", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.RunID: utils.MetaDefault, utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.13, } tTime := time.Date(2020, time.April, 18, 23, 0, 0, 0, time.UTC) s := &Session{ OptsStart: map[string]interface{}{ utils.MetaOriginID: "RandomCGRID", }, Tenant: "cgrates.org", EventStart: engine.NewMapEvent(startEv), DebitInterval: time.Second, SRuns: []*SRun{{ Event: engine.NewMapEvent(ev), TotalUsage: 2 * time.Second, NextAutoDebit: &tTime, }}, } exp := &ExternalSession{ CGRID: "RandomCGRID", RunID: utils.MetaDefault, ToR: utils.MetaVoice, OriginID: "123451", // OriginHost: s.EventStart.GetStringIgnoreErrors(utils.OriginHost), Source: utils.SessionS + "_" + "TEST_EVENT", RequestType: utils.MetaPrepaid, Tenant: "cgrates.org", Category: "call", Account: "1001", Subject: "1001", Destination: "1004", SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), Usage: 2 * time.Second, ExtraFields: map[string]string{ utils.EventName: "TEST_EVENT2", }, NodeID: "ALL", DebitInterval: time.Second, LoopIndex: 10, DurationIndex: 3 * time.Second, MaxRate: 11, MaxRateUnit: 30 * time.Second, MaxCostSoFar: 20, NextAutoDebit: tTime, } //check for some fields if populated correct rply := s.AsExternalSession(s.SRuns[0], "", "ALL") if !reflect.DeepEqual(exp, rply) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(exp), utils.ToJSON(rply)) } } */ func TestSessiontotalUsage(t *testing.T) { //empty check session := new(Session) rcv := session.totalUsage() eOut := time.Duration(0) if !reflect.DeepEqual(eOut, rcv) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } //normal check tTime := time.Now() tTime2 := time.Date(2020, time.April, 18, 23, 0, 0, 0, time.UTC) session = &Session{ OptsStart: map[string]interface{}{ utils.MetaOriginID: "originID", }, Tenant: "cgrates.org", ResourceID: "resourceID", ClientConnID: "ClientConnID", EventStart: engine.NewMapEvent(nil), DebitInterval: 18, SRuns: []*SRun{ { Event: engine.NewMapEvent(nil), ExtraDuration: 1, LastUsage: 2, TotalUsage: 5, NextAutoDebit: &tTime, }, { Event: engine.NewMapEvent(nil), ExtraDuration: 4, LastUsage: 5, TotalUsage: 6, NextAutoDebit: &tTime2, }, }, } eOut = 5 rcv = session.totalUsage() if !reflect.DeepEqual(eOut, rcv) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } } func TestSessionstopSTerminator(t *testing.T) { //empty check session := new(Session) rcv := session.totalUsage() eOut := time.Duration(0) if !reflect.DeepEqual(eOut, rcv) { t.Errorf("Expecting: %s, received: %s", utils.ToJSON(eOut), utils.ToJSON(rcv)) } //normal check session = &Session{ sTerminator: &sTerminator{endChan: make(chan struct{})}, } session.stopSTerminator() if session.sTerminator.endChan != nil { t.Errorf("Expecting: nil, received: %s", utils.ToJSON(session.sTerminator.endChan)) } } func TestSessionstopDebitLoops(t *testing.T) { session := &Session{ debitStop: make(chan struct{}), } session.stopDebitLoops() if session.debitStop != nil { t.Errorf("Expecting: nil, received: %s", utils.ToJSON(session.debitStop)) } } func TestUpdateSRuns(t *testing.T) { startEv := map[string]interface{}{ utils.EventName: "TEST_EVENT", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.12, } ev := map[string]interface{}{ utils.EventName: "TEST_EVENT2", utils.ToR: utils.MetaVoice, utils.OriginID: "123451", utils.AccountField: "1001", utils.Subject: "1001", utils.Destination: "1004", utils.Category: "call", utils.MetaRunID: utils.MetaDefault, utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPrepaid, utils.SetupTime: time.Date(2016, time.January, 5, 18, 30, 59, 0, time.UTC), utils.AnswerTime: time.Date(2016, time.January, 5, 18, 31, 05, 0, time.UTC), utils.Usage: 2 * time.Second, utils.Cost: 12.13, } s := &Session{ OptsStart: map[string]interface{}{ utils.MetaOriginID: "RandomOriginID", }, Tenant: "cgrates.org", EventStart: engine.NewMapEvent(startEv), DebitInterval: time.Second, SRuns: []*SRun{{ Event: engine.NewMapEvent(ev), TotalUsage: 2 * time.Second, }}, } updEv := map[string]interface{}{ utils.EventName: "TEST_EVENT2", utils.Tenant: "cgrates.org", utils.RequestType: utils.MetaPostpaid, } s.updateSRuns(updEv, utils.NewStringSet(nil)) if s.SRuns[0].Event[utils.RequestType] != utils.MetaPrepaid { t.Errorf("Expected session to not change") } s.UpdateSRuns(updEv, utils.NewStringSet(nil)) if s.SRuns[0].Event[utils.RequestType] != utils.MetaPrepaid { t.Errorf("Expected session to not change") } s.UpdateSRuns(updEv, utils.NewStringSet([]string{utils.RequestType})) if s.SRuns[0].Event[utils.RequestType] != utils.MetaPostpaid { t.Errorf("Expected request type to be: %q, received: %q", utils.MetaPostpaid, s.SRuns[0].Event[utils.RequestType]) } }