mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-12 09:01:58 -06:00
only seed math/rand once
Re-seeding the PRNG every time only serves to make the output an obfuscated timestamp. On windows with a low clock resolution, this manifests itself by outputting the same value on calls within the minimum time delta of the clock.
This commit is contained in:
parent
91ae7ec951
commit
a036ea0ec8
@ -16,24 +16,25 @@ import (
|
||||
"golang.org/x/crypto/ssh"
|
||||
)
|
||||
|
||||
func init() {
|
||||
rand.Seed(time.Now().UTC().UnixNano())
|
||||
}
|
||||
|
||||
// Helpers for generating random tidbits for use in identifiers to prevent
|
||||
// collisions in acceptance tests.
|
||||
|
||||
// RandInt generates a random integer
|
||||
func RandInt() int {
|
||||
reseed()
|
||||
return rand.New(rand.NewSource(time.Now().UnixNano())).Int()
|
||||
}
|
||||
|
||||
// RandomWithPrefix is used to generate a unique name with a prefix, for
|
||||
// randomizing names in acceptance tests
|
||||
func RandomWithPrefix(name string) string {
|
||||
reseed()
|
||||
return fmt.Sprintf("%s-%d", name, rand.New(rand.NewSource(time.Now().UnixNano())).Int())
|
||||
}
|
||||
|
||||
func RandIntRange(min int, max int) int {
|
||||
reseed()
|
||||
source := rand.New(rand.NewSource(time.Now().UnixNano()))
|
||||
rangeMax := max - min
|
||||
|
||||
@ -48,7 +49,6 @@ func RandString(strlen int) string {
|
||||
// RandStringFromCharSet generates a random string by selecting characters from
|
||||
// the charset provided
|
||||
func RandStringFromCharSet(strlen int, charSet string) string {
|
||||
reseed()
|
||||
result := make([]byte, strlen)
|
||||
for i := 0; i < strlen; i++ {
|
||||
result[i] = charSet[rand.Intn(len(charSet))]
|
||||
@ -129,11 +129,6 @@ func pemEncode(b []byte, block string) (string, error) {
|
||||
return buf.String(), nil
|
||||
}
|
||||
|
||||
// Seeds random with current timestamp
|
||||
func reseed() {
|
||||
rand.Seed(time.Now().UTC().UnixNano())
|
||||
}
|
||||
|
||||
const (
|
||||
// CharSetAlphaNum is the alphanumeric character set for use with
|
||||
// RandStringFromCharSet
|
||||
|
Loading…
Reference in New Issue
Block a user