// +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 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 migrator import ( "log" "path" "reflect" "testing" "github.com/cgrates/cgrates/config" "github.com/cgrates/cgrates/engine" "github.com/cgrates/cgrates/utils" ) var ( actPlnPathIn string actPlnPathOut string actPlnCfgIn *config.CGRConfig actPlnCfgOut *config.CGRConfig actPlnMigrator *Migrator actActionPlan string ) var sTestsActPlnIT = []func(t *testing.T){ testActPlnITConnect, testActPlnITFlush, testActPlnITMigrateAndMove, } func TestActionPlanITRedis(t *testing.T) { var err error actPlnPathIn = path.Join(*dataDir, "conf", "samples", "tutmysql") actPlnCfgIn, err = config.NewCGRConfigFromPath(actPlnPathIn) if err != nil { t.Fatal(err) } actPlnPathOut = path.Join(*dataDir, "conf", "samples", "tutmysql") actPlnCfgOut, err = config.NewCGRConfigFromPath(actPlnPathOut) if err != nil { t.Fatal(err) } actActionPlan = utils.Migrate for _, stest := range sTestsActPlnIT { t.Run("TestActionPlanITMigrateRedis", stest) } actPlnMigrator.Close() } func TestActionPlanITMongo(t *testing.T) { var err error actPlnPathIn = path.Join(*dataDir, "conf", "samples", "tutmongo") actPlnCfgIn, err = config.NewCGRConfigFromPath(actPlnPathIn) if err != nil { t.Fatal(err) } actPlnPathOut = path.Join(*dataDir, "conf", "samples", "tutmongo") actPlnCfgOut, err = config.NewCGRConfigFromPath(actPlnPathOut) if err != nil { t.Fatal(err) } actActionPlan = utils.Migrate for _, stest := range sTestsActPlnIT { t.Run("TestActionPlanITMigrateMongo", stest) } actPlnMigrator.Close() } func TestActionPlanITMove(t *testing.T) { var err error actPlnPathIn = path.Join(*dataDir, "conf", "samples", "tutmongo") actPlnCfgIn, err = config.NewCGRConfigFromPath(actPlnPathIn) if err != nil { t.Fatal(err) } actPlnPathOut = path.Join(*dataDir, "conf", "samples", "tutmysql") actPlnCfgOut, err = config.NewCGRConfigFromPath(actPlnPathOut) if err != nil { t.Fatal(err) } actActionPlan = utils.Move for _, stest := range sTestsActPlnIT { t.Run("TestActionPlanITMove", stest) } actPlnMigrator.Close() } func TestActionPlanITMigrateMongo2Redis(t *testing.T) { var err error actPlnPathIn = path.Join(*dataDir, "conf", "samples", "tutmongo") actPlnCfgIn, err = config.NewCGRConfigFromPath(actPlnPathIn) if err != nil { t.Fatal(err) } actPlnPathOut = path.Join(*dataDir, "conf", "samples", "tutmysql") actPlnCfgOut, err = config.NewCGRConfigFromPath(actPlnPathOut) if err != nil { t.Fatal(err) } actActionPlan = utils.Migrate for _, stest := range sTestsActPlnIT { t.Run("TestActionPlanITMigrateMongo2Redis", stest) } actPlnMigrator.Close() } func TestActionPlanITMoveEncoding(t *testing.T) { var err error actPlnPathIn = path.Join(*dataDir, "conf", "samples", "tutmongo") actPlnCfgIn, err = config.NewCGRConfigFromPath(actPlnPathIn) if err != nil { t.Fatal(err) } actPlnPathOut = path.Join(*dataDir, "conf", "samples", "tutmongojson") actPlnCfgOut, err = config.NewCGRConfigFromPath(actPlnPathOut) if err != nil { t.Fatal(err) } actActionPlan = utils.Move for _, stest := range sTestsActPlnIT { t.Run("TestActionPlanITMoveEncoding", stest) } actPlnMigrator.Close() } func TestActionPlanITMoveEncoding2(t *testing.T) { var err error actPlnPathIn = path.Join(*dataDir, "conf", "samples", "tutmysql") actPlnCfgIn, err = config.NewCGRConfigFromPath(actPlnPathIn) if err != nil { t.Fatal(err) } actPlnPathOut = path.Join(*dataDir, "conf", "samples", "tutmysqljson") actPlnCfgOut, err = config.NewCGRConfigFromPath(actPlnPathOut) if err != nil { t.Fatal(err) } actActionPlan = utils.Move for _, stest := range sTestsActPlnIT { t.Run("TestActionPlanITMoveEncoding2", stest) } actPlnMigrator.Close() } func testActPlnITConnect(t *testing.T) { dataDBIn, err := NewMigratorDataDB(actPlnCfgIn.DataDbCfg().DataDbType, actPlnCfgIn.DataDbCfg().DataDbHost, actPlnCfgIn.DataDbCfg().DataDbPort, actPlnCfgIn.DataDbCfg().DataDbName, actPlnCfgIn.DataDbCfg().DataDbUser, actPlnCfgIn.DataDbCfg().DataDbPass, actPlnCfgIn.GeneralCfg().DBDataEncoding, config.CgrConfig().CacheCfg(), "", actPlnCfgIn.DataDbCfg().Items) if err != nil { log.Fatal(err) } dataDBOut, err := NewMigratorDataDB(actPlnCfgOut.DataDbCfg().DataDbType, actPlnCfgOut.DataDbCfg().DataDbHost, actPlnCfgOut.DataDbCfg().DataDbPort, actPlnCfgOut.DataDbCfg().DataDbName, actPlnCfgOut.DataDbCfg().DataDbUser, actPlnCfgOut.DataDbCfg().DataDbPass, actPlnCfgOut.GeneralCfg().DBDataEncoding, config.CgrConfig().CacheCfg(), "", actPlnCfgOut.DataDbCfg().Items) if err != nil { log.Fatal(err) } if reflect.DeepEqual(actPlnPathIn, actPlnPathOut) { actPlnMigrator, err = NewMigrator(dataDBIn, dataDBOut, nil, nil, false, true, false, false) } else { actPlnMigrator, err = NewMigrator(dataDBIn, dataDBOut, nil, nil, false, false, false, false) } if err != nil { log.Fatal(err) } } func testActPlnITFlush(t *testing.T) { actPlnMigrator.dmOut.DataManager().DataDB().Flush("") if err := engine.SetDBVersions(actPlnMigrator.dmOut.DataManager().DataDB()); err != nil { t.Error("Error ", err.Error()) } actPlnMigrator.dmIN.DataManager().DataDB().Flush("") if err := engine.SetDBVersions(actPlnMigrator.dmIN.DataManager().DataDB()); err != nil { t.Error("Error ", err.Error()) } } func testActPlnITMigrateAndMove(t *testing.T) { timingSlice := &engine.RITiming{ Years: utils.Years{}, Months: utils.Months{}, MonthDays: utils.MonthDays{}, WeekDays: utils.WeekDays{}, } v1actPln := &v1ActionPlans{ &v1ActionPlan{ Id: "test", AccountIds: []string{"one"}, Timing: &engine.RateInterval{ Timing: timingSlice, }, }, } actPln := &engine.ActionPlan{ Id: "test", AccountIDs: utils.StringMap{"one": true}, ActionTimings: []*engine.ActionTiming{ { Timing: &engine.RateInterval{ Timing: timingSlice, }, }, }, } switch actActionPlan { case utils.Migrate: err := actPlnMigrator.dmIN.setV1ActionPlans(v1actPln) if err != nil { t.Error("Error when setting v1 ActionPlan ", err.Error()) } currentVersion := engine.Versions{ utils.StatS: 2, utils.Thresholds: 2, utils.Accounts: 2, utils.Actions: 2, utils.ActionTriggers: 2, utils.ActionPlans: 1, utils.SharedGroups: 2, } err = actPlnMigrator.dmIN.DataManager().DataDB().SetVersions(currentVersion, false) if err != nil { t.Error("Error when setting version for ActionPlan ", err.Error()) } err, _ = actPlnMigrator.Migrate([]string{utils.MetaActionPlans}) if err != nil { t.Error("Error when migrating ActionPlan ", err.Error()) } result, err := actPlnMigrator.dmOut.DataManager().GetActionPlan((*v1actPln)[0].Id, true, utils.NonTransactional) if err != nil { t.Fatal("Error when getting ActionPlan ", err.Error()) } // compared fields, uuid is generated in ActionTiming if !reflect.DeepEqual(actPln.Id, result.Id) { t.Errorf("Expecting: %+v, received: %+v", actPln.Id, result.Id) } else if !reflect.DeepEqual(actPln.AccountIDs, result.AccountIDs) { t.Errorf("Expecting: %+v, received: %+v", actPln.AccountIDs, result.AccountIDs) } else if !reflect.DeepEqual(actPln.ActionTimings[0].Timing, result.ActionTimings[0].Timing) { t.Errorf("Expecting: %+v, received: %+v", actPln.ActionTimings[0].Timing, result.ActionTimings[0].Timing) } case utils.Move: if err := actPlnMigrator.dmIN.DataManager().SetActionPlan((*v1actPln)[0].Id, actPln, true, utils.NonTransactional); err != nil { t.Error("Error when setting ActionPlan ", err.Error()) } currentVersion := engine.CurrentDataDBVersions() err := actPlnMigrator.dmIN.DataManager().DataDB().SetVersions(currentVersion, false) if err != nil { t.Error("Error when setting version for ActionPlan ", err.Error()) } err, _ = actPlnMigrator.Migrate([]string{utils.MetaActionPlans}) if err != nil { t.Error("Error when migrating ActionPlan ", err.Error()) } result, err := actPlnMigrator.dmOut.DataManager().GetActionPlan((*v1actPln)[0].Id, true, utils.NonTransactional) if err != nil { t.Error("Error when getting ActionPlan ", err.Error()) } // compared fields, uuid is generated in ActionTiming if !reflect.DeepEqual(actPln.Id, result.Id) { t.Errorf("Expecting: %+v, received: %+v", actPln.Id, result.Id) } else if !reflect.DeepEqual(actPln.AccountIDs, result.AccountIDs) { t.Errorf("Expecting: %+v, received: %+v", actPln.AccountIDs, result.AccountIDs) } else if !reflect.DeepEqual(actPln.ActionTimings[0].Timing, result.ActionTimings[0].Timing) { t.Errorf("Expecting: %+v, received: %+v", actPln.ActionTimings[0].Timing, result.ActionTimings[0].Timing) } result, err = actPlnMigrator.dmIN.DataManager().GetActionPlan((*v1actPln)[0].Id, true, utils.NonTransactional) if err != utils.ErrNotFound { t.Error(err) } } }