Skip to content

chaijs/chai-json-schema

Repository files navigation

chai-json-schema

npm version CI downloads license

Chai plugin with assertions to validate values against JSON Schema v4.

Assert both simple values and complex objects with the rich collection of validation terms (examples).

For general help with json-schema see this excellent guide and usable reference.

Status

The 1.x line is in maintenance: dependency hygiene and CI updates only. The runtime is unchanged since 1.5.1 and continues to work for existing users.

Compatibility

Supported
Node (runtime) >= 6 (per engines.node; CI tested on 18, 20, 22, 24)
chai (peer) >= 1.6.1 < 5
JSON Schema draft-04 (via tv4)

Notes

JSON Schema validation is done by Tiny Validator tv4. tv4 is unmaintained and only supports JSON Schema draft-04. If you need newer drafts or better performance, ajv is the maintained alternative.

The assertion will fail if a schema uses a $ref to a schema that is not added before the assertion is called. Use chai.tv4.addSchema(uri, schema) to preset schemas.

JSON Schema's main use-case is validating JSON documents and API responses, but it is also a powerful way to describe and validate any JavaScript value or object.

Usage

Install from npm:

npm install chai-json-schema

Register the plugin with chai:

var chai = require('chai');
chai.use(require('chai-json-schema'));

Assertions

jsonSchema(value, schema)

Validate that the given javascript value conforms to the specified JSON Schema. Both the value and schema would likely be JSON loaded from an external datasource but could also be literals or object instances.

var goodApple = {
  skin: 'thin',
  colors: ['red', 'green', 'yellow'],
  taste: 10
};
var badApple = {
  colors: ['brown'],
  taste: 0,
  worms: 2
};
var fruitSchema = {
  title: 'fresh fruit schema v1',
  type: 'object',
  required: ['skin', 'colors', 'taste'],
  properties: {
    colors: {
      type: 'array',
      minItems: 1,
      uniqueItems: true,
      items: {
        type: 'string'
      }
    },
    skin: {
      type: 'string'
    },
    taste: {
      type: 'number',
      minimum: 5
    }
  }
};

// bdd style
expect(goodApple).to.be.jsonSchema(fruitSchema);
expect(badApple).to.not.be.jsonSchema(fruitSchema);

goodApple.should.be.jsonSchema(fruitSchema);
badApple.should.not.be.jsonSchema(fruitSchema);

// tdd style
assert.jsonSchema(goodApple, fruitSchema);
assert.notJsonSchema(badApple, fruitSchema);

Additional API

The tv4 instance is exported as chai.tv4 and can be accessed to add schemas for use in validations:

chai.tv4.addSchema(uri, schema);

There are other useful methods:

var list = chai.tv4.getMissingUris();
var list = chai.tv4.getMissingUris(/^https?:/);

var list = chai.tv4.getSchemaUris();
var list = chai.tv4.getSchemaUris(/example.com/);

var schema = chai.tv4.getSchema('http://example.com/item');
var schema = chai.tv4.getSchema('http://example.com/item/#sub/type');

chai.tv4.dropSchemas();

For more API methods and info on the validator see the tv4 documentation.

Non-standard tv4 properties

Cyclical objects

This will be passed to the internal tv4 validate call to enable support for cyclical objects. It allows tv4 to validate normal javascript structures (instead of pure JSON) without risk of entering a loop on cyclical references.

chai.tv4.cyclicCheck = true;

This is slightly slower than regular validation so it is disabled by default.

Ban unknown properties

chai.tv4.banUnknown = true;

Passed to the internal tv4 validate call, makes validation fail on unknown schema properties. Use this to make sure your schema does not contain undesirable data.

Validate multiple errors

chai.tv4.multiple = true;

Calls tv4.validateMultiple for validation instead of tv4.validateResult. Use this if you want to see all validation errors.

Remote references

Due to the synchronous nature of assertions there is no support for dynamically loading remote references during validation.

Use the asynchronous preparation feature of your test runner to preload remote schemas:

// simplified example using a bdd-style async before();
// as used in mocha, jasmine etc.

before(function (done) {
  // iterate missing
  var checkMissing = function (callback) {
    var missing = chai.tv4.getMissingUris();
    if (missing.length === 0) {
      // all $ref's solved
      callback();
      return;
    }
    // load a schema using your favourite JSON loader
    // (jQuery, request, SuperAgent etc)
    var uri = missing.pop();
    myFavoriteJsonLoader.load(uri, function (err, schema) {
      if (err || !schema) {
        callback(err || 'no data loaded');
        return;
      }
      // add it
      chai.tv4.addSchema(uri, schema);
      // iterate
      checkMissing(callback);
    });
  };

  // load first instance manually
  myFavoriteJsonLoader.load(uri, function (err, schema) {
    if (err || !schema) {
      done(err || 'no data loaded');
      return;
    }
    // add it
    chai.tv4.addSchema(uri, schema);

    // start checking
    checkMissing(done);
  });
});

History

See Releases.

Development

In a git checkout:

npm install
npm test

npm test runs ESLint, the Prettier format check, and both Mocha suites (passing assertions and failing-on-purpose assertions). CI runs the same flow on Node 18, 20, 22 and 24.

License

Copyright (c) 2013 Bart van der Schoor

Licensed under the MIT license.

About

Chai plugin for JSON Schema v4

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors