1
1
mirror of https://github.com/wader/fq.git synced 2024-09-20 08:18:51 +03:00
fq/pkg/bitio/buffer_test.go
Mattias Wadman 970465996c Init
2021-09-12 13:08:42 +02:00

96 lines
1.9 KiB
Go

package bitio_test
// TODO: unbreak, check err
import (
"fmt"
"fq/pkg/bitio"
"math/rand"
"strings"
"testing"
)
func TestBufferBitString(t *testing.T) {
testCases := []string{
"",
"1",
"0",
"10",
"01",
"11",
"00",
"1000001",
"0000000",
"10000001",
"00000000",
"100000001",
"000000000",
"101010101",
"111100000",
}
for _, tC := range testCases {
t.Run(tC, func(t *testing.T) {
bb := bitio.NewBufferFromBitString(tC)
actual, err := bb.BitString()
if err != nil {
t.Error(err)
}
if tC != actual {
t.Errorf("expected %s, got %s", tC, actual)
}
for i := int64(0); i < bb.Len(); i++ {
t.Run(fmt.Sprintf("%s_%d", tC, i), func(t *testing.T) {
startBb, _ := bb.BitBufRange(i, bb.Len()-i)
startExpected := tC[i : i+bb.Len()-i]
startActual, _ := startBb.BitString()
if startExpected != startActual {
t.Errorf("startBb expected %s, got %s", startExpected, startActual)
}
lenBb, _ := bb.BitBufRange(0, i)
lenExpected := tC[0:i]
lenActual, _ := lenBb.BitString()
if lenExpected != lenActual {
t.Errorf("lenBb expected %s, got %s", lenExpected, lenActual)
}
})
}
})
}
}
func TestBitStringRandom(t *testing.T) {
r := rand.New(rand.NewSource(0)) //nolint:gosec
for i := 0; i < 10000; i++ {
var ss []string
for j := uint32(0); j < r.Uint32()%1000; j++ {
switch r.Uint32() % 2 {
case 0:
ss = append(ss, "0")
case 1:
ss = append(ss, "1")
}
}
expected := strings.Join(ss, "")
bb := bitio.NewBufferFromBitString(expected)
actual, _ := bb.BitString()
if expected != actual {
t.Errorf("expected %s, got %s", expected, actual)
}
}
}
func TestInvalidBitString(t *testing.T) {
// TODO: check panic?
defer func() {
if err := recover(); err != nil {
// nop
} else {
t.Error("did not panic")
}
}()
bitio.NewBufferFromBitString("01invalid")
}