diff --git a/services/httpagent_it_test.go b/services/httpagent_it_test.go
index fba3a4be3..bea9f22dc 100644
--- a/services/httpagent_it_test.go
+++ b/services/httpagent_it_test.go
@@ -83,7 +83,10 @@ func TestHTTPAgentReload(t *testing.T) {
if err != utils.ErrServiceAlreadyRunning {
t.Errorf("\nExpecting <%+v>,\n Received <%+v>", utils.ErrServiceAlreadyRunning, err)
}
- srv.Shutdown()
+ err = srv.Shutdown()
+ if err != utils.ErrServiceAlreadyRunning {
+ t.Errorf("\nExpecting <%+v>,\n Received <%+v>", utils.ErrServiceAlreadyRunning, err)
+ }
if srv.IsRunning() {
t.Errorf("Expected service to be down")
}
diff --git a/services/loaders_it_test.go b/services/loaders_it_test.go
new file mode 100644
index 000000000..f2cc8e35f
--- /dev/null
+++ b/services/loaders_it_test.go
@@ -0,0 +1,80 @@
+// +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 services
+
+/*
+func TestLoadersReload(t *testing.T) {
+ cfg := config.NewDefaultCGRConfig()
+ cfg.SessionSCfg().Enabled = true
+ utils.Logger, _ = utils.Newlogger(utils.MetaSysLog, cfg.GeneralCfg().NodeID)
+ utils.Logger.SetLogLevel(7)
+ filterSChan := make(chan *engine.FilterS, 1)
+ filterSChan <- nil
+ shdChan := utils.NewSyncedChan()
+ shdWg := new(sync.WaitGroup)
+ chS := engine.NewCacheS(cfg, nil, nil)
+ cacheSChan := make(chan rpcclient.ClientConnector, 1)
+ cacheSChan <- chS
+ server := cores.NewServer(nil)
+ srvMngr := servmanager.NewServiceManager(cfg, shdChan, shdWg)
+ srvDep := map[string]*sync.WaitGroup{utils.DataDB: new(sync.WaitGroup)}
+ db := NewDataDBService(cfg, nil, srvDep)
+ anz := NewAnalyzerService(cfg, server, filterSChan, shdChan, make(chan rpcclient.ClientConnector, 1), srvDep)
+ srv := NewLoaderService(cfg, db, filterSChan, server, make(chan rpcclient.ClientConnector, 1), nil, anz, srvDep)
+ engine.NewConnManager(cfg, nil)
+ srvMngr.AddServices(srv, db)
+ if err := srvMngr.StartServices(); err != nil {
+ t.Fatal(err)
+ }
+ if srv.IsRunning() {
+ t.Errorf("Expected service to be down")
+ }
+ var reply string
+ if err := cfg.V1ReloadConfig(&config.ReloadArgs{
+ Path: path.Join("/usr", "share", "cgrates", "conf", "samples", "tutmysql_internal"),
+ Section: "loaders",
+ }, &reply); err != nil {
+ t.Fatal(err)
+ } else if reply != utils.OK {
+ t.Errorf("Expecting OK ,received %s", reply)
+ }
+ time.Sleep(10 * time.Millisecond) //need to switch to gorutine
+ if !srv.IsRunning() {
+ t.Errorf("Expected service to be running")
+ }
+ srvReload := srv.Reload()
+ if srvReload != nil {
+ t.Errorf("\nExpecting ,\n Received <%+v>", srvReload)
+ }
+ err := srv.Start()
+ if err != utils.ErrServiceAlreadyRunning {
+ t.Errorf("\nExpecting <%+v>,\n Received <%+v>", utils.ErrServiceAlreadyRunning, err)
+ }
+ err = srv.Shutdown()
+ if err != utils.ErrServiceAlreadyRunning {
+ t.Errorf("\nExpecting <%+v>,\n Received <%+v>", utils.ErrServiceAlreadyRunning, err)
+ }
+ if srv.IsRunning() {
+ t.Errorf("Expected service to be down")
+ }
+ shdChan.CloseOnce()
+ time.Sleep(10 * time.Millisecond)
+}
+*/