mirror of
https://github.com/OffchainLabs/prysm.git
synced 2026-01-08 23:18:15 -05:00
* Ran gopls modernize to fix everything go run golang.org/x/tools/gopls/internal/analysis/modernize/cmd/modernize@latest -fix -test ./... * Override rules_go provided dependency for golang.org/x/tools to v0.38.0. To update this, checked out rules_go, then ran `bazel run //go/tools/releaser -- upgrade-dep -mirror=false org_golang_x_tools` and copied the patches. * Fix buildtag violations and ignore buildtag violations in external * Introduce modernize analyzer package. * Add modernize "any" analyzer. * Fix violations of any analyzer * Add modernize "appendclipped" analyzer. * Fix violations of appendclipped * Add modernize "bloop" analyzer. * Add modernize "fmtappendf" analyzer. * Add modernize "forvar" analyzer. * Add modernize "mapsloop" analyzer. * Add modernize "minmax" analyzer. * Fix violations of minmax analyzer * Add modernize "omitzero" analyzer. * Add modernize "rangeint" analyzer. * Fix violations of rangeint. * Add modernize "reflecttypefor" analyzer. * Fix violations of reflecttypefor analyzer. * Add modernize "slicescontains" analyzer. * Add modernize "slicessort" analyzer. * Add modernize "slicesdelete" analyzer. This is disabled by default for now. See https://go.dev/issue/73686. * Add modernize "stringscutprefix" analyzer. * Add modernize "stringsbuilder" analyzer. * Fix violations of stringsbuilder analyzer. * Add modernize "stringsseq" analyzer. * Add modernize "testingcontext" analyzer. * Add modernize "waitgroup" analyzer. * Changelog fragment * gofmt * gazelle * Add modernize "newexpr" analyzer. * Disable newexpr until go1.26 * Add more details in WORKSPACE on how to update the override * @nalepae feedback on min() * gofmt * Fix violations of forvar
108 lines
1.6 KiB
Go
108 lines
1.6 KiB
Go
package leakybucket
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestLen(t *testing.T) {
|
|
q := make(priorityQueue, 0, 4096)
|
|
|
|
if q.Len() != 0 {
|
|
t.Fatal("Queue should be empty?!")
|
|
}
|
|
|
|
for i := 1; i <= 5; i++ {
|
|
b := NewLeakyBucket(1.0, 5, time.Second)
|
|
q.Push(b)
|
|
|
|
l := q.Len()
|
|
if l != i {
|
|
t.Fatalf("Expected length %d, got %d", i, l)
|
|
}
|
|
}
|
|
for i := 4; i >= 0; i-- {
|
|
q.Pop()
|
|
|
|
l := q.Len()
|
|
if l != i {
|
|
t.Fatalf("Expected length %d, got %d", i, l)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestPeak(t *testing.T) {
|
|
q := make(priorityQueue, 0, 4096)
|
|
|
|
for range 5 {
|
|
b := NewLeakyBucket(1.0, 5, time.Second)
|
|
q.Push(b)
|
|
}
|
|
}
|
|
|
|
func TestLess(t *testing.T) {
|
|
q := make(priorityQueue, 0, 4096)
|
|
|
|
for i := range 5 {
|
|
b := NewLeakyBucket(1.0, 5, time.Second)
|
|
b.p = now().Add(time.Duration(i))
|
|
q.Push(b)
|
|
}
|
|
|
|
for i, j := 0, 4; i < 5; i, j = i+1, j-1 {
|
|
if i < j && !q.Less(i, j) {
|
|
t.Fatal("Less is more?!")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestSwap(t *testing.T) {
|
|
q := make(priorityQueue, 0, 4096)
|
|
|
|
for range 5 {
|
|
b := NewLeakyBucket(1.0, 5, time.Second)
|
|
q.Push(b)
|
|
}
|
|
|
|
i := 2
|
|
j := 4
|
|
|
|
bi := q[i]
|
|
bj := q[j]
|
|
|
|
q.Swap(i, j)
|
|
|
|
if bi != q[j] || bj != q[i] {
|
|
t.Fatal("Element weren't swapped?!")
|
|
}
|
|
}
|
|
|
|
func TestPush(t *testing.T) {
|
|
q := make(priorityQueue, 0, 4096)
|
|
|
|
for range 5 {
|
|
b := NewLeakyBucket(1.0, 5, time.Second)
|
|
q.Push(b)
|
|
|
|
if b != q[len(q)-1] {
|
|
t.Fatal("Push should append to queue.")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestPop(t *testing.T) {
|
|
q := make(priorityQueue, 0, 4096)
|
|
|
|
for i := 1; i <= 5; i++ {
|
|
b := NewLeakyBucket(1.0, 5, time.Second)
|
|
q.Push(b)
|
|
}
|
|
|
|
for i := 1; i <= 5; i++ {
|
|
b := q[len(q)-1]
|
|
if b != q.Pop() {
|
|
t.Fatal("Pop should remove from end of queue.")
|
|
}
|
|
}
|
|
}
|