You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
36 lines
687 B
Go
36 lines
687 B
Go
package bptc
|
|
|
|
import (
|
|
"math/rand"
|
|
"pd0mz/go-dmr/bit"
|
|
)
|
|
import "testing"
|
|
|
|
func Test(t *testing.T) {
|
|
for i := 0; i < 100; i++ {
|
|
test := make(bit.Bits, 96)
|
|
for b := 0; b < 96; b++ {
|
|
if rand.Uint32() > 0x7fffffff {
|
|
test[b].Flip()
|
|
}
|
|
}
|
|
bptc := New(test)
|
|
if len(bptc) != 196 {
|
|
t.Fatalf("expected 196 bits, got %d", len(bptc))
|
|
}
|
|
if testing.Verbose() {
|
|
Dump(bptc)
|
|
}
|
|
corrupt := rand.Intn(10)
|
|
bptc[corrupt].Flip()
|
|
if ok, err := CheckAndRepair(bptc); !ok {
|
|
t.Fatalf("check and repair failed: %v", err)
|
|
}
|
|
bptc[corrupt].Flip()
|
|
back := Extract(bptc)
|
|
if len(test) != len(back) {
|
|
t.Fatalf("expected %d bits, got %d", len(test), len(back))
|
|
}
|
|
}
|
|
}
|