Files
cgrates/scheduler/scheduler_test.go
2021-01-11 10:57:44 +01:00

49 lines
2.0 KiB
Go

/*
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 scheduler
import (
"testing"
"time"
"github.com/cgrates/cgrates/engine"
"github.com/cgrates/cgrates/utils"
)
func TestSchedulerUpdateActStats(t *testing.T) {
sched := &Scheduler{actStatsInterval: time.Millisecond, actSuccessStats: make(map[string]map[time.Time]bool)}
sched.updateActStats(&engine.Action{Id: "REMOVE_1", ActionType: utils.MetaRemoveAccount}, false)
if len(sched.actSuccessStats[utils.MetaRemoveAccount]) != 1 {
t.Errorf("Wrong stats: %+v", sched.actSuccessStats[utils.MetaRemoveAccount])
}
sched.updateActStats(&engine.Action{Id: "REMOVE_2", ActionType: utils.MetaRemoveAccount}, false)
if len(sched.actSuccessStats[utils.MetaRemoveAccount]) != 2 {
t.Errorf("Wrong stats: %+v", sched.actSuccessStats[utils.MetaRemoveAccount])
}
sched.updateActStats(&engine.Action{Id: "LOG1", ActionType: utils.MetaLog}, false)
if len(sched.actSuccessStats[utils.MetaLog]) != 1 ||
len(sched.actSuccessStats[utils.MetaRemoveAccount]) != 2 {
t.Errorf("Wrong stats: %+v", sched.actSuccessStats)
}
time.Sleep(sched.actStatsInterval)
sched.updateActStats(&engine.Action{Id: "REMOVE_3", ActionType: utils.MetaRemoveAccount}, false)
if len(sched.actSuccessStats[utils.MetaRemoveAccount]) != 1 || len(sched.actSuccessStats) != 1 {
t.Errorf("Wrong stats: %+v", sched.actSuccessStats)
}
}