fixed an endless loop when length of chars is a divisor of 256
This commit is contained in:
parent
bc4af7603a
commit
1b691aeab2
@ -56,7 +56,7 @@ func NewLenChars(length int, chars []byte) string {
|
||||
panic("error reading from random source: " + err.Error())
|
||||
}
|
||||
for _, c := range r {
|
||||
if c >= maxrb {
|
||||
if c > maxrb {
|
||||
// Skip this number to avoid modulo bias.
|
||||
continue
|
||||
}
|
||||
|
@ -2,13 +2,7 @@ package uniuri
|
||||
|
||||
import "testing"
|
||||
|
||||
func TestNew(t *testing.T) {
|
||||
u := New()
|
||||
// Check length
|
||||
if len(u) != StdLen {
|
||||
t.Fatalf("wrong length: expected %d, got %d", StdLen, len(u))
|
||||
}
|
||||
// Check that only allowed characters are present
|
||||
func validateChars(t *testing.T, u string, chars []byte) {
|
||||
for _, c := range u {
|
||||
var present bool
|
||||
for _, a := range StdChars {
|
||||
@ -20,6 +14,17 @@ func TestNew(t *testing.T) {
|
||||
t.Fatalf("chars not allowed in %q", u)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestNew(t *testing.T) {
|
||||
u := New()
|
||||
// Check length
|
||||
if len(u) != StdLen {
|
||||
t.Fatalf("wrong length: expected %d, got %d", StdLen, len(u))
|
||||
}
|
||||
// Check that only allowed characters are present
|
||||
validateChars(t, u, StdChars)
|
||||
|
||||
// Generate 1000 uniuris and check that they are unique
|
||||
uris := make([]string, 1000)
|
||||
for i, _ := range uris {
|
||||
@ -33,3 +38,16 @@ func TestNew(t *testing.T) {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestNewLenChars(t *testing.T) {
|
||||
length := 10
|
||||
chars := []byte("01234567")
|
||||
u := NewLenChars(length, chars)
|
||||
|
||||
// Check length
|
||||
if len(u) != length {
|
||||
t.Fatalf("wrong length: expected %d, got %d", StdLen, len(u))
|
||||
}
|
||||
// Check that only allowed characters are present
|
||||
validateChars(t, u, chars)
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user