Added subset example

This commit is contained in:
Mike Farah 2022-11-01 09:29:05 +11:00
parent ed551bf339
commit 5af062a86f
4 changed files with 46 additions and 7 deletions

View File

@ -1,5 +1 @@
volumes: ["foobar", "foobaz", "blarp"]
beehive-conf:
driver: local
services:
- beehive

View File

@ -1,6 +1,14 @@
# Contains # Contains
This returns `true` if the context contains the passed in parameter, and false otherwise. This returns `true` if the context contains the passed in parameter, and false otherwise. For arrays, this will return true if the passed in array is contained within the array. For strings, it will return true if the string is a substring.
{% hint style="warning" %}
_Note_ that, just like jq, when checking if an array of strings `contains` another, this will use `contains` and _not_ equals to check each string. This means an array like `contains(["cat"])` will return true for an array `["cats"]`.
See the "Array has a subset array" example below on how to check for a subset.
{% endhint %}
## Array contains array ## Array contains array
Array is equal or subset of Array is equal or subset of
@ -20,6 +28,24 @@ will output
true true
``` ```
## Array has a subset array
Subtract the superset array from the subset, if there's anything left, it's not a subset
Given a sample.yml file of:
```yaml
- foobar
- foobaz
- blarp
```
then
```bash
yq '["baz", "bar"] - . | length == 0' sample.yml
```
will output
```yaml
false
```
## Object included in array ## Object included in array
Given a sample.yml file of: Given a sample.yml file of:
```yaml ```yaml

View File

@ -1,3 +1,11 @@
# Contains # Contains
This returns `true` if the context contains the passed in parameter, and false otherwise. This returns `true` if the context contains the passed in parameter, and false otherwise. For arrays, this will return true if the passed in array is contained within the array. For strings, it will return true if the string is a substring.
{% hint style="warning" %}
_Note_ that, just like jq, when checking if an array of strings `contains` another, this will use `contains` and _not_ equals to check each string. This means an array like `contains(["cat"])` will return true for an array `["cats"]`.
See the "Array has a subset array" example below on how to check for a subset.
{% endhint %}

View File

@ -33,6 +33,15 @@ var containsOperatorScenarios = []expressionScenario{
"D0, P[], (!!bool)::true\n", "D0, P[], (!!bool)::true\n",
}, },
}, },
{
description: "Array has a subset array",
subdescription: "Subtract the superset array from the subset, if there's anything left, it's not a subset",
document: `["foobar", "foobaz", "blarp"]`,
expression: `["baz", "bar"] - . | length == 0`,
expected: []string{
"D0, P[], (!!bool)::false\n",
},
},
{ {
skipDoc: true, skipDoc: true,
expression: `["dog", "cat", "giraffe"] | contains(["camel"])`, expression: `["dog", "cat", "giraffe"] | contains(["camel"])`,