4 releases (breaking)
0.5.0 | Dec 21, 2024 |
---|---|
0.3.1 | Dec 1, 2024 |
0.2.0 | Sep 21, 2024 |
0.1.0 | Jun 27, 2024 |
#846 in Database interfaces
172 downloads per month
145KB
4K
SLoC
ys - yaml-schema
yaml-schema is a tool to validate YAML files against a YAML schema.
The YAML Schema specification is based on JSON Schema (https://json-schema.org/), but expressed as YAML.
yaml-schema is both a Rust library and an executable.
Example Usage
Given a schema.yaml
file containing:
type: object
properties:
foo:
type: string
bar:
type: number
And a valid.yaml
file containing:
foo: "I'm a string"
bar: 42
Then when you issue the command
ys -f schema.yaml valid.yaml
Then the command should succeed with exit code 0
On the other hand, when given an invalid.yaml
file containing:
foo: 42
bar: "I'm a string"
Then the command
ys -f schema.yaml invalid.yaml
Should fail with exit code 1
Features
yaml-schema uses Cucumber to specify and test features:
- CLI usage
- Basic features
- String validation
- Numeric types
- Const
- Enums
- Object types
- Arrays
- Composition
See the features folder for all examples.
Installation
Currently, yaml-schema requires Git, Rust and Cargo to build and install: https://doc.rust-lang.org/cargo/
To install the ys
binary, simply issue the command:
cargo install yaml-schema
That should build and install the executable at $HOME/.cargo/bin/ys
(which should be in your PATH)
Usage
Running ys
without any options or arguments should display the help:
A tool for validating YAML against a schema
Usage: ys [OPTIONS] [FILE] [COMMAND]
Commands:
version Display the ys version
help Print this message or the help of the given subcommand(s)
Arguments:
[FILE] The YAML file to validate
Options:
-f, --schema <SCHEMAS> The schema to validate against
--fail-fast Specify this flag to exit (1) as soon as any error is encountered
-h, --help Print help
-V, --version Print version
Self-Validation
yaml-schema is self-validating. That is, running
cargo run -- -f yaml-schema.yaml yaml-schema.yaml
should always succeed.
Dependencies
~8.5MB
~144K SLoC