2014-12-07 16:41:24 +01:00
|
|
|
// Copyright (C) 2014 The Syncthing Authors.
|
|
|
|
//
|
2015-03-07 21:36:35 +01:00
|
|
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
|
|
// You can obtain one at http://mozilla.org/MPL/2.0/.
|
2014-12-07 16:41:24 +01:00
|
|
|
|
2016-03-25 07:35:18 +00:00
|
|
|
package util
|
2014-12-07 16:41:24 +01:00
|
|
|
|
2015-01-06 23:03:35 +01:00
|
|
|
import (
|
2015-06-01 09:33:08 +02:00
|
|
|
"runtime"
|
2015-01-06 23:03:35 +01:00
|
|
|
"sync"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
var predictableRandomTest sync.Once
|
2014-12-07 16:41:24 +01:00
|
|
|
|
|
|
|
func TestPredictableRandom(t *testing.T) {
|
2015-06-01 09:33:08 +02:00
|
|
|
if runtime.GOARCH != "amd64" {
|
|
|
|
t.Skip("Test only for 64 bit platforms; but if it works there, it should work on 32 bit")
|
|
|
|
}
|
2015-01-06 23:03:35 +01:00
|
|
|
predictableRandomTest.Do(func() {
|
|
|
|
// predictable random sequence is predictable
|
2015-06-01 09:33:08 +02:00
|
|
|
e := int64(3440579354231278675)
|
2016-03-25 07:35:18 +00:00
|
|
|
if v := int64(PredictableRandom.Int()); v != e {
|
2015-01-06 23:03:35 +01:00
|
|
|
t.Errorf("Unexpected random value %d != %d", v, e)
|
|
|
|
}
|
|
|
|
})
|
2014-12-07 16:41:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestSeedFromBytes(t *testing.T) {
|
|
|
|
// should always return the same seed for the same bytes
|
|
|
|
tcs := []struct {
|
|
|
|
bs []byte
|
|
|
|
v int64
|
|
|
|
}{
|
|
|
|
{[]byte("hello world"), -3639725434188061933},
|
|
|
|
{[]byte("hello worlx"), -2539100776074091088},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range tcs {
|
2016-03-25 07:35:18 +00:00
|
|
|
if v := SeedFromBytes(tc.bs); v != tc.v {
|
2014-12-07 16:41:24 +01:00
|
|
|
t.Errorf("Unexpected seed value %d != %d", v, tc.v)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRandomString(t *testing.T) {
|
|
|
|
for _, l := range []int{0, 1, 2, 3, 4, 8, 42} {
|
2016-03-25 07:35:18 +00:00
|
|
|
s := RandomString(l)
|
2014-12-07 16:41:24 +01:00
|
|
|
if len(s) != l {
|
2014-12-08 16:19:08 +01:00
|
|
|
t.Errorf("Incorrect length %d != %d", len(s), l)
|
2014-12-07 16:41:24 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
strings := make([]string, 1000)
|
|
|
|
for i := range strings {
|
2016-03-25 07:35:18 +00:00
|
|
|
strings[i] = RandomString(8)
|
2014-12-07 16:41:24 +01:00
|
|
|
for j := range strings {
|
|
|
|
if i == j {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if strings[i] == strings[j] {
|
|
|
|
t.Errorf("Repeated random string %q", strings[i])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRandomInt64(t *testing.T) {
|
|
|
|
ints := make([]int64, 1000)
|
|
|
|
for i := range ints {
|
2016-03-25 07:35:18 +00:00
|
|
|
ints[i] = RandomInt64()
|
2014-12-07 16:41:24 +01:00
|
|
|
for j := range ints {
|
|
|
|
if i == j {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if ints[i] == ints[j] {
|
|
|
|
t.Errorf("Repeated random int64 %d", ints[i])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|