diff --git a/docs/modules.md b/docs/modules.md index 2ac91ee18c..0cbc14c34e 100644 --- a/docs/modules.md +++ b/docs/modules.md @@ -214,7 +214,7 @@ See [examples/sunrise.star](../examples/sunrise.star) for an example. ## Pixlet module: Random -The `random` module provides a pseudorandom number generator for pixlet. The generator is automatically seeded to a new random value on each execution, but a deterministic seed can also be set. +The `random` module provides a pseudorandom number generator for pixlet. The generator is automatically seeded on each execution. The seed itself changes every 15 seconds, making apps deterministic over that same time window. This behavior enables more effective caching of execution results on Tidbyt servers. Developer can reseed via `random.seed` if needed. | Function | Description | | --- | --- | diff --git a/runtime/modules/random/random.go b/runtime/modules/random/random.go index 9cab9d9306..24e124ba08 100644 --- a/runtime/modules/random/random.go +++ b/runtime/modules/random/random.go @@ -11,8 +11,9 @@ import ( ) const ( - ModuleName = "random" - threadRandKey = "tidbyt.dev/pixlet/runtime/random" + ModuleName = "random" + threadRandKey = "tidbyt.dev/pixlet/runtime/random" + randomSeedWindow = 15 ) var ( @@ -21,10 +22,16 @@ var ( ) func AttachToThread(t *starlark.Thread) { + nowSeconds := time.Now().UnixMilli() / 1000 + t.SetLocal( threadRandKey, rand.New( - rand.NewSource(rand.Int63()), + // Seed RNG with a constant for brief time + // windows. This allows app to be "random", + // while still enabling Tidbyt's backend to + // cache the results. + rand.NewSource(nowSeconds/randomSeedWindow), ), ) }