mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
35 lines
1 KiB
Go
35 lines
1 KiB
Go
|
|
// Copyright 2023 The Go Authors. All rights reserved.
|
||
|
|
// Use of this source code is governed by a BSD-style
|
||
|
|
// license that can be found in the LICENSE file.
|
||
|
|
|
||
|
|
package trace
|
||
|
|
|
||
|
|
import "testing"
|
||
|
|
|
||
|
|
func TestQueue(t *testing.T) {
|
||
|
|
var q queue[int]
|
||
|
|
check := func(name string, exp []int) {
|
||
|
|
for _, v := range exp {
|
||
|
|
q.push(v)
|
||
|
|
}
|
||
|
|
for i, want := range exp {
|
||
|
|
if got, ok := q.pop(); !ok {
|
||
|
|
t.Fatalf("check %q: expected to be able to pop after %d pops", name, i+1)
|
||
|
|
} else if got != want {
|
||
|
|
t.Fatalf("check %q: expected value %d after on pop %d, got %d", name, want, i+1, got)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
if _, ok := q.pop(); ok {
|
||
|
|
t.Fatalf("check %q: did not expect to be able to pop more values", name)
|
||
|
|
}
|
||
|
|
if _, ok := q.pop(); ok {
|
||
|
|
t.Fatalf("check %q: did not expect to be able to pop more values a second time", name)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
check("one element", []int{4})
|
||
|
|
check("two elements", []int{64, 12})
|
||
|
|
check("six elements", []int{55, 16423, 2352, 644, 12874, 9372})
|
||
|
|
check("one element again", []int{7})
|
||
|
|
check("two elements again", []int{77, 6336})
|
||
|
|
}
|