hugo

Fork of github.com/gohugoio/hugo with reverse pagination support

git clone git://git.shimmy1996.com/hugo.git

evictingqueue_test.go (1875B)

    1 // Copyright 2017-present The Hugo Authors. All rights reserved.
    2 //
    3 // Licensed under the Apache License, Version 2.0 (the "License");
    4 // you may not use this file except in compliance with the License.
    5 // You may obtain a copy of the License at
    6 // http://www.apache.org/licenses/LICENSE-2.0
    7 //
    8 // Unless required by applicable law or agreed to in writing, software
    9 // distributed under the License is distributed on an "AS IS" BASIS,
   10 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   11 // See the License for the specific language governing permissions and
   12 // limitations under the License.
   13 
   14 package types
   15 
   16 import (
   17 	"sync"
   18 	"testing"
   19 
   20 	qt "github.com/frankban/quicktest"
   21 )
   22 
   23 func TestEvictingStringQueue(t *testing.T) {
   24 	c := qt.New(t)
   25 
   26 	queue := NewEvictingStringQueue(3)
   27 
   28 	c.Assert(queue.Peek(), qt.Equals, "")
   29 	queue.Add("a")
   30 	queue.Add("b")
   31 	queue.Add("a")
   32 	c.Assert(queue.Peek(), qt.Equals, "b")
   33 	queue.Add("b")
   34 	c.Assert(queue.Peek(), qt.Equals, "b")
   35 
   36 	queue.Add("a")
   37 	queue.Add("b")
   38 
   39 	c.Assert(queue.Contains("a"), qt.Equals, true)
   40 	c.Assert(queue.Contains("foo"), qt.Equals, false)
   41 
   42 	c.Assert(queue.PeekAll(), qt.DeepEquals, []string{"b", "a"})
   43 	c.Assert(queue.Peek(), qt.Equals, "b")
   44 	queue.Add("c")
   45 	queue.Add("d")
   46 	// Overflowed, a should now be removed.
   47 	c.Assert(queue.PeekAll(), qt.DeepEquals, []string{"d", "c", "b"})
   48 	c.Assert(len(queue.PeekAllSet()), qt.Equals, 3)
   49 	c.Assert(queue.PeekAllSet()["c"], qt.Equals, true)
   50 }
   51 
   52 func TestEvictingStringQueueConcurrent(t *testing.T) {
   53 	var wg sync.WaitGroup
   54 	val := "someval"
   55 
   56 	queue := NewEvictingStringQueue(3)
   57 
   58 	for j := 0; j < 100; j++ {
   59 		wg.Add(1)
   60 		go func() {
   61 			defer wg.Done()
   62 			queue.Add(val)
   63 			v := queue.Peek()
   64 			if v != val {
   65 				t.Error("wrong val")
   66 			}
   67 			vals := queue.PeekAll()
   68 			if len(vals) != 1 || vals[0] != val {
   69 				t.Error("wrong val")
   70 			}
   71 		}()
   72 	}
   73 	wg.Wait()
   74 }