mirror of
https://github.com/ergochat/ergo.git
synced 2025-01-10 12:12:37 +01:00
9fe65223db
Use []uint32 in bitset instead of []uint64, because it's harder to guarantee 64-bit alignment of []uint64 than I had realized: https://go101.org/article/memory-layout.html
84 lines
1.8 KiB
Go
84 lines
1.8 KiB
Go
// Copyright (c) 2018 Shivaram Lingamneni <slingamn@cs.stanford.edu>
|
|
// released under the MIT license
|
|
|
|
package utils
|
|
|
|
import "testing"
|
|
|
|
type testBitset [4]uint32
|
|
|
|
func TestSets(t *testing.T) {
|
|
var t1 testBitset
|
|
t1s := t1[:]
|
|
|
|
if BitsetGet(t1s, 0) || BitsetGet(t1s, 63) || BitsetGet(t1s, 64) || BitsetGet(t1s, 127) {
|
|
t.Error("no bits should be set in a newly initialized bitset")
|
|
}
|
|
|
|
var i uint
|
|
for i = 0; i < 128; i++ {
|
|
if i%2 == 0 {
|
|
if !BitsetSet(t1s, i, true) {
|
|
t.Error("setting an uninitialized bit should return true")
|
|
}
|
|
}
|
|
}
|
|
|
|
if BitsetSet(t1s, 24, true) {
|
|
t.Error("setting an already-set bit should return false")
|
|
}
|
|
|
|
if !(BitsetGet(t1s, 0) && !BitsetGet(t1s, 1) && BitsetGet(t1s, 64) && BitsetGet(t1s, 72) && !BitsetGet(t1s, 127)) {
|
|
t.Error("exactly the even-numbered bits should be set")
|
|
}
|
|
|
|
if !BitsetSet(t1s, 72, false) {
|
|
t.Error("removing a set bit should return true")
|
|
}
|
|
|
|
if BitsetGet(t1s, 72) {
|
|
t.Error("remove doesn't work")
|
|
}
|
|
|
|
if BitsetSet(t1s, 72, false) {
|
|
t.Error("removing an unset bit should return false")
|
|
}
|
|
|
|
var t2 testBitset
|
|
t2s := t2[:]
|
|
|
|
for i = 0; i < 128; i++ {
|
|
if i%2 == 1 {
|
|
BitsetSet(t2s, i, true)
|
|
}
|
|
}
|
|
|
|
BitsetUnion(t1s, t2s)
|
|
for i = 0; i < 128; i++ {
|
|
expected := (i != 72)
|
|
if BitsetGet(t1s, i) != expected {
|
|
t.Error("all bits should be set except 72")
|
|
}
|
|
}
|
|
|
|
var t3 testBitset
|
|
t3s := t3[:]
|
|
BitsetSet(t3s, 72, true)
|
|
if !BitsetGet(t3s, 72) {
|
|
t.Error("bit 72 should be set")
|
|
}
|
|
// copy t1 on top of t2
|
|
BitsetCopy(t3s, t1s)
|
|
for i = 0; i < 128; i++ {
|
|
expected := (i != 72)
|
|
if BitsetGet(t3s, i) != expected {
|
|
t.Error("all bits should be set except 72")
|
|
}
|
|
}
|
|
|
|
BitsetSubtract(t3s, t2s)
|
|
if !BitsetGet(t3s, 0) || BitsetGet(t3s, 72) || !BitsetGet(t3s, 74) || BitsetGet(t3s, 71) {
|
|
t.Error("subtract doesn't work")
|
|
}
|
|
}
|