UNPKG

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
<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>