package nuid import ( "bytes" "testing" ) func TestDigits(t *testing.T) { if len(digits) != base { t.Fatalf("digits length does not match base modulo") } } func TestGlobalNUIDInit(t *testing.T) { if globalNUID == nil { t.Fatalf("Expected g to be non-nil\n") } if globalNUID.pre == nil || len(globalNUID.pre) != preLen { t.Fatalf("Expected prefix to be initialized\n") } if globalNUID.seq == 0 { t.Fatalf("Expected seq to be non-zero\n") } } func TestNUIDRollover(t *testing.T) { globalNUID.seq = maxSeq // copy oldPre := append([]byte{}, globalNUID.pre...) Next() if bytes.Equal(globalNUID.pre, oldPre) { t.Fatalf("Expected new pre, got the old one\n") } } func TestGUIDLen(t *testing.T) { nuid := Next() if len(nuid) != totalLen { t.Fatalf("Expected len of %d, got %d\n", totalLen, len(nuid)) } } func TestProperPrefix(t *testing.T) { min := byte(255) max := byte(0) for i := 0; i < len(digits); i++ { if digits[i] < min { min = digits[i] } if digits[i] > max { max = digits[i] } } total := 100000 for i := 0; i < total; i++ { n := New() for j := 0; j < preLen; j++ { if n.pre[j] < min || n.pre[j] > max { t.Fatalf("Iter %d. Valid range for bytes prefix: [%d..%d]\nIncorrect prefix at pos %d: %v (%s)", i, min, max, j, n.pre, string(n.pre)) } } } } func BenchmarkNUIDSpeed(b *testing.B) { n := New() b.ReportAllocs() for i := 0; i < b.N; i++ { n.Next() } } func BenchmarkGlobalNUIDSpeed(b *testing.B) { b.ReportAllocs() for i := 0; i < b.N; i++ { Next() } }