ast-deep-contains
Version:
Like t.same assert on array of objects, where element order doesn't matter.
96 lines (74 loc) • 3.42 kB
Markdown
<h1 align="center">ast-deep-contains</h1>
<p align="center">Like t.same assert on array of objects, where element order doesn't matter.</p>
<p align="center">
<a href="https://codsen.com/os/ast-deep-contains" rel="nofollow noreferrer noopener">
<img src="https://img.shields.io/badge/-codsen-blue?style=flat-square" alt="page on codsen.com">
</a>
<a href="https://www.npmjs.com/package/ast-deep-contains" rel="nofollow noreferrer noopener">
<img src="https://img.shields.io/badge/-npm-blue?style=flat-square" alt="page on npm">
</a>
<a href="https://github.com/codsen/codsen/tree/main/packages/ast-deep-contains" rel="nofollow noreferrer noopener">
<img src="https://img.shields.io/badge/-github-blue?style=flat-square" alt="page on github">
</a>
<a href="https://npmcharts.com/compare/ast-deep-contains?interval=30" rel="nofollow noreferrer noopener" target="_blank">
<img src="https://img.shields.io/npm/dm/ast-deep-contains.svg?style=flat-square" alt="Downloads per month">
</a>
<a href="https://codsen.com/os/ast-deep-contains/changelog" rel="nofollow noreferrer noopener">
<img src="https://img.shields.io/badge/changelog-here-brightgreen?style=flat-square" alt="changelog">
</a>
<img src="https://img.shields.io/badge/licence-MIT-brightgreen.svg?style=flat-square" alt="MIT Licence">
</p>
## Install
This package is [pure ESM](https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c). If you're not ready yet, install an older version of this program, 3.1.0 (`npm i ast-deep-contains@3.1.0`).
```bash
npm i ast-deep-contains
```
## Quick Take
```js
import { strict as assert } from "assert";
import { deepContains } from "ast-deep-contains";
const gathered = [];
const errors = [];
const reference = [
{ c: "2" }, // will end up not used
{ a: "1", b: "2", c: "3" },
{ x: "8", y: "9", z: "0" },
];
const structureToMatch = [
{ a: "1", b: "2", c: "3" }, // matches but has different position in the source
{ x: "8", y: "9" }, // "z" missing
];
// This program pre-matches first, then matches objects as a set-subset
deepContains(
reference,
structureToMatch,
(leftSideVal, rightSideVal) => {
// This callback does the pre-matching and picks the key pairs for you.
// It's up to you what you will do with left- and right-side
// values - we normally feed them to unit test asserts but here we just push
// to array:
gathered.push([leftSideVal, rightSideVal]);
},
(err) => {
errors.push(err);
},
);
// imagine instead of pushing pairs into array, you fed them into assert
// function in unit tests:
assert.deepEqual(gathered, [
["1", "1"],
["2", "2"],
["3", "3"],
["8", "8"],
["9", "9"],
]);
assert.equal(errors.length, 0);
```
## Documentation
Please [visit codsen.com](https://codsen.com/os/ast-deep-contains/) for a full description of the API.
## Contributing
To report bugs or request features or assistance, [raise an issue](https://github.com/codsen/codsen/issues/new/choose) on GitHub.
## Licence
MIT License
Copyright © 2010-2025 Roy Revelt and other contributors
<p align="center"><img src="https://codsen.com/images/png-codsen-ok.png" width="98" alt="ok" align="center"> <img src="https://codsen.com/images/png-codsen-1.png" width="148" alt="codsen" align="center"> <img src="https://codsen.com/images/png-codsen-star-small.png" width="32" alt="star" align="center"></p>