Generic configuration validation tool that helps you with warnings, errors and deprecation messages as well as showing users examples of correct configuration.
By default `jest-validate` will print generic warning and error messages. You can however customize this behavior by providing `options: ValidationOptions` object as a second argument:
Almost anything can be overwritten to suite your needs.
### Options
-`recursiveDenylist`– optional array of string keyPaths that should be excluded from deep (recursive) validation.
-`comment`– optional string to be rendered below error/warning message.
-`condition`– an optional function with validation condition.
-`deprecate`, `error`, `unknown`– optional functions responsible for displaying warning and error messages.
-`deprecatedConfig`– optional object with deprecated config keys.
-`exampleConfig`– the only **required** option with configuration against which you'd like to test.
-`title`– optional object of titles for errors and messages.
You will find examples of `condition`, `deprecate`, `error`, `unknown`, and `deprecatedConfig` inside source of this repository, named respectively.
## exampleConfig syntax
`exampleConfig` should be an object with key/value pairs that contain an example of a valid value for each key. A configuration value is considered valid when:
- it matches the JavaScript type of the example value, e.g. `string`, `number`, `array`, `boolean`, `function`, or `object`
- it is `null` or `undefined`
- it matches the Javascript type of any of arguments passed to `MultipleValidOptions(...)`
The last condition is a special syntax that allows validating where more than one type is permissible; see example below. It's acceptable to have multiple values of the same type in the example, so you can also use this syntax to provide more than one example. When a validation failure occurs, the error message will show all other values in the array as examples.
If `argv` contains a deprecated option that is not specifid in `allowedOptions`, `validateCLIOptions` will throw an error with the message specified in the `deprecatedOptions` config:
```bash
● collectCoverageOnlyFrom:
Option "collectCoverageOnlyFrom" was replaced by "collectCoverageFrom"