Documentation ¶
Index ¶
- Variables
- func Bind(rt *goja.Runtime, v interface{}, ctxPtr *context.Context) map[string]interface{}
- func BindToGlobal(rt *goja.Runtime, data map[string]interface{}) func()
- func FieldName(t reflect.Type, f reflect.StructField) string
- func GetRuntime(ctx context.Context) *goja.Runtime
- func MethodName(t reflect.Type, m reflect.Method) string
- func NewRandSource() goja.RandSource
- func RunString(rt *goja.Runtime, src string) (goja.Value, error)
- func Throw(rt *goja.Runtime, err error)
- func WithRuntime(ctx context.Context, rt *goja.Runtime) context.Context
- func WithState(ctx context.Context, state *State) context.Context
- type FieldNameMapper
- type State
Constants ¶
This section is empty.
Variables ¶
View Source
var DefaultRandSource = NewRandSource()
Functions ¶
func BindToGlobal ¶
Binds an object's members to the global scope. Returns a function that un-binds them. Note that this will panic if passed something that isn't a struct; please don't do that.
func FieldName ¶
func FieldName(t reflect.Type, f reflect.StructField) string
Returns the JS name for an exported struct field. The name is snake_cased, with respect for certain common initialisms (URL, ID, HTTP, etc).
func MethodName ¶
Returns the JS name for an exported method. The first letter of the method's name is lowercased, otherwise it is unaltered.
func NewRandSource ¶
func NewRandSource() goja.RandSource
func RunString ¶
Runs an ES6 string in the given runtime. Use this rather than writing ES5 in tests.
Types ¶
type FieldNameMapper ¶
type FieldNameMapper struct{}
FieldNameMapper for goja.Runtime.SetFieldNameMapper()
func (FieldNameMapper) FieldName ¶
func (FieldNameMapper) FieldName(t reflect.Type, f reflect.StructField) string
func (FieldNameMapper) MethodName ¶
type State ¶
type State struct { // Global options. Options lib.Options // Logger. Avoid using the global logger. Logger *log.Logger // Current group; all emitted metrics are tagged with this. Group *lib.Group // Networking equipment. HTTPTransport http.RoundTripper Dialer *netext.Dialer CookieJar *cookiejar.Jar // Rate limits. RPSLimit *rate.Limiter // Sample buffer, emitted at the end of the iteration. Samples []stats.Sample // Bytes sent and received during this iteration. Use `sync/atomic`. BytesRead, BytesWritten int64 // Buffer pool; use instead of allocating fresh buffers when possible. BPool *bpool.BufferPool Vu, Iteration int64 }
Provides volatile state for a VU.
Click to show internal directories.
Click to hide internal directories.