| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- // Copyright (c) 2013-2017, Peter H. Froehlich. All rights reserved.
- // Use of this source code is governed by a BSD-style license
- // that can be found in the LICENSE file.
- package queue
- import "testing"
- import "container/list"
- import "math/rand"
- func ensureEmpty(t *testing.T, q *Queue) {
- if l := q.Len(); l != 0 {
- t.Errorf("q.Len() = %d, want %d", l, 0)
- }
- if e := q.Front(); e != nil {
- t.Errorf("q.Front() = %v, want %v", e, nil)
- }
- if e := q.Back(); e != nil {
- t.Errorf("q.Back() = %v, want %v", e, nil)
- }
- if e := q.PopFront(); e != nil {
- t.Errorf("q.PopFront() = %v, want %v", e, nil)
- }
- if e := q.PopBack(); e != nil {
- t.Errorf("q.PopBack() = %v, want %v", e, nil)
- }
- }
- func TestNew(t *testing.T) {
- q := New()
- ensureEmpty(t, q)
- }
- func ensureSingleton(t *testing.T, q *Queue) {
- if l := q.Len(); l != 1 {
- t.Errorf("q.Len() = %d, want %d", l, 1)
- }
- if e := q.Front(); e != 42 {
- t.Errorf("q.Front() = %v, want %v", e, 42)
- }
- if e := q.Back(); e != 42 {
- t.Errorf("q.Back() = %v, want %v", e, 42)
- }
- }
- func TestSingleton(t *testing.T) {
- q := New()
- ensureEmpty(t, q)
- q.PushFront(42)
- ensureSingleton(t, q)
- q.PopFront()
- ensureEmpty(t, q)
- q.PushBack(42)
- ensureSingleton(t, q)
- q.PopBack()
- ensureEmpty(t, q)
- q.PushFront(42)
- ensureSingleton(t, q)
- q.PopBack()
- ensureEmpty(t, q)
- q.PushBack(42)
- ensureSingleton(t, q)
- q.PopFront()
- ensureEmpty(t, q)
- }
- func TestDuos(t *testing.T) {
- q := New()
- ensureEmpty(t, q)
- q.PushFront(42)
- ensureSingleton(t, q)
- q.PushBack(43)
- if l := q.Len(); l != 2 {
- t.Errorf("q.Len() = %d, want %d", l, 2)
- }
- if e := q.Front(); e != 42 {
- t.Errorf("q.Front() = %v, want %v", e, 42)
- }
- if e := q.Back(); e != 43 {
- t.Errorf("q.Back() = %v, want %v", e, 43)
- }
- }
- func ensureLength(t *testing.T, q *Queue, len int) {
- if l := q.Len(); l != len {
- t.Errorf("q.Len() = %d, want %d", l, len)
- }
- }
- func TestZeroValue(t *testing.T) {
- var q Queue
- q.PushFront(1)
- ensureLength(t, &q, 1)
- q.PushFront(2)
- ensureLength(t, &q, 2)
- q.PushFront(3)
- ensureLength(t, &q, 3)
- q.PushFront(4)
- ensureLength(t, &q, 4)
- q.PushFront(5)
- ensureLength(t, &q, 5)
- q.PushBack(6)
- ensureLength(t, &q, 6)
- q.PushBack(7)
- ensureLength(t, &q, 7)
- q.PushBack(8)
- ensureLength(t, &q, 8)
- q.PushBack(9)
- ensureLength(t, &q, 9)
- const want = "[5, 4, 3, 2, 1, 6, 7, 8, 9]"
- if s := q.String(); s != want {
- t.Errorf("q.String() = %s, want %s", s, want)
- }
- }
- const size = 1024
- func BenchmarkPushFrontQueue(b *testing.B) {
- for i := 0; i < b.N; i++ {
- var q Queue
- for n := 0; n < size; n++ {
- q.PushFront(n)
- }
- }
- }
- func BenchmarkPushFrontList(b *testing.B) {
- for i := 0; i < b.N; i++ {
- var q list.List
- for n := 0; n < size; n++ {
- q.PushFront(n)
- }
- }
- }
- func BenchmarkPushBackQueue(b *testing.B) {
- for i := 0; i < b.N; i++ {
- var q Queue
- for n := 0; n < size; n++ {
- q.PushBack(n)
- }
- }
- }
- func BenchmarkPushBackList(b *testing.B) {
- for i := 0; i < b.N; i++ {
- var q list.List
- for n := 0; n < size; n++ {
- q.PushBack(n)
- }
- }
- }
- func BenchmarkPushBackChannel(b *testing.B) {
- for i := 0; i < b.N; i++ {
- q := make(chan interface{}, size)
- for n := 0; n < size; n++ {
- q <- n
- }
- close(q)
- }
- }
- var rands []float32
- func makeRands() {
- if rands != nil {
- return
- }
- rand.Seed(64738)
- for i := 0; i < 4*size; i++ {
- rands = append(rands, rand.Float32())
- }
- }
- func BenchmarkRandomQueue(b *testing.B) {
- makeRands()
- for i := 0; i < b.N; i++ {
- var q Queue
- for n := 0; n < size; n++ {
- if rands[n*4] < 0.8 {
- q.PushBack(n)
- }
- if rands[n*4+1] < 0.8 {
- q.PushFront(n)
- }
- if rands[n*4+2] < 0.5 {
- q.PopFront()
- }
- if rands[n*4+3] < 0.5 {
- q.PopBack()
- }
- }
- }
- }
- func BenchmarkRandomList(b *testing.B) {
- makeRands()
- for i := 0; i < b.N; i++ {
- var q list.List
- for n := 0; n < size; n++ {
- if rands[n*4] < 0.8 {
- q.PushBack(n)
- }
- if rands[n*4+1] < 0.8 {
- q.PushFront(n)
- }
- if rands[n*4+2] < 0.5 {
- if e := q.Front(); e != nil {
- q.Remove(e)
- }
- }
- if rands[n*4+3] < 0.5 {
- if e := q.Back(); e != nil {
- q.Remove(e)
- }
- }
- }
- }
- }
|