v0.4.0-rc.2
Pre-release
Pre-release
Features
Summary:
- Goss v0.4.X introduces some major enhancements to the matching logic allowing far more flexibility for asserts.
- For example, can assert that the output of
echo "3"
is less than 5.
- For example, can assert that the output of
- Introduces some minor breaking changes (see below)
Since v0.4.0-rc.1
- Added: string diff support (#827)
- Changed: split ops and
vfs-opts
(#826)- Note: this effectively removes the
mount.opts
breaking change when upgrading from v0.3.X
- Note: this effectively removes the
Matcher change
v4 introduced the ability to compare different types and more advanced string matching. See matchers section in the manual for more information.
For example:
command:
echo_test:
# command that outputs JSON, but this could be anything, http response, command output, etc
exec: |
echo '{"string_value": "15"}'
exit-status: 0
stdout:
# advanced string parsing
gjson:
# extract "string_value"
string_value:
and:
# The value is numerically <= 20 (auto type conversion)
- le: 20
# The value is numerically 15
- 15
# Equal does a strict check, the types have to match, hence string_value is "15" but not 15
- equal: "15"
- not: {equal: 15}
This conversion also allows treating an io.Reader (memory efficient line-by-line parsing) as a whole string (when compared with a string). This has the benefit of showing the full command output, which was a long-requested feature. For example:
$ cat goss.yaml
command:
echo_test:
exec: |
echo 'hello world'
exit-status: 0
stdout: |
goodbye world
$ goss v
.F
Failures/Skipped:
Command: echo_test: stdout:
Expected
"hello world\n"
to equal
"goodbye world\n"
Total Duration: 0.001s
Count: 2, Failed: 1, Skipped: 0
Breaking changes
- Changed:
file.Contains
->file.Contents
- Changed: RPM Version is now full EVR (
-qf "%|EPOCH?{%{EPOCH}:}:{}|%{VERSION}-%{RELEASE}
), this opens the door for proper rpm version comparison in the future - For array matches (ex.
user.Groups
) duplicate entries will raise an error if they don't exist in the system.
In goss 3.X this would succeed:
user:
xxx:
exists: true
groups:
- foo
- wheel
- wheel
Now it will throw an error unless groups actually contain 2 copies of "wheel" in its response array from the system.
You can mimic the old behavior by modifying the test as follows:
user:
xxx:
exists: true
groups:
and:
- contain-element: foo
- contain-element: wheel
- contain-element: wheel
- Goss is more aware of types with goss v4, so ensure when doing string matching that integers and floats are surrounded by double quotes.
For example, this no longer works:
command:
echo "123":
exit-status: 0
stdout:
- 123
New way:
command:
echo "123":
exit-status: 0
stdout:
- "123"
Changes
- Added: transforms support (closes #538)
- Allows comparison of string to int, ex: ensuring a systctl output below/above a specific number (closes #220)
- Allows JSON parsing/validation support (closes #578)
- Allows comparing command output to a string, this will display the failed output on failure (closes #483)
-o include_raw
will show the non-transformed value
- Added: Some new matchers
equal
matcher added to do strict type comparison (e.x. string to string)contain-substring
have-patterns
- This mimics the existing default behavior of file contents and command outputcontain-elements
- checks that an array value matches a set of matchers
- Added: runlevels support for service
- Added: option to sort output (closes #416)
- Added: All resources now support key override (closes #518, closes #742)
- Added: Use exit code 78 if test file is unparseable (closes #317)
- Changed: removed alpha from non-linux binary names
- Changed: StartTime is no longer calculated from goss start. Calculated from first test start, this allows accurate reporting when showing a cached result
- Changed: Completely re-worked matchers and shared output logic
- Changed: Cache test results in serve instead of output (closes #612)
- Added: Significantly improved test coverage of matcher, output code
- Changed: Doc to reference
cat -E /proc/<PID>/comm
to avoid whitespace issues (closes #762) - Changed: Removed file.Size from autoadd (closes #262)
- Added:
matcher.as-reader
this allows the matcher string to behave as an io.Reader output. Can be useful for testing - Removed:
json_online
output format, use:goss v -f json -o oneline