Documentation ¶
Overview ¶
Package js is the JavaScript implementation of the lib.Runner and relative concepts for executing concurrent-safe JavaScript code.
Index ¶
- type ActiveVU
- type Bundle
- type BundleInstance
- type Runner
- func (r *Runner) GetOptions() lib.Options
- func (r *Runner) GetSetupData() []byte
- func (r *Runner) HandleSummary(ctx context.Context, summary *lib.Summary) (map[string]io.Reader, error)
- func (r *Runner) IsExecutable(name string) bool
- func (r *Runner) MakeArchive() *lib.Archive
- func (r *Runner) NewVU(ctx context.Context, idLocal, idGlobal uint64, ...) (lib.InitializedVU, error)
- func (r *Runner) SetOptions(opts lib.Options) error
- func (r *Runner) SetSetupData(data []byte)
- func (r *Runner) Setup(ctx context.Context, out chan<- metrics.SampleContainer) error
- func (r *Runner) Teardown(ctx context.Context, out chan<- metrics.SampleContainer) error
- type VU
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ActiveVU ¶ added in v0.27.0
type ActiveVU struct { *VU *lib.VUActivationParams // contains filtered or unexported fields }
ActiveVU holds a VU and its activation parameters
type Bundle ¶ added in v0.13.0
type Bundle struct { Options lib.Options CompatibilityMode lib.CompatibilityMode // parsed value ModuleResolver *modules.ModuleResolver // contains filtered or unexported fields }
A Bundle is a self-contained bundle of scripts and resources. You can use this to produce identical BundleInstance objects.
func NewBundle ¶ added in v0.13.0
func NewBundle( piState *lib.TestPreInitState, src *loader.SourceData, filesystems map[string]fsext.Fs, ) (*Bundle, error)
NewBundle creates a new bundle from a source file and a filesystem.
func NewBundleFromArchive ¶ added in v0.15.0
NewBundleFromArchive creates a new bundle from an lib.Archive.
func (*Bundle) Instantiate ¶ added in v0.13.0
Instantiate creates a new runtime from this bundle.
type BundleInstance ¶ added in v0.13.0
A BundleInstance is a self-contained instance of a Bundle.
type Runner ¶
type Runner struct { Bundle *Bundle BaseDialer net.Dialer Resolver netext.Resolver // TODO: Remove ActualResolver, it's a hack to simplify mocking in tests. ActualResolver netext.MultiResolver RPSLimit *rate.Limiter RunTags *metrics.TagSet BufferPool *lib.BufferPool // contains filtered or unexported fields }
Runner implements lib.Runner and is used to run js tests
func New ¶
func New(piState *lib.TestPreInitState, src *loader.SourceData, filesystems map[string]fsext.Fs) (*Runner, error)
New returns a new Runner for the provided source
func NewFromArchive ¶ added in v0.15.0
NewFromArchive returns a new Runner from the source in the provided archive
func NewFromBundle ¶ added in v0.15.0
func NewFromBundle(piState *lib.TestPreInitState, b *Bundle) (*Runner, error)
NewFromBundle returns a new Runner from the provided Bundle
func (*Runner) GetOptions ¶
GetOptions returns the currently calculated lib.Options for the given Runner.
func (*Runner) GetSetupData ¶ added in v0.21.0
GetSetupData returns the setup data as json if Setup() was specified and executed, nil otherwise
func (*Runner) HandleSummary ¶ added in v0.32.0
func (r *Runner) HandleSummary(ctx context.Context, summary *lib.Summary) (map[string]io.Reader, error)
HandleSummary calls the specified summary callback, if supplied.
func (*Runner) IsExecutable ¶ added in v0.27.0
IsExecutable returns whether the given name is an exported and executable function in the script.
func (*Runner) MakeArchive ¶ added in v0.15.0
MakeArchive creates an Archive of the runner. There should be a corresponding NewFromArchive() function that will restore the runner from the archive.
func (*Runner) NewVU ¶
func (r *Runner) NewVU( ctx context.Context, idLocal, idGlobal uint64, samplesOut chan<- metrics.SampleContainer, ) (lib.InitializedVU, error)
NewVU returns a new initialized VU.
func (*Runner) SetOptions ¶ added in v0.18.1
SetOptions sets the test Options to the provided data and makes necessary changes to the Runner.
func (*Runner) SetSetupData ¶ added in v0.21.0
SetSetupData saves the externally supplied setup data as json in the runner, so it can be used in VUs
type VU ¶
type VU struct { BundleInstance Runner *Runner Transport *http.Transport Dialer *netext.Dialer CookieJar *cookiejar.Jar TLSConfig *tls.Config ID uint64 // local to the current instance IDGlobal uint64 // global across all instances Console *console BufferPool *lib.BufferPool Samples chan<- metrics.SampleContainer // contains filtered or unexported fields }
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package common contains helpers for interacting with the JavaScript runtime.
|
Package common contains helpers for interacting with the JavaScript runtime. |
Package compiler implements additional functionality for k6 to compile js code.
|
Package compiler implements additional functionality for k6 to compile js code. |
Package eventloop implements an event loop to be used thought js and it's subpackages
|
Package eventloop implements an event loop to be used thought js and it's subpackages |
Package modules defines interfaces used for developing k6's JavaScript modules.
|
Package modules defines interfaces used for developing k6's JavaScript modules. |
k6
Package k6 implements the module imported as 'k6' from inside k6.
|
Package k6 implements the module imported as 'k6' from inside k6. |
k6/crypto
Package crypto provides common hashing function for the k6
|
Package crypto provides common hashing function for the k6 |
k6/crypto/x509
Package x509 provides X.509 certificate parsing for the k6
|
Package x509 provides X.509 certificate parsing for the k6 |
k6/data
Package data implements `k6/data` js module for k6.
|
Package data implements `k6/data` js module for k6. |
k6/encoding
Package encoding provides encoding/decoding functionality for the k6
|
Package encoding provides encoding/decoding functionality for the k6 |
k6/execution
Package execution implements k6/execution which lets script find out more about it is execution.
|
Package execution implements k6/execution which lets script find out more about it is execution. |
k6/experimental
Package experimental includes experimental module features
|
Package experimental includes experimental module features |
k6/experimental/csv
Package csv provides a CSV parser for k6.
|
Package csv provides a CSV parser for k6. |
k6/experimental/fs
Package fs provides a k6 module that allows users to interact with files from the local filesystem as per the [File API design document].
|
Package fs provides a k6 module that allows users to interact with files from the local filesystem as per the [File API design document]. |
k6/experimental/streams
Package streams provides support for the Web Streams API.
|
Package streams provides support for the Web Streams API. |
k6/experimental/tracing
Package tracing implements a k6 JS module for instrumenting k6 scripts with tracing context information.
|
Package tracing implements a k6 JS module for instrumenting k6 scripts with tracing context information. |
k6/grpc
Package grpc is the root module of the k6-grpc extension.
|
Package grpc is the root module of the k6-grpc extension. |
k6/html
generated by js/modules/k6/html/gen/gen_elements.go; DO NOT EDIT
|
generated by js/modules/k6/html/gen/gen_elements.go; DO NOT EDIT |
k6/html/gen
Package main - this package generates some of the code for k6/html
|
Package main - this package generates some of the code for k6/html |
k6/http
Package http implements the k6/http js module for k6.
|
Package http implements the k6/http js module for k6. |
k6/metrics
Package metrics implements k6/metrics and let script work with custom metrics.
|
Package metrics implements k6/metrics and let script work with custom metrics. |
k6/timers
Package timers is implementing setInterval setTimeout and co.
|
Package timers is implementing setInterval setTimeout and co. |
k6/ws
Package ws implements a k6/ws for k6.
|
Package ws implements a k6/ws for k6. |
Package modulestest contains helpers to test js modules
|
Package modulestest contains helpers to test js modules |
Package promises provides helpers for working with promises in k6.
|
Package promises provides helpers for working with promises in k6. |