Socket
Socket
Sign inDemoInstall

chai-jest-diff

Package Overview
Dependencies
321
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    chai-jest-diff

A plugin to make Chai’s equality assertions (shallow or deep) fail with Jest-like diffs


Version published
Weekly downloads
1.1K
decreased by-23.87%
Maintainers
1
Install size
1.07 MB
Created
Weekly downloads
 

Readme

Source

Jest-style diffs on Chai equalities

Chai’s assertions have a built-in showDiff flag, but do not produce the diff themselves; it’s up to the test runner to produce such output.

The very popular Mocha does that, but Jest doesn’t: its neat diffs are produced internally by its built-in matchers; it doesn’t rely on any sort of metadata to produce diff for third-party assertions.

When you start using Jest, if you still prefer Chai for your assertions, you quickly miss Jest’s neat JSON diffs, especially if you used to run tests with Mocha, which produced similar diffs on its own.

This Chai plugin tries to fix that, piggybacking on Jest’s jest-diff and jest-matcher-utils for maximum compatibility with Jest’s built-in expectation output.

It focuses on deep equality testing (through any variation of .deep.equal or .eql), where such diffs are most relevant. Because Jest uses diffs even for its ===-based .toBe expectation, it also provides it for shallow equal testing, just for consistency’s sake.

On the other hand, it currently doesn’t provide it for .property value testing, unlike Jest’s .toHaveProperty expectation. This seemed to require too much duplication of code between Chai’s internal assertions and this plugin, as there are many edge cases. We’ll see.

Usage

const chai = require('chai')
const chaiJestDiff = require('chai-jest-diff')

chai.use(chaiJestDiff())

Options

The plugin factory accepts a boolean argument, expand, that mirrors Jest’s expand configuration setting, for full-length diffs (instead of close-context diffs). I couldn’t figure out a way to get this information dynamically from Jest’s exposed API, so you’d have to pass that in manually if you need it.

License

© 2017 Delicious Insights

This plugin is provided under the MIT license. See LICENSE.md for details.

Keywords

FAQs

Last updated on 20 Dec 2017

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc