Skip to main content

Selection functions

var

Commentary

added in 0.0.5

Look up a variable defined in the top-level vars or varsOnce sections, optionally drilling into its subvalue with path. Vars may refer to other variables.

If you make multiple references to the same var in a single generator, you are guaranteed to get the same value each time.

Values in varsOnce are only ever evaluated once, and then locked for the duration of the generator, as the name implies.

You can use vars to generate multiple values in one shot, then drill into them with the path function modifier. 1


Examples

Retrieve a variable

Use vars to generate a fresh value for each iteration. Use varsOnce to generate values only once and then lock them.

{
"topic": "sandbox",
"vars": {
"val1": {
"_gen": "uniformDistribution",
"bounds": [
1,
5
]
}
},
"varsOnce": {
"val2": {
"_gen": "uniformDistribution",
"bounds": [
1,
5
]
}
},
"value": {
"val1": {
"_gen": "var",
"var": "val1"
},
"val2": {
"_gen": "var",
"var": "val2"
}
}
}
[
{
"val1": 2.9061307556033125,
"val2": 2.9328274755679455
},
{
"val1": 2.6928066694820765,
"val2": 2.9328274755679455
},
{
"val1": 4.414892023009555,
"val2": 2.9328274755679455
},
{
"val1": 3.5409869216123346,
"val2": 2.9328274755679455
},
{
"val1": 2.9073119943325,
"val2": 2.9328274755679455
}
]

Drill into a map

Use a compound structure, like a map, to generate multiple values assigned to one var. This is especially useful for choices where two or more values relate to each other.

{
"topic": "sandbox",
"vars": {
"profile": {
"_gen": "oneOf",
"choices": [
{
"luckyNumber": {
"_gen": "uniformDistribution",
"bounds": [
1,
50
],
"decimals": 0
},
"active": false
},
{
"luckyNumber": {
"_gen": "uniformDistribution",
"bounds": [
50,
99
],
"decimals": 0
},
"active": true
}
]
}
},
"value": {
"userProfile": {
"theNumber": {
"_gen": "var",
"var": "profile",
"path": [
"luckyNumber"
]
},
"tags": {
"isActive": {
"_gen": "var",
"var": "profile",
"path": [
"active"
]
}
}
}
}
}
[
{
"userProfile": {
"theNumber": 48,
"tags": {
"isActive": false
}
}
},
{
"userProfile": {
"theNumber": 96,
"tags": {
"isActive": true
}
}
},
{
"userProfile": {
"theNumber": 36,
"tags": {
"isActive": false
}
}
},
{
"userProfile": {
"theNumber": 67,
"tags": {
"isActive": true
}
}
},
{
"userProfile": {
"theNumber": 72,
"tags": {
"isActive": true
}
}
}
]

Specification

JSON schema

{
"type": "object",
"properties": {
"var": {
"type": "string"
},
"path": {
"type": "array",
"items": {
"oneOf": [
{
"type": "integer",
"minimum": 0
},
{
"type": "string"
}
]
}
}
},
"required": [
"var"
]
}