2016-06-27 02:21:09 +00:00
|
|
|
// Copyright (c) 2015, Emir Pasic. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
2015-03-10 01:58:57 +00:00
|
|
|
|
|
|
|
package doublylinkedlist
|
|
|
|
|
|
|
|
import (
|
2016-06-21 01:29:29 +00:00
|
|
|
"fmt"
|
2015-03-10 01:58:57 +00:00
|
|
|
"testing"
|
2018-09-19 18:41:47 +00:00
|
|
|
|
|
|
|
"github.com/emirpasic/gods/utils"
|
2015-03-10 01:58:57 +00:00
|
|
|
)
|
|
|
|
|
2018-09-20 16:40:32 +00:00
|
|
|
func TestListNew(t *testing.T) {
|
|
|
|
list1 := New()
|
|
|
|
|
|
|
|
if actualValue := list1.Empty(); actualValue != true {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, true)
|
|
|
|
}
|
|
|
|
|
|
|
|
list2 := New(1, "b")
|
|
|
|
|
|
|
|
if actualValue := list2.Size(); actualValue != 2 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 2)
|
|
|
|
}
|
|
|
|
|
|
|
|
if actualValue, ok := list2.Get(0); actualValue != 1 || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
if actualValue, ok := list2.Get(1); actualValue != "b" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "b")
|
|
|
|
}
|
|
|
|
|
|
|
|
if actualValue, ok := list2.Get(2); actualValue != nil || ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, nil)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListAdd(t *testing.T) {
|
2015-03-10 01:58:57 +00:00
|
|
|
list := New()
|
2016-06-24 17:17:50 +00:00
|
|
|
list.Add("a")
|
|
|
|
list.Add("b", "c")
|
|
|
|
if actualValue := list.Empty(); actualValue != false {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, false)
|
2015-03-10 01:58:57 +00:00
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
if actualValue := list.Size(); actualValue != 3 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 3)
|
|
|
|
}
|
|
|
|
if actualValue, ok := list.Get(2); actualValue != "c" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "c")
|
|
|
|
}
|
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListRemove(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a")
|
|
|
|
list.Add("b", "c")
|
|
|
|
list.Remove(2)
|
|
|
|
if actualValue, ok := list.Get(2); actualValue != nil || ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, nil)
|
|
|
|
}
|
|
|
|
list.Remove(1)
|
|
|
|
list.Remove(0)
|
|
|
|
list.Remove(0) // no effect
|
2015-03-10 01:58:57 +00:00
|
|
|
if actualValue := list.Empty(); actualValue != true {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, true)
|
|
|
|
}
|
|
|
|
if actualValue := list.Size(); actualValue != 0 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 0)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListGet(t *testing.T) {
|
|
|
|
list := New()
|
2015-03-10 01:58:57 +00:00
|
|
|
list.Add("a")
|
|
|
|
list.Add("b", "c")
|
2016-06-24 17:17:50 +00:00
|
|
|
if actualValue, ok := list.Get(0); actualValue != "a" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "a")
|
2015-03-10 01:58:57 +00:00
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
if actualValue, ok := list.Get(1); actualValue != "b" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "b")
|
2015-03-10 01:58:57 +00:00
|
|
|
}
|
|
|
|
if actualValue, ok := list.Get(2); actualValue != "c" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "c")
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
if actualValue, ok := list.Get(3); actualValue != nil || ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, nil)
|
|
|
|
}
|
|
|
|
list.Remove(0)
|
|
|
|
if actualValue, ok := list.Get(0); actualValue != "b" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "b")
|
|
|
|
}
|
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListSwap(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a")
|
|
|
|
list.Add("b", "c")
|
2015-03-13 23:36:10 +00:00
|
|
|
list.Swap(0, 1)
|
|
|
|
if actualValue, ok := list.Get(0); actualValue != "b" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "c")
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2015-03-13 23:36:10 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListSort(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Sort(utils.StringComparator)
|
|
|
|
list.Add("e", "f", "g", "a", "b", "c", "d")
|
|
|
|
list.Sort(utils.StringComparator)
|
|
|
|
for i := 1; i < list.Size(); i++ {
|
|
|
|
a, _ := list.Get(i - 1)
|
|
|
|
b, _ := list.Get(i)
|
|
|
|
if a.(string) > b.(string) {
|
|
|
|
t.Errorf("Not sorted! %s > %s", a, b)
|
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListClear(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("e", "f", "g", "a", "b", "c", "d")
|
|
|
|
list.Clear()
|
2015-03-10 01:58:57 +00:00
|
|
|
if actualValue := list.Empty(); actualValue != true {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, true)
|
|
|
|
}
|
|
|
|
if actualValue := list.Size(); actualValue != 0 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 0)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListContains(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a")
|
|
|
|
list.Add("b", "c")
|
|
|
|
if actualValue := list.Contains("a"); actualValue != true {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, true)
|
|
|
|
}
|
2015-03-13 23:36:10 +00:00
|
|
|
if actualValue := list.Contains("a", "b", "c"); actualValue != true {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, true)
|
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
if actualValue := list.Contains("a", "b", "c", "d"); actualValue != false {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, false)
|
|
|
|
}
|
|
|
|
list.Clear()
|
2015-03-13 23:36:10 +00:00
|
|
|
if actualValue := list.Contains("a"); actualValue != false {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, false)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
if actualValue := list.Contains("a", "b", "c"); actualValue != false {
|
2015-03-10 01:58:57 +00:00
|
|
|
t.Errorf("Got %v expected %v", actualValue, false)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListValues(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a")
|
|
|
|
list.Add("b", "c")
|
|
|
|
if actualValue, expectedValue := fmt.Sprintf("%s%s%s", list.Values()...), "abc"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
2015-03-10 01:58:57 +00:00
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
|
2017-12-26 13:49:36 +00:00
|
|
|
func TestListIndexOf(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
|
|
|
|
expectedIndex := -1
|
2018-06-18 11:13:01 +00:00
|
|
|
if index := list.IndexOf("a"); index != expectedIndex {
|
|
|
|
t.Errorf("Got %v expected %v", index, expectedIndex)
|
2017-12-26 13:49:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
list.Add("a")
|
|
|
|
list.Add("b", "c")
|
|
|
|
|
|
|
|
expectedIndex = 0
|
2018-06-18 11:13:01 +00:00
|
|
|
if index := list.IndexOf("a"); index != expectedIndex {
|
|
|
|
t.Errorf("Got %v expected %v", index, expectedIndex)
|
2017-12-26 13:49:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
expectedIndex = 1
|
2018-06-18 11:13:01 +00:00
|
|
|
if index := list.IndexOf("b"); index != expectedIndex {
|
|
|
|
t.Errorf("Got %v expected %v", index, expectedIndex)
|
2017-12-26 13:49:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
expectedIndex = 2
|
2018-06-18 11:13:01 +00:00
|
|
|
if index := list.IndexOf("c"); index != expectedIndex {
|
|
|
|
t.Errorf("Got %v expected %v", index, expectedIndex)
|
2017-12-26 13:49:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListInsert(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Insert(0, "b", "c")
|
|
|
|
list.Insert(0, "a")
|
|
|
|
list.Insert(10, "x") // ignore
|
|
|
|
if actualValue := list.Size(); actualValue != 3 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 3)
|
|
|
|
}
|
|
|
|
list.Insert(3, "d") // append
|
|
|
|
if actualValue := list.Size(); actualValue != 4 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 4)
|
|
|
|
}
|
|
|
|
if actualValue, expectedValue := fmt.Sprintf("%s%s%s%s", list.Values()...), "abcd"; actualValue != expectedValue {
|
2016-06-21 01:29:29 +00:00
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
2018-09-19 18:41:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestListSet(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Set(0, "a")
|
|
|
|
list.Set(1, "b")
|
|
|
|
if actualValue := list.Size(); actualValue != 2 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 2)
|
|
|
|
}
|
|
|
|
list.Set(2, "c") // append
|
|
|
|
if actualValue := list.Size(); actualValue != 3 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 3)
|
|
|
|
}
|
|
|
|
list.Set(4, "d") // ignore
|
|
|
|
list.Set(1, "bb") // update
|
|
|
|
if actualValue := list.Size(); actualValue != 3 {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, 3)
|
|
|
|
}
|
|
|
|
if actualValue, expectedValue := fmt.Sprintf("%s%s%s", list.Values()...), "abbc"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
list.Set(2, "cc") // last to first traversal
|
|
|
|
list.Set(0, "aa") // first to last traversal
|
|
|
|
if actualValue, expectedValue := fmt.Sprintf("%s%s%s", list.Values()...), "aabbcc"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
2016-06-21 01:29:29 +00:00
|
|
|
}
|
2016-06-22 03:26:48 +00:00
|
|
|
}
|
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListEach(t *testing.T) {
|
2016-06-22 03:26:48 +00:00
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
2016-06-22 19:03:51 +00:00
|
|
|
list.Each(func(index int, value interface{}) {
|
2016-06-22 03:26:48 +00:00
|
|
|
switch index {
|
|
|
|
case 0:
|
|
|
|
if actualValue, expectedValue := value, "a"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
case 1:
|
|
|
|
if actualValue, expectedValue := value, "b"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
case 2:
|
|
|
|
if actualValue, expectedValue := value, "c"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
t.Errorf("Too many")
|
|
|
|
}
|
|
|
|
})
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2016-06-22 03:26:48 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListMap(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
2016-06-22 19:03:51 +00:00
|
|
|
mappedList := list.Map(func(index int, value interface{}) interface{} {
|
2016-06-22 03:26:48 +00:00
|
|
|
return "mapped: " + value.(string)
|
2016-06-24 04:20:24 +00:00
|
|
|
})
|
2016-06-22 03:26:48 +00:00
|
|
|
if actualValue, _ := mappedList.Get(0); actualValue != "mapped: a" {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "mapped: a")
|
|
|
|
}
|
|
|
|
if actualValue, _ := mappedList.Get(1); actualValue != "mapped: b" {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "mapped: b")
|
|
|
|
}
|
|
|
|
if actualValue, _ := mappedList.Get(2); actualValue != "mapped: c" {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "mapped: c")
|
|
|
|
}
|
|
|
|
if mappedList.Size() != 3 {
|
|
|
|
t.Errorf("Got %v expected %v", mappedList.Size(), 3)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2016-06-22 03:26:48 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListSelect(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
2016-06-22 19:03:51 +00:00
|
|
|
selectedList := list.Select(func(index int, value interface{}) bool {
|
2016-06-22 03:26:48 +00:00
|
|
|
return value.(string) >= "a" && value.(string) <= "b"
|
2016-06-24 04:20:24 +00:00
|
|
|
})
|
2016-06-22 03:26:48 +00:00
|
|
|
if actualValue, _ := selectedList.Get(0); actualValue != "a" {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "value: a")
|
|
|
|
}
|
|
|
|
if actualValue, _ := selectedList.Get(1); actualValue != "b" {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "value: b")
|
|
|
|
}
|
|
|
|
if selectedList.Size() != 2 {
|
|
|
|
t.Errorf("Got %v expected %v", selectedList.Size(), 3)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
2016-06-21 01:29:29 +00:00
|
|
|
|
2016-06-24 17:17:50 +00:00
|
|
|
func TestListAny(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
2016-06-22 19:03:51 +00:00
|
|
|
any := list.Any(func(index int, value interface{}) bool {
|
2016-06-22 03:26:48 +00:00
|
|
|
return value.(string) == "c"
|
|
|
|
})
|
|
|
|
if any != true {
|
|
|
|
t.Errorf("Got %v expected %v", any, true)
|
|
|
|
}
|
2016-06-22 19:03:51 +00:00
|
|
|
any = list.Any(func(index int, value interface{}) bool {
|
2016-06-22 03:26:48 +00:00
|
|
|
return value.(string) == "x"
|
|
|
|
})
|
|
|
|
if any != false {
|
|
|
|
t.Errorf("Got %v expected %v", any, false)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
|
|
|
func TestListAll(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
2016-06-22 19:03:51 +00:00
|
|
|
all := list.All(func(index int, value interface{}) bool {
|
2016-06-22 03:26:48 +00:00
|
|
|
return value.(string) >= "a" && value.(string) <= "c"
|
|
|
|
})
|
|
|
|
if all != true {
|
|
|
|
t.Errorf("Got %v expected %v", all, true)
|
|
|
|
}
|
2016-06-22 19:03:51 +00:00
|
|
|
all = list.All(func(index int, value interface{}) bool {
|
2016-06-22 03:26:48 +00:00
|
|
|
return value.(string) >= "a" && value.(string) <= "b"
|
|
|
|
})
|
|
|
|
if all != false {
|
|
|
|
t.Errorf("Got %v expected %v", all, false)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
|
|
|
func TestListFind(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
2016-06-22 19:03:51 +00:00
|
|
|
foundIndex, foundValue := list.Find(func(index int, value interface{}) bool {
|
2016-06-22 03:26:48 +00:00
|
|
|
return value.(string) == "c"
|
|
|
|
})
|
|
|
|
if foundValue != "c" || foundIndex != 2 {
|
|
|
|
t.Errorf("Got %v at %v expected %v at %v", foundValue, foundIndex, "c", 2)
|
|
|
|
}
|
2016-06-22 19:03:51 +00:00
|
|
|
foundIndex, foundValue = list.Find(func(index int, value interface{}) bool {
|
2016-06-22 03:26:48 +00:00
|
|
|
return value.(string) == "x"
|
|
|
|
})
|
2016-06-22 19:03:51 +00:00
|
|
|
if foundValue != nil || foundIndex != -1 {
|
2016-06-22 03:26:48 +00:00
|
|
|
t.Errorf("Got %v at %v expected %v at %v", foundValue, foundIndex, nil, nil)
|
|
|
|
}
|
2016-06-24 17:17:50 +00:00
|
|
|
}
|
|
|
|
func TestListChaining(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
|
|
|
chainedList := list.Select(func(index int, value interface{}) bool {
|
|
|
|
return value.(string) > "a"
|
|
|
|
}).Map(func(index int, value interface{}) interface{} {
|
|
|
|
return value.(string) + value.(string)
|
|
|
|
})
|
|
|
|
if chainedList.Size() != 2 {
|
|
|
|
t.Errorf("Got %v expected %v", chainedList.Size(), 2)
|
|
|
|
}
|
|
|
|
if actualValue, ok := chainedList.Get(0); actualValue != "bb" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "b")
|
|
|
|
}
|
|
|
|
if actualValue, ok := chainedList.Get(1); actualValue != "cc" || !ok {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, "c")
|
|
|
|
}
|
|
|
|
}
|
2016-06-22 03:26:48 +00:00
|
|
|
|
2016-06-25 16:17:48 +00:00
|
|
|
func TestListIteratorNextOnEmpty(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
it := list.Iterator()
|
|
|
|
for it.Next() {
|
|
|
|
t.Errorf("Shouldn't iterate on empty list")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestListIteratorNext(t *testing.T) {
|
2016-06-24 17:17:50 +00:00
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
2016-06-22 03:26:48 +00:00
|
|
|
it := list.Iterator()
|
2016-06-25 16:17:48 +00:00
|
|
|
count := 0
|
2016-06-22 03:26:48 +00:00
|
|
|
for it.Next() {
|
2016-06-25 16:17:48 +00:00
|
|
|
count++
|
2016-06-22 03:26:48 +00:00
|
|
|
index := it.Index()
|
|
|
|
value := it.Value()
|
|
|
|
switch index {
|
|
|
|
case 0:
|
|
|
|
if actualValue, expectedValue := value, "a"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
case 1:
|
|
|
|
if actualValue, expectedValue := value, "b"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
case 2:
|
|
|
|
if actualValue, expectedValue := value, "c"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
t.Errorf("Too many")
|
|
|
|
}
|
|
|
|
}
|
2016-06-25 16:17:48 +00:00
|
|
|
if actualValue, expectedValue := count, 3; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestListIteratorPrevOnEmpty(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
it := list.Iterator()
|
|
|
|
for it.Prev() {
|
2016-06-22 03:26:48 +00:00
|
|
|
t.Errorf("Shouldn't iterate on empty list")
|
|
|
|
}
|
2015-03-10 01:58:57 +00:00
|
|
|
}
|
|
|
|
|
2016-06-25 16:17:48 +00:00
|
|
|
func TestListIteratorPrev(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
|
|
|
it := list.Iterator()
|
|
|
|
for it.Next() {
|
|
|
|
}
|
|
|
|
count := 0
|
|
|
|
for it.Prev() {
|
|
|
|
count++
|
|
|
|
index := it.Index()
|
|
|
|
value := it.Value()
|
|
|
|
switch index {
|
|
|
|
case 0:
|
|
|
|
if actualValue, expectedValue := value, "a"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
case 1:
|
|
|
|
if actualValue, expectedValue := value, "b"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
case 2:
|
|
|
|
if actualValue, expectedValue := value, "c"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
t.Errorf("Too many")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if actualValue, expectedValue := count, 3; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-26 22:08:01 +00:00
|
|
|
func TestListIteratorBegin(t *testing.T) {
|
2016-06-26 19:44:23 +00:00
|
|
|
list := New()
|
|
|
|
it := list.Iterator()
|
2016-06-26 22:08:01 +00:00
|
|
|
it.Begin()
|
2016-06-26 19:44:23 +00:00
|
|
|
list.Add("a", "b", "c")
|
|
|
|
for it.Next() {
|
|
|
|
}
|
2016-06-26 22:08:01 +00:00
|
|
|
it.Begin()
|
2016-06-26 19:44:23 +00:00
|
|
|
it.Next()
|
|
|
|
if index, value := it.Index(), it.Value(); index != 0 || value != "a" {
|
|
|
|
t.Errorf("Got %v,%v expected %v,%v", index, value, 0, "a")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-27 00:42:05 +00:00
|
|
|
func TestListIteratorEnd(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
it := list.Iterator()
|
|
|
|
|
|
|
|
if index := it.Index(); index != -1 {
|
|
|
|
t.Errorf("Got %v expected %v", index, -1)
|
|
|
|
}
|
|
|
|
|
|
|
|
it.End()
|
|
|
|
if index := it.Index(); index != 0 {
|
|
|
|
t.Errorf("Got %v expected %v", index, 0)
|
|
|
|
}
|
|
|
|
|
|
|
|
list.Add("a", "b", "c")
|
|
|
|
it.End()
|
|
|
|
if index := it.Index(); index != list.Size() {
|
|
|
|
t.Errorf("Got %v expected %v", index, list.Size())
|
|
|
|
}
|
|
|
|
|
|
|
|
it.Prev()
|
|
|
|
if index, value := it.Index(), it.Value(); index != list.Size()-1 || value != "c" {
|
|
|
|
t.Errorf("Got %v,%v expected %v,%v", index, value, list.Size()-1, "c")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-26 21:58:23 +00:00
|
|
|
func TestListIteratorFirst(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
it := list.Iterator()
|
|
|
|
if actualValue, expectedValue := it.First(), false; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
list.Add("a", "b", "c")
|
|
|
|
if actualValue, expectedValue := it.First(), true; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
if index, value := it.Index(), it.Value(); index != 0 || value != "a" {
|
|
|
|
t.Errorf("Got %v,%v expected %v,%v", index, value, 0, "a")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-26 20:40:49 +00:00
|
|
|
func TestListIteratorLast(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
it := list.Iterator()
|
|
|
|
if actualValue, expectedValue := it.Last(), false; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
list.Add("a", "b", "c")
|
|
|
|
if actualValue, expectedValue := it.Last(), true; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
if index, value := it.Index(), it.Value(); index != 2 || value != "c" {
|
|
|
|
t.Errorf("Got %v,%v expected %v,%v", index, value, 2, "c")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-06 00:05:01 +00:00
|
|
|
func TestListSerialization(t *testing.T) {
|
|
|
|
list := New()
|
|
|
|
list.Add("a", "b", "c")
|
|
|
|
|
|
|
|
var err error
|
|
|
|
assert := func() {
|
|
|
|
if actualValue, expectedValue := fmt.Sprintf("%s%s%s", list.Values()...), "abc"; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
if actualValue, expectedValue := list.Size(), 3; actualValue != expectedValue {
|
|
|
|
t.Errorf("Got %v expected %v", actualValue, expectedValue)
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Got error %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
assert()
|
|
|
|
|
|
|
|
json, err := list.ToJSON()
|
|
|
|
assert()
|
|
|
|
|
|
|
|
err = list.FromJSON(json)
|
|
|
|
assert()
|
|
|
|
}
|
|
|
|
|
2016-07-16 02:40:16 +00:00
|
|
|
func benchmarkGet(b *testing.B, list *List, size int) {
|
2015-03-10 01:58:57 +00:00
|
|
|
for i := 0; i < b.N; i++ {
|
2016-07-16 02:40:16 +00:00
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Get(n)
|
2015-03-10 01:58:57 +00:00
|
|
|
}
|
2016-07-16 02:40:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func benchmarkAdd(b *testing.B, list *List, size int) {
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func benchmarkRemove(b *testing.B, list *List, size int) {
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Remove(n)
|
2015-03-10 01:58:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-07-16 02:40:16 +00:00
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListGet100(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 100
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkGet(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListGet1000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 1000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkGet(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListGet10000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 10000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkGet(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListGet100000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 100000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkGet(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListAdd100(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 100
|
|
|
|
list := New()
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkAdd(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListAdd1000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 1000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkAdd(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListAdd10000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 10000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkAdd(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListAdd100000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 100000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkAdd(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListRemove100(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 100
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkRemove(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListRemove1000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 1000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkRemove(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListRemove10000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 10000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkRemove(b, list, size)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkDoublyLinkedListRemove100000(b *testing.B) {
|
|
|
|
b.StopTimer()
|
|
|
|
size := 100000
|
|
|
|
list := New()
|
|
|
|
for n := 0; n < size; n++ {
|
|
|
|
list.Add(n)
|
|
|
|
}
|
|
|
|
b.StartTimer()
|
|
|
|
benchmarkRemove(b, list, size)
|
|
|
|
}
|