torrent/ordered_test.go

48 lines
682 B
Go

package torrent
import (
"testing"
)
func TestOrderedList(t *testing.T) {
ol := newOrderedList(func(a, b interface{}) bool {
return a.(int) < b.(int)
})
if ol.Len() != 0 {
t.FailNow()
}
e := ol.Insert(0)
if ol.Len() != 1 {
t.FailNow()
}
if e.Value.(int) != 0 {
t.FailNow()
}
e = ol.Front()
if e.Value.(int) != 0 {
t.FailNow()
}
if e.Next() != nil {
t.FailNow()
}
ol.Insert(1)
if e.Next().Value.(int) != 1 {
t.FailNow()
}
ol.Insert(-1)
if e.Prev().Value.(int) != -1 {
t.FailNow()
}
e.Value = -2
ol.ValueChanged(e)
if e.Prev() != nil {
t.FailNow()
}
if e.Next().Value.(int) != -1 {
t.FailNow()
}
if ol.Len() != 3 {
t.FailNow()
}
}