mirror of
https://github.com/protocolbuffers/protobuf-go.git
synced 2025-01-17 10:11:58 +00:00
ac50359592
So far only Ints is being used and it does not seem like the other set types will ever be used. Remove them. We can always add them back if we need them again. Change-Id: I9a9e8ce76bd231d1fe5b726af7da690dc4019bb8 Reviewed-on: https://go-review.googlesource.com/c/protobuf/+/170625 Reviewed-by: Herbie Ong <herbie@google.com>
76 lines
1.5 KiB
Go
76 lines
1.5 KiB
Go
// Copyright 2018 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 set
|
|
|
|
import (
|
|
"math/rand"
|
|
"testing"
|
|
)
|
|
|
|
const maxLimit = 1024
|
|
|
|
var toSet, toClear [maxLimit]bool
|
|
|
|
func init() {
|
|
r := rand.New(rand.NewSource(0))
|
|
for i := 0; i < maxLimit; i++ {
|
|
toSet[i] = r.Intn(2) == 0
|
|
toClear[i] = r.Intn(2) == 0
|
|
}
|
|
}
|
|
|
|
func TestInts(t *testing.T) {
|
|
ns := new(Ints)
|
|
|
|
// Check that set starts empty.
|
|
wantLen := 0
|
|
if ns.Len() != wantLen {
|
|
t.Errorf("init: Len() = %d, want %d", ns.Len(), wantLen)
|
|
}
|
|
for i := 0; i < maxLimit; i++ {
|
|
if ns.Has(uint64(i)) {
|
|
t.Errorf("init: Has(%d) = true, want false", i)
|
|
}
|
|
}
|
|
|
|
// Set some numbers.
|
|
for i, b := range toSet[:maxLimit] {
|
|
if b {
|
|
ns.Set(uint64(i))
|
|
wantLen++
|
|
}
|
|
}
|
|
|
|
// Check that integers were set.
|
|
if ns.Len() != wantLen {
|
|
t.Errorf("after Set: Len() = %d, want %d", ns.Len(), wantLen)
|
|
}
|
|
for i := 0; i < maxLimit; i++ {
|
|
if got := ns.Has(uint64(i)); got != toSet[i] {
|
|
t.Errorf("after Set: Has(%d) = %v, want %v", i, got, !got)
|
|
}
|
|
}
|
|
|
|
// Clear some numbers.
|
|
for i, b := range toClear[:maxLimit] {
|
|
if b {
|
|
ns.Clear(uint64(i))
|
|
if toSet[i] {
|
|
wantLen--
|
|
}
|
|
}
|
|
}
|
|
|
|
// Check that integers were cleared.
|
|
if ns.Len() != wantLen {
|
|
t.Errorf("after Clear: Len() = %d, want %d", ns.Len(), wantLen)
|
|
}
|
|
for i := 0; i < maxLimit; i++ {
|
|
if got := ns.Has(uint64(i)); got != toSet[i] && !toClear[i] {
|
|
t.Errorf("after Clear: Has(%d) = %v, want %v", i, got, !got)
|
|
}
|
|
}
|
|
}
|