mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-11 18:16:24 +05:00
220 lines
6.7 KiB
Go
220 lines
6.7 KiB
Go
//go:build integration
|
|
// +build integration
|
|
|
|
/*
|
|
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 Affero 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 Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>
|
|
*/
|
|
|
|
package migrator
|
|
|
|
import (
|
|
"path"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/cgrates/cgrates/config"
|
|
"github.com/cgrates/cgrates/engine"
|
|
"github.com/cgrates/cgrates/utils"
|
|
)
|
|
|
|
var (
|
|
sCostPathIn string
|
|
sCostPathOut string
|
|
sCostCfgIn *config.CGRConfig
|
|
sCostCfgOut *config.CGRConfig
|
|
sCostMigrator *Migrator
|
|
sCostAction string
|
|
)
|
|
|
|
var sTestssCostIT = []func(t *testing.T){
|
|
testSessionCostITConnect,
|
|
testSessionCostITRename,
|
|
testSessionCostITFlush,
|
|
testSessionCostITMigrate,
|
|
}
|
|
|
|
func TestSessionCostITMongo(t *testing.T) {
|
|
var err error
|
|
sCostPathIn = path.Join(*utils.DataDir, "conf", "samples", "tutmongo")
|
|
sCostCfgIn, err = config.NewCGRConfigFromPath(sCostPathIn)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
sCostPathOut = path.Join(*utils.DataDir, "conf", "samples", "tutmongojson")
|
|
sCostCfgOut, err = config.NewCGRConfigFromPath(sCostPathOut)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
for _, stest := range sTestssCostIT {
|
|
t.Run("TestSessionSCostITMigrateMongo", stest)
|
|
}
|
|
sCostMigrator.Close()
|
|
}
|
|
|
|
func TestSessionCostITMySql(t *testing.T) {
|
|
var err error
|
|
sCostPathIn = path.Join(*utils.DataDir, "conf", "samples", "tutmysql")
|
|
sCostCfgIn, err = config.NewCGRConfigFromPath(sCostPathIn)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
sCostPathOut = path.Join(*utils.DataDir, "conf", "samples", "tutmysql")
|
|
sCostCfgOut, err = config.NewCGRConfigFromPath(sCostPathOut)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
for _, stest := range sTestssCostIT {
|
|
t.Run("TestSessionSCostITMigrateMySql", stest)
|
|
}
|
|
sCostMigrator.Close()
|
|
}
|
|
|
|
func testSessionCostITConnect(t *testing.T) {
|
|
storDBIn, err := NewMigratorStorDB(sCostCfgIn.StorDbCfg().Type,
|
|
sCostCfgIn.StorDbCfg().Host, sCostCfgIn.StorDbCfg().Port,
|
|
sCostCfgIn.StorDbCfg().Name, sCostCfgIn.StorDbCfg().User,
|
|
sCostCfgIn.StorDbCfg().Password, sCostCfgIn.GeneralCfg().DBDataEncoding,
|
|
sCostCfgIn.StorDbCfg().StringIndexedFields, sCostCfgIn.StorDbCfg().PrefixIndexedFields,
|
|
sCostCfgIn.StorDbCfg().Opts, nil)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
storDBOut, err := NewMigratorStorDB(sCostCfgOut.StorDbCfg().Type,
|
|
sCostCfgOut.StorDbCfg().Host, sCostCfgOut.StorDbCfg().Port,
|
|
sCostCfgOut.StorDbCfg().Name, sCostCfgOut.StorDbCfg().User,
|
|
sCostCfgOut.StorDbCfg().Password, sCostCfgOut.GeneralCfg().DBDataEncoding,
|
|
sCostCfgIn.StorDbCfg().StringIndexedFields, sCostCfgIn.StorDbCfg().PrefixIndexedFields,
|
|
sCostCfgOut.StorDbCfg().Opts, nil)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if actTrgPathIn == actTrgPathOut {
|
|
sCostMigrator, err = NewMigrator(nil, nil, storDBIn, storDBOut,
|
|
false, false, true, false)
|
|
} else {
|
|
sCostMigrator, err = NewMigrator(nil, nil, storDBIn, storDBOut,
|
|
false, false, false, false)
|
|
}
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func testSessionCostITRename(t *testing.T) {
|
|
var err error
|
|
if err = sCostMigrator.storDBIn.createV1SMCosts(); err != nil {
|
|
t.Error(err)
|
|
}
|
|
currentVersion := engine.Versions{
|
|
utils.SessionSCosts: 1,
|
|
}
|
|
err = sCostMigrator.storDBIn.StorDB().SetVersions(currentVersion, false)
|
|
if err != nil {
|
|
t.Error("Error when setting version for SessionsCosts ", err.Error())
|
|
}
|
|
if vrs, err := sCostMigrator.storDBIn.StorDB().GetVersions(""); err != nil {
|
|
t.Error(err)
|
|
} else if vrs[utils.SessionSCosts] != 1 {
|
|
t.Errorf("Unexpected version returned: %d", vrs[utils.SessionSCosts])
|
|
}
|
|
_, err = sCostMigrator.Migrate([]string{utils.MetaSessionsCosts})
|
|
if err != nil {
|
|
t.Error("Error when migrating SessionsCosts ", err.Error())
|
|
}
|
|
if vrs, err := sCostMigrator.storDBOut.StorDB().GetVersions(""); err != nil {
|
|
t.Error(err)
|
|
} else if vrs[utils.SessionSCosts] != 2 {
|
|
t.Errorf("Unexpected version returned: %d", vrs[utils.SessionSCosts])
|
|
} else if sCostMigrator.stats[utils.SessionSCosts] != 0 {
|
|
t.Errorf("Expected 0, received: %v", sCostMigrator.stats[utils.SessionSCosts])
|
|
}
|
|
|
|
}
|
|
|
|
func testSessionCostITFlush(t *testing.T) {
|
|
if err := sCostMigrator.storDBOut.StorDB().Flush(
|
|
path.Join(sCostCfgIn.DataFolderPath, "storage", dbPath(sCostCfgIn.StorDbCfg().Type))); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func testSessionCostITMigrate(t *testing.T) {
|
|
cc := &engine.CallCost{
|
|
Cost: 1.23,
|
|
Destination: "0723045326",
|
|
Timespans: []*engine.TimeSpan{
|
|
{
|
|
TimeStart: time.Date(2013, 9, 24, 10, 48, 0, 0, time.UTC),
|
|
TimeEnd: time.Date(2013, 9, 24, 10, 48, 10, 0, time.UTC),
|
|
DurationIndex: 0,
|
|
RateInterval: &engine.RateInterval{
|
|
Rating: &engine.RIRate{
|
|
Rates: engine.RateGroups{
|
|
&engine.RGRate{
|
|
GroupIntervalStart: 0,
|
|
Value: 100,
|
|
RateIncrement: 10 * time.Second,
|
|
RateUnit: time.Second,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ToR: utils.MetaVoice,
|
|
}
|
|
v2Cost := &v2SessionsCost{
|
|
CGRID: utils.Sha1("dsafdsaf", time.Date(2013, 11, 7, 8, 42, 20, 0, time.UTC).String()),
|
|
OriginID: "dsafdsaf",
|
|
OriginHost: "192.168.1.1",
|
|
RunID: utils.MetaDefault,
|
|
Usage: 10,
|
|
CostSource: utils.MetaSessionS,
|
|
CostDetails: cc,
|
|
}
|
|
var err error
|
|
if err = sCostMigrator.storDBIn.setV2SMCost(v2Cost); err != nil {
|
|
t.Error(err)
|
|
}
|
|
currentVersion := engine.Versions{
|
|
utils.SessionSCosts: 2,
|
|
}
|
|
err = sCostMigrator.storDBIn.StorDB().SetVersions(currentVersion, false)
|
|
if err != nil {
|
|
t.Error("Error when setting version for SessionsCosts ", err.Error())
|
|
}
|
|
if vrs, err := sCostMigrator.storDBIn.StorDB().GetVersions(""); err != nil {
|
|
t.Error(err)
|
|
} else if vrs[utils.SessionSCosts] != 2 {
|
|
t.Errorf("Unexpected version returned: %d", vrs[utils.SessionSCosts])
|
|
}
|
|
_, err = sCostMigrator.Migrate([]string{utils.MetaSessionsCosts})
|
|
if err != nil {
|
|
t.Error("Error when migrating SessionsCosts ", err.Error())
|
|
}
|
|
if rcvCosts, err := sCostMigrator.storDBOut.StorDB().GetSMCosts("", utils.MetaDefault, "", ""); err != nil {
|
|
t.Error(err)
|
|
} else if len(rcvCosts) != 1 {
|
|
t.Errorf("Unexpected number of SessionsCosts returned: %d", len(rcvCosts))
|
|
}
|
|
if vrs, err := sCostMigrator.storDBOut.StorDB().GetVersions(""); err != nil {
|
|
t.Error(err)
|
|
} else if vrs[utils.SessionSCosts] != 3 {
|
|
t.Errorf("Unexpected version returned: %d", vrs[utils.SessionSCosts])
|
|
}
|
|
}
|