OLD | NEW |
| (Empty) |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 package wrapper | |
6 | |
7 import ( | |
8 "math/rand" | |
9 | |
10 "golang.org/x/net/context" | |
11 "infra/libs/clock" | |
12 ) | |
13 | |
14 // MathRandFactory is the function signature for factory methods compatible with | |
15 // SetMathRandFactory. | |
16 type MathRandFactory func(context.Context) *rand.Rand | |
17 | |
18 // GetMathRand gets a *"math/rand".Rand from the context. If one hasn't been | |
19 // set, this creates a new Rand object with a Source initialized from the | |
20 // current time clock.Now(c).UnixNano(). | |
21 func GetMathRand(c context.Context) *rand.Rand { | |
22 if f, ok := c.Value(mathRandKey).(MathRandFactory); ok && f != nil { | |
23 return f(c) | |
24 } | |
25 return rand.New(rand.NewSource(clock.Now(c).UnixNano())) | |
26 } | |
27 | |
28 // SetMathRandFactory sets the function to produce *"math/rand".Rand instances, | |
29 // as returned by the GetMathRand method. | |
30 func SetMathRandFactory(c context.Context, mrf MathRandFactory) context.Context
{ | |
31 return context.WithValue(c, mathRandKey, mrf) | |
32 } | |
33 | |
34 // SetMathRand sets the current *"math/rand".Rand object in the context. Useful | |
35 // for testing with a quick mock. This is just a shorthand SetMathRandFactory | |
36 // invocation to set a factory which always returns the same object. | |
37 func SetMathRand(c context.Context, r *rand.Rand) context.Context { | |
38 if r == nil { | |
39 return SetMathRandFactory(c, nil) | |
40 } | |
41 return SetMathRandFactory(c, func(context.Context) *rand.Rand { return r
}) | |
42 } | |
OLD | NEW |