mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-11 18:16:24 +05:00
493 lines
15 KiB
Go
493 lines
15 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 utils
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
)
|
|
|
|
func TestPathItemListNext(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushFront(node3)
|
|
list.PushFront(node2)
|
|
list.PushFront(node1)
|
|
if !reflect.DeepEqual("path2", list.Front().Next().Value.String()) {
|
|
t.Errorf("Expecting: <path2>, received: <%+v>", list.Front().Next().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListNextNil(t *testing.T) {
|
|
var e PathItemElement
|
|
received := e.Next()
|
|
if received != nil {
|
|
t.Errorf("Expecting: <nil>, received: <%+v>", received)
|
|
}
|
|
}
|
|
|
|
func TestPathItemListPrev(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushFront(node3)
|
|
list.PushFront(node2)
|
|
list.PushFront(node1)
|
|
if !reflect.DeepEqual("path2", list.Back().Prev().Value.String()) {
|
|
t.Errorf("Expecting: <path2>, received: <%+v>", list.Back().Prev().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListPrevNil(t *testing.T) {
|
|
var e PathItemElement
|
|
received := e.Prev()
|
|
if received != nil {
|
|
t.Errorf("Expecting: <nil>, received: <%+v>", received)
|
|
}
|
|
}
|
|
|
|
func TestPathItemListInit(t *testing.T) {
|
|
list := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushFront(node3)
|
|
list.PushFront(node2)
|
|
list.PushFront(node1)
|
|
if !reflect.DeepEqual(list2, list.Init()) {
|
|
t.Errorf("Expecting: <%+v>, received: <%+v>", list2, list.Init())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListNewPathItemList(t *testing.T) {
|
|
list := NewPathItemList()
|
|
list2 := new(PathItemList).Init()
|
|
if !reflect.DeepEqual(list2, list) {
|
|
t.Errorf("Expecting: <%+v>, received: <%+v>", list2, list)
|
|
}
|
|
}
|
|
|
|
func TestPathItemListLen(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushFront(node3)
|
|
list.PushFront(node2)
|
|
list.PushFront(node1)
|
|
if !reflect.DeepEqual(3, list.Len()) {
|
|
t.Errorf("Expecting: <3>, received: <%+v>", list.Len())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListFront(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
if !reflect.DeepEqual("path1", list.Front().Value.String()) {
|
|
t.Errorf("Expecting: <path1>, received: <%+v>", list.Front().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListFrontNil(t *testing.T) {
|
|
var e PathItemList
|
|
received := e.Front()
|
|
if received != nil {
|
|
t.Errorf("Expecting: <nil>, received: <%+v>", received)
|
|
}
|
|
}
|
|
|
|
func TestPathItemListBack(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
if !reflect.DeepEqual("path2", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path2>, received: <%+v>", list.Back().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListBackNil(t *testing.T) {
|
|
var e PathItemList
|
|
received := e.Back()
|
|
if received != nil {
|
|
t.Errorf("Expecting: <nil>, received: <%+v>", received)
|
|
}
|
|
}
|
|
|
|
func TestPathItemListLazyInit(t *testing.T) {
|
|
list := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
list.root.next = nil
|
|
list.lazyInit()
|
|
if !reflect.DeepEqual(list2, list) {
|
|
t.Errorf("Expecting: <%+v>, received: <%+v>", list2, list)
|
|
}
|
|
}
|
|
|
|
func TestPathItemListInsert(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.insert(list.Front(), list.Back())
|
|
if !reflect.DeepEqual("path1", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path1>, received: <%+v>", list.Back().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListInsertValue(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.insertValue(PathItems{{Field: "path3"}}, list.Back())
|
|
if !reflect.DeepEqual("path3", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path3>, received: <%+v>", list.Back().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListRemoveLowerCase(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.remove(list.Back())
|
|
if !reflect.DeepEqual("path2", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path2>, received: <%+v>", list.Back().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListRemoveUpperCase1(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.Remove(list.Front().Next())
|
|
if !reflect.DeepEqual("path3", list.Front().Next().Value.String()) {
|
|
t.Errorf("Expecting: <path3>, received: <%+v>", list.Front().Next().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListRemoveUpperCase2(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
node1 := NewPathItems([]string{"pathA"})
|
|
node2 := NewPathItems([]string{"pathB"})
|
|
list1.PushBack(node1)
|
|
list2.PushBack(node2)
|
|
list1.Remove(list2.Front())
|
|
if !reflect.DeepEqual("pathA", list1.Front().Value.String()) {
|
|
t.Errorf("Expecting: <pathA>, received: <%+v>", list1.Front().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListMoveEqual(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.move(list.Back(), list.Back())
|
|
if !reflect.DeepEqual("path3", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path3>, received: <%+v>", list.Back().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListMove(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.move(list.Front(), list.Back())
|
|
if !reflect.DeepEqual("path3", list.Front().next.Value.String()) {
|
|
t.Errorf("Expecting: <path3>, received: <%+v>", list.Front().next.Value.String())
|
|
}
|
|
if !reflect.DeepEqual("path1", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path1>, received: <%+v>", list.Back().Value.String())
|
|
}
|
|
if !reflect.DeepEqual("path2", list.Front().Value.String()) {
|
|
t.Errorf("Expecting: <path2>, received: <%+v>", list.Front().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListPushFront(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.PushFront(PathItems{{Field: "path4"}})
|
|
if !reflect.DeepEqual("path4", list.Front().Value.String()) {
|
|
t.Errorf("Expecting: <path4>, received: <%+v>", list.Front().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListPushBack(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.PushBack(PathItems{{Field: "path4"}})
|
|
if !reflect.DeepEqual("path4", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path4>, received: <%+v>", list.Back().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListInsertBefore(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.InsertBefore(PathItems{{Field: "path4"}}, list.Back())
|
|
if !reflect.DeepEqual("path4", list.Back().Prev().Value.String()) {
|
|
t.Errorf("Expecting: <path4>, received: <%+v>", list.Back().Prev().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListInsertBeforeNil(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
var received *PathItemElement
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list1.PushBack(node1)
|
|
list2.PushBack(node2)
|
|
received = list1.InsertBefore(PathItems{{Field: "path4"}}, list2.Back())
|
|
if received != nil {
|
|
t.Errorf("Expecting: <%+v>, received: <%+v>", nil, received)
|
|
}
|
|
}
|
|
|
|
func TestPathItemListInsertAfter(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.InsertAfter(PathItems{{Field: "path4"}}, list.Front())
|
|
if !reflect.DeepEqual("path4", list.Front().Next().Value.String()) {
|
|
t.Errorf("Expecting: <path4>, received: <%+v>", list.Front().Next().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListInsertAfterNil(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
var received *PathItemElement
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list1.PushBack(node1)
|
|
list2.PushBack(node2)
|
|
received = list1.InsertAfter(PathItems{{Field: "path4"}}, list2.Back())
|
|
if received != nil {
|
|
t.Errorf("Expecting: <%+v>, received: <%+v>", nil, received)
|
|
}
|
|
}
|
|
|
|
func TestPathItemListMoveToFrontCase1(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list1.PushBack(node1)
|
|
list2.PushBack(node2)
|
|
list1.MoveToFront(list2.Back())
|
|
if !reflect.DeepEqual("path1", list1.Front().Value.String()) {
|
|
t.Errorf("Expecting: <path3>, received: <%+v>", list1.Front().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListMoveToFrontCase2(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.MoveToFront(list.Back())
|
|
if !reflect.DeepEqual("path3", list.Front().Value.String()) {
|
|
t.Errorf("Expecting: <path3>, received: <%+v>", list.Front().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListMoveToBackCase1(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list1.PushBack(node1)
|
|
list2.PushBack(node2)
|
|
list1.MoveToBack(list2.Back())
|
|
if !reflect.DeepEqual("path1", list1.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path1>, received: <%+v>", list1.Back().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListMoveToBackCase2(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.MoveToBack(list.Front())
|
|
if !reflect.DeepEqual("path1", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path1>, received: <%+v>", list.Front().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListMoveBeforeCase1(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
list1.PushBack(node1)
|
|
list2.PushBack(node2)
|
|
list1.MoveBefore(list2.Front(), list1.Back())
|
|
if !reflect.DeepEqual("path1", list1.Front().Value.String()) {
|
|
t.Errorf("Expecting: <path1>, received: <%+v>", list1.Front().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListMoveBeforeCase2(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.MoveBefore(list.Front(), list.Back())
|
|
if !reflect.DeepEqual("path1", list.Back().Prev().Value.String()) {
|
|
t.Errorf("Expecting: <path1>, received: <%+v>", list.Back().Prev().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListMoveAfterCase1(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
node1 := NewPathItems([]string{"pathA"})
|
|
node2 := NewPathItems([]string{"pathB"})
|
|
list1.PushBack(node1)
|
|
list2.PushBack(node2)
|
|
list1.MoveAfter(list2.Front(), list1.Back())
|
|
if !reflect.DeepEqual("pathA", list1.Back().Value.String()) {
|
|
t.Errorf("Expecting: <pathA>, received: <%+v>", list1.Back().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListMoveAfterCase2(t *testing.T) {
|
|
list := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
node3 := NewPathItems([]string{"path3"})
|
|
list.PushBack(node1)
|
|
list.PushBack(node2)
|
|
list.PushBack(node3)
|
|
list.MoveAfter(list.Front(), list.Back())
|
|
if !reflect.DeepEqual("path1", list.Back().Value.String()) {
|
|
t.Errorf("Expecting: <path1>, received: <%+v>", list.Back().Value.String())
|
|
}
|
|
|
|
}
|
|
|
|
func TestPathItemListPushBackList(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
nodeA := NewPathItems([]string{"pathA"})
|
|
nodeB := NewPathItems([]string{"pathB"})
|
|
list1.PushBack(node1)
|
|
list1.PushBack(node2)
|
|
list2.PushBack(nodeA)
|
|
list2.PushBack(nodeB)
|
|
list1.PushBackList(list2)
|
|
if !reflect.DeepEqual("pathB", list1.Back().Value.String()) {
|
|
t.Errorf("Expecting: <pathB>, received: <%+v>", list1.Back().Value.String())
|
|
}
|
|
if !reflect.DeepEqual("pathA", list1.Back().Prev().Value.String()) {
|
|
t.Errorf("Expecting: <pathA>, received: <%+v>", list1.Back().Prev().Value.String())
|
|
}
|
|
}
|
|
|
|
func TestPathItemListPushFrontList(t *testing.T) {
|
|
list1 := NewPathItemList()
|
|
list2 := NewPathItemList()
|
|
node1 := NewPathItems([]string{"path1"})
|
|
node2 := NewPathItems([]string{"path2"})
|
|
nodeA := NewPathItems([]string{"pathA"})
|
|
nodeB := NewPathItems([]string{"pathB"})
|
|
list1.PushBack(node1)
|
|
list1.PushBack(node2)
|
|
list2.PushBack(nodeA)
|
|
list2.PushBack(nodeB)
|
|
list1.PushFrontList(list2)
|
|
if !reflect.DeepEqual("pathA", list1.Front().Value.String()) {
|
|
t.Errorf("Expecting: <pathA>, received: <%+v>", list1.Front().Value.String())
|
|
}
|
|
if !reflect.DeepEqual("pathB", list1.Front().Next().Value.String()) {
|
|
t.Errorf("Expecting: <pathB>, received: <%+v>", list1.Front().Next().Value.String())
|
|
}
|
|
}
|