90 lines
2.4 KiB
Go
90 lines
2.4 KiB
Go
|
// +build acceptance common
|
||
|
|
||
|
package tools
|
||
|
|
||
|
import (
|
||
|
"crypto/rand"
|
||
|
"errors"
|
||
|
mrand "math/rand"
|
||
|
"os"
|
||
|
"time"
|
||
|
|
||
|
"github.com/rackspace/gophercloud"
|
||
|
)
|
||
|
|
||
|
// ErrTimeout is returned if WaitFor takes longer than 300 second to happen.
|
||
|
var ErrTimeout = errors.New("Timed out")
|
||
|
|
||
|
// OnlyRS overrides the default Gophercloud behavior of using OS_-prefixed environment variables
|
||
|
// if RS_ variables aren't present. Otherwise, they'll stomp over each other here in the acceptance
|
||
|
// tests, where you need to have both defined.
|
||
|
func OnlyRS(original gophercloud.AuthOptions) gophercloud.AuthOptions {
|
||
|
if os.Getenv("RS_AUTH_URL") == "" {
|
||
|
original.IdentityEndpoint = ""
|
||
|
}
|
||
|
if os.Getenv("RS_USERNAME") == "" {
|
||
|
original.Username = ""
|
||
|
}
|
||
|
if os.Getenv("RS_PASSWORD") == "" {
|
||
|
original.Password = ""
|
||
|
}
|
||
|
if os.Getenv("RS_API_KEY") == "" {
|
||
|
original.APIKey = ""
|
||
|
}
|
||
|
return original
|
||
|
}
|
||
|
|
||
|
// WaitFor polls a predicate function once per second to wait for a certain state to arrive.
|
||
|
func WaitFor(predicate func() (bool, error)) error {
|
||
|
for i := 0; i < 300; i++ {
|
||
|
time.Sleep(1 * time.Second)
|
||
|
|
||
|
satisfied, err := predicate()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
if satisfied {
|
||
|
return nil
|
||
|
}
|
||
|
}
|
||
|
return ErrTimeout
|
||
|
}
|
||
|
|
||
|
// MakeNewPassword generates a new string that's guaranteed to be different than the given one.
|
||
|
func MakeNewPassword(oldPass string) string {
|
||
|
randomPassword := RandomString("", 16)
|
||
|
for randomPassword == oldPass {
|
||
|
randomPassword = RandomString("", 16)
|
||
|
}
|
||
|
return randomPassword
|
||
|
}
|
||
|
|
||
|
// RandomString generates a string of given length, but random content.
|
||
|
// All content will be within the ASCII graphic character set.
|
||
|
// (Implementation from Even Shaw's contribution on
|
||
|
// http://stackoverflow.com/questions/12771930/what-is-the-fastest-way-to-generate-a-long-random-string-in-go).
|
||
|
func RandomString(prefix string, n int) string {
|
||
|
const alphanum = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
|
||
|
var bytes = make([]byte, n)
|
||
|
rand.Read(bytes)
|
||
|
for i, b := range bytes {
|
||
|
bytes[i] = alphanum[b%byte(len(alphanum))]
|
||
|
}
|
||
|
return prefix + string(bytes)
|
||
|
}
|
||
|
|
||
|
// RandomInt will return a random integer between a specified range.
|
||
|
func RandomInt(min, max int) int {
|
||
|
mrand.Seed(time.Now().Unix())
|
||
|
return mrand.Intn(max-min) + min
|
||
|
}
|
||
|
|
||
|
// Elide returns the first bit of its input string with a suffix of "..." if it's longer than
|
||
|
// a comfortable 40 characters.
|
||
|
func Elide(value string) string {
|
||
|
if len(value) > 40 {
|
||
|
return value[0:37] + "..."
|
||
|
}
|
||
|
return value
|
||
|
}
|