Added integration tests for CacheSv1 methods from DispatcherSv1

This commit is contained in:
Trial97
2019-03-18 16:50:35 +02:00
committed by Dan Christian Bogos
parent ac31d88d43
commit 2c2860ae82
3 changed files with 362 additions and 1 deletions

View File

@@ -1327,7 +1327,9 @@ func main() {
// init cache
cacheS := engine.NewCacheS(cfg, dm)
server.RpcRegister(v1.NewCacheSv1(cacheS)) // before pre-caching so we can check status via API
if !cfg.DispatcherSCfg().Enabled {
server.RpcRegister(v1.NewCacheSv1(cacheS)) // before pre-caching so we can check status via API
}
go func() {
if err := cacheS.Precache(); err != nil {
errCGR := err.(*utils.CGRError)

View File

@@ -9,3 +9,4 @@ cgrates.org,ATTR_API_STAT_AUTH,*auth,*string:~APIKey:stat12345,,,APIMethods,Stat
cgrates.org,ATTR_API_RES_AUTH,*auth,*string:~APIKey:res12345,,,APIMethods,ResourceSv1.Ping&ResourceSv1.GetResourcesForEvent&ResourceSv1.AuthorizeResources&ResourceSv1.AllocateResources&ResourceSv1.ReleaseResources,false,20
cgrates.org,ATTR_API_SES_AUTH,*auth,*string:~APIKey:ses12345,,,APIMethods,SessionSv1.Ping&SessionSv1.AuthorizeEventWithDigest&SessionSv1.InitiateSessionWithDigest&SessionSv1.UpdateSession&SessionSv1.TerminateSession&SessionSv1.ProcessCDR&SessionSv1.ProcessEvent&SessionSv1.GetActiveSessions&SessionSv1.GetActiveSessionsCount&SessionSv1.ForceDisconnect&SessionSv1.GetPassiveSessions&SessionSv1.GetPassiveSessionsCount&SessionSv1.SetPassiveSession&SessionSv1.ReplicateSessions,false,20
cgrates.org,ATTR_API_RSP_AUTH,*auth,*string:~APIKey:rsp12345,,,APIMethods,Responder.Status&Responder.GetTimeout&Responder.Shutdown,false,20
cgrates.org,ATTR_API_CHC_AUTH,*auth,*string:~APIKey:chc12345,,,APIMethods,CacheSv1.Ping&CacheSv1.GetCacheStats&CacheSv1.LoadCache&CacheSv1.PrecacheStatus&CacheSv1.GetItemIDs&CacheSv1.HasItem&CacheSv1.GetItemExpiryTime&CacheSv1.ReloadCache&CacheSv1.RemoveItem&CacheSv1.FlushCache&CacheSv1.Clear,false,20
1 #Tenant ID Contexts FilterIDs ActivationInterval AttributeFilterIDs FieldName Substitute Blocker Weight
9 cgrates.org ATTR_API_RES_AUTH *auth *string:~APIKey:res12345 APIMethods ResourceSv1.Ping&ResourceSv1.GetResourcesForEvent&ResourceSv1.AuthorizeResources&ResourceSv1.AllocateResources&ResourceSv1.ReleaseResources false 20
10 cgrates.org ATTR_API_SES_AUTH *auth *string:~APIKey:ses12345 APIMethods SessionSv1.Ping&SessionSv1.AuthorizeEventWithDigest&SessionSv1.InitiateSessionWithDigest&SessionSv1.UpdateSession&SessionSv1.TerminateSession&SessionSv1.ProcessCDR&SessionSv1.ProcessEvent&SessionSv1.GetActiveSessions&SessionSv1.GetActiveSessionsCount&SessionSv1.ForceDisconnect&SessionSv1.GetPassiveSessions&SessionSv1.GetPassiveSessionsCount&SessionSv1.SetPassiveSession&SessionSv1.ReplicateSessions false 20
11 cgrates.org ATTR_API_RSP_AUTH *auth *string:~APIKey:rsp12345 APIMethods Responder.Status&Responder.GetTimeout&Responder.Shutdown false 20
12 cgrates.org ATTR_API_CHC_AUTH *auth *string:~APIKey:chc12345 APIMethods CacheSv1.Ping&CacheSv1.GetCacheStats&CacheSv1.LoadCache&CacheSv1.PrecacheStatus&CacheSv1.GetItemIDs&CacheSv1.HasItem&CacheSv1.GetItemExpiryTime&CacheSv1.ReloadCache&CacheSv1.RemoveItem&CacheSv1.FlushCache&CacheSv1.Clear false 20

View File

@@ -0,0 +1,358 @@
// +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 <http://www.gnu.org/licenses/>
*/
package dispatchers
import (
"reflect"
"testing"
"time"
"github.com/cgrates/cgrates/engine"
"github.com/cgrates/cgrates/utils"
"github.com/cgrates/ltcache"
)
var sTestsDspChc = []func(t *testing.T){
testDspChcPing,
testDspChcLoadAfterFolder,
testDspChcPrecacheStatus,
testDspChcGetItemIDs,
testDspChcHasItem,
testDspChcGetItemExpiryTime,
testDspChcReloadCache,
testDspChcRemoveItem,
testDspChcClear,
testDspChcFlush,
}
//Test start here
func TestDspCacheSv1TMySQL(t *testing.T) {
testDsp(t, sTestsDspChc, "TestDspCacheSv1", "all", "all2", "attributes", "dispatchers", "tutorial", "oldtutorial", "dispatchers")
}
func TestDspCacheSv1Mongo(t *testing.T) {
testDsp(t, sTestsDspChc, "TestDspCacheSv1", "all", "all2", "attributes_mongo", "dispatchers_mongo", "tutorial", "oldtutorial", "dispatchers")
}
func testDspChcPing(t *testing.T) {
var reply string
if err := allEngine.RCP.Call(utils.CacheSv1Ping, new(utils.CGREvent), &reply); err != nil {
t.Error(err)
} else if reply != utils.Pong {
t.Errorf("Received: %s", reply)
}
if dispEngine.RCP == nil {
t.Fatal(dispEngine.RCP)
}
if err := dispEngine.RCP.Call(utils.CacheSv1Ping, &CGREvWithApiKey{
CGREvent: utils.CGREvent{
Tenant: "cgrates.org",
},
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
}, &reply); err != nil {
t.Error(err)
} else if reply != utils.Pong {
t.Errorf("Received: %s", reply)
}
}
func testDspChcLoadAfterFolder(t *testing.T) {
var rcvStats map[string]*ltcache.CacheStats
expStats := engine.GetDefaultEmptyCacheStats()
expStats[utils.CacheAccountActionPlans].Items = 3
expStats[utils.CacheActionPlans].Items = 1
expStats[utils.CacheDestinations].Items = 4
args := AttrCacheIDsWithApiKey{
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}
if err := dispEngine.RCP.Call(utils.CacheSv1GetCacheStats, args, &rcvStats); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(expStats, rcvStats) {
t.Errorf("Expecting: %+v, received: %+v", utils.ToJSON(expStats), utils.ToJSON(rcvStats))
}
reply := ""
// Simple test that command is executed without errors
if err := dispEngine.RCP.Call(utils.CacheSv1LoadCache, AttrReloadCacheWithApiKey{
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}, &reply); err != nil {
t.Error(err)
} else if reply != "OK" {
t.Error(reply)
}
expStats[utils.CacheActions].Items = 2
expStats[utils.CacheAttributeProfiles].Items = 9
expStats[utils.CacheChargerProfiles].Items = 1
expStats[utils.CacheFilters].Items = 7
expStats[utils.CacheRatingPlans].Items = 5
expStats[utils.CacheRatingProfiles].Items = 4
expStats[utils.CacheResourceProfiles].Items = 1
expStats[utils.CacheResources].Items = 1
expStats[utils.CacheReverseDestinations].Items = 4
expStats[utils.CacheStatQueueProfiles].Items = 2
expStats[utils.CacheStatQueues].Items = 2
expStats[utils.CacheSupplierProfiles].Items = 3
expStats[utils.CacheThresholdProfiles].Items = 2
expStats[utils.CacheThresholds].Items = 2
if err := dispEngine.RCP.Call(utils.CacheSv1GetCacheStats, &args, &rcvStats); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(expStats, rcvStats) {
t.Errorf("Expecting: %+v, received: %+v", utils.ToJSON(expStats), utils.ToJSON(rcvStats))
}
}
func testDspChcPrecacheStatus(t *testing.T) {
var reply map[string]string
expected := map[string]string{
utils.CacheDestinations: utils.MetaReady,
utils.CacheReverseDestinations: utils.MetaReady,
utils.CacheRatingPlans: utils.MetaReady,
utils.CacheRatingProfiles: utils.MetaReady,
utils.CacheActions: utils.MetaReady,
utils.CacheActionPlans: utils.MetaReady,
utils.CacheAccountActionPlans: utils.MetaReady,
utils.CacheActionTriggers: utils.MetaReady,
utils.CacheSharedGroups: utils.MetaReady,
utils.CacheResourceProfiles: utils.MetaReady,
utils.CacheResources: utils.MetaReady,
utils.CacheEventResources: utils.MetaReady,
utils.CacheTimings: utils.MetaReady,
utils.CacheStatQueueProfiles: utils.MetaReady,
utils.CacheStatQueues: utils.MetaReady,
utils.CacheThresholdProfiles: utils.MetaReady,
utils.CacheThresholds: utils.MetaReady,
utils.CacheFilters: utils.MetaReady,
utils.CacheSupplierProfiles: utils.MetaReady,
utils.CacheAttributeProfiles: utils.MetaReady,
utils.CacheChargerProfiles: utils.MetaReady,
utils.CacheDispatcherProfiles: utils.MetaReady,
utils.CacheDiameterMessages: utils.MetaReady,
utils.CacheAttributeFilterIndexes: utils.MetaReady,
utils.CacheResourceFilterIndexes: utils.MetaReady,
utils.CacheStatFilterIndexes: utils.MetaReady,
utils.CacheThresholdFilterIndexes: utils.MetaReady,
utils.CacheSupplierFilterIndexes: utils.MetaReady,
utils.CacheChargerFilterIndexes: utils.MetaReady,
utils.CacheDispatcherFilterIndexes: utils.MetaReady,
}
if err := dispEngine.RCP.Call(utils.CacheSv1PrecacheStatus, AttrCacheIDsWithApiKey{
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}, &reply); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(expected, reply) {
t.Errorf("Expected: %v , received:%v", utils.ToJSON(expected), utils.ToJSON(reply))
}
}
func testDspChcGetItemIDs(t *testing.T) {
var rcvKeys []string
expKeys := []string{"cgrates.org:DEFAULT"}
argsAPI := ArgsGetCacheItemIDsWithApiKey{
ArgsGetCacheItemIDs: engine.ArgsGetCacheItemIDs{
CacheID: utils.CacheChargerProfiles,
},
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}
if err := dispEngine.RCP.Call(utils.CacheSv1GetItemIDs, argsAPI, &rcvKeys); err != nil {
t.Fatalf("Got error on ApierV1.GetCacheStats: %s ", err.Error())
}
if !reflect.DeepEqual(expKeys, rcvKeys) {
t.Errorf("Expected: %+v, received: %+v", expKeys, rcvKeys)
}
}
func testDspChcHasItem(t *testing.T) {
var reply bool
expected := true
argsAPI := ArgsGetCacheItemWithApiKey{
ArgsGetCacheItem: engine.ArgsGetCacheItem{
CacheID: utils.CacheChargerProfiles,
ItemID: "cgrates.org:DEFAULT",
},
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}
if err := dispEngine.RCP.Call(utils.CacheSv1HasItem, argsAPI, &reply); err != nil {
t.Error(err)
} else if !reply {
t.Errorf("Expected: %v , received:%v", expected, reply)
}
}
func testDspChcGetItemExpiryTime(t *testing.T) {
var reply time.Time
var expected time.Time
argsAPI := ArgsGetCacheItemWithApiKey{
ArgsGetCacheItem: engine.ArgsGetCacheItem{
CacheID: utils.CacheChargerProfiles,
ItemID: "cgrates.org:DEFAULT",
},
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}
if err := dispEngine.RCP.Call(utils.CacheSv1GetItemExpiryTime, argsAPI, &reply); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(expected, reply) {
t.Errorf("Expected: %v , received:%v", expected, reply)
}
}
func testDspChcReloadCache(t *testing.T) {
reply := ""
if err := dispEngine.RCP.Call(utils.CacheSv1ReloadCache, AttrReloadCacheWithApiKey{
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}, &reply); err != nil {
t.Error("Got error on CacheSv1.ReloadCache: ", err.Error())
} else if reply != "OK" {
t.Error("Calling CacheSv1.ReloadCache got reply: ", reply)
}
}
func testDspChcRemoveItem(t *testing.T) {
var reply bool
argsAPI := ArgsGetCacheItemWithApiKey{
ArgsGetCacheItem: engine.ArgsGetCacheItem{
CacheID: utils.CacheChargerProfiles,
ItemID: "cgrates.org:DEFAULT",
},
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}
if err := dispEngine.RCP.Call(utils.CacheSv1HasItem, argsAPI, &reply); err != nil {
t.Error(err)
} else if !reply {
t.Errorf("Expected: %v , received:%v", true, reply)
}
var remReply string
if err := dispEngine.RCP.Call(utils.CacheSv1RemoveItem, argsAPI, &remReply); err != nil {
t.Error(err)
} else if remReply != utils.OK {
t.Errorf("Expected: %v , received:%v", utils.OK, remReply)
}
if err := dispEngine.RCP.Call(utils.CacheSv1HasItem, argsAPI, &reply); err != nil {
t.Error(err)
} else if reply {
t.Errorf("Expected: %v , received:%v", false, reply)
}
}
func testDspChcClear(t *testing.T) {
reply := ""
if err := dispEngine.RCP.Call(utils.CacheSv1Clear, AttrCacheIDsWithApiKey{
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}, &reply); err != nil {
t.Error(err)
} else if reply != utils.OK {
t.Error("Calling CacheSv1.ReloadCache got reply: ", reply)
}
var rcvStats map[string]*ltcache.CacheStats
expStats := engine.GetDefaultEmptyCacheStats()
if err := dispEngine.RCP.Call(utils.CacheSv1GetCacheStats, AttrCacheIDsWithApiKey{
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}, &rcvStats); err != nil {
t.Error("Got error on CacheSv1.GetCacheStats: ", err.Error())
} else if !reflect.DeepEqual(expStats, rcvStats) {
t.Errorf("Expecting: %+v, received: %+v", utils.ToJSON(expStats), utils.ToJSON(rcvStats))
}
}
func testDspChcFlush(t *testing.T) {
reply := ""
if err := dispEngine.RCP.Call(utils.CacheSv1FlushCache, AttrReloadCacheWithApiKey{
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
AttrReloadCache: utils.AttrReloadCache{
FlushAll: true,
},
}, &reply); err != nil {
t.Error("Got error on CacheSv1.ReloadCache: ", err.Error())
} else if reply != utils.OK {
t.Error("Calling CacheSv1.ReloadCache got reply: ", reply)
}
var rcvStats map[string]*ltcache.CacheStats
expStats := engine.GetDefaultEmptyCacheStats()
if err := dispEngine.RCP.Call(utils.CacheSv1GetCacheStats, AttrCacheIDsWithApiKey{
DispatcherResource: DispatcherResource{
APIKey: "chc12345",
},
TenantArg: utils.TenantArg{
Tenant: "cgrates.org",
},
}, &rcvStats); err != nil {
t.Error("Got error on CacheSv1.GetCacheStats: ", err.Error())
} else if !reflect.DeepEqual(expStats, rcvStats) {
t.Errorf("Expecting: %+v, received: %+v", utils.ToJSON(expStats), utils.ToJSON(rcvStats))
}
}