--- id: 587d824c367417b2b2512c4c title: Assert Deep Equality with .deepEqual and .notDeepEqual challengeType: 2 forumTopicId: 301587 dashedName: assert-deep-equality-with--deepequal-and--notdeepequal --- # --description-- As a reminder, this project is being built upon the following starter project on [Repl.it](https://repl.it/github/freeCodeCamp/boilerplate-mochachai), or cloned from [GitHub](https://github.com/freeCodeCamp/boilerplate-mochachai/). `deepEqual()` asserts that two objects are deep equal. # --instructions-- Within `tests/1_unit-tests.js` under the test labelled `#7` in the `Equality` suite, change each `assert` to either `assert.deepEqual` or `assert.notDeepEqual` to make the test pass (should evaluate to `true`). Do not alter the arguments passed to the asserts. # --hints-- All tests should pass. ```js (getUserInput) => $.get(getUserInput('url') + '/_api/get-tests?type=unit&n=6').then( (data) => { assert.equal(data.state, 'passed'); }, (xhr) => { throw new Error(xhr.responseText); } ); ``` You should choose the correct method for the first assertion - `deepEqual` vs. `notDeepEqual`. ```js (getUserInput) => $.get(getUserInput('url') + '/_api/get-tests?type=unit&n=6').then( (data) => { assert.equal( data.assertions[0].method, 'deepEqual', 'The order of the keys does not matter' ); }, (xhr) => { throw new Error(xhr.responseText); } ); ``` You should choose the correct method for the second assertion - `deepEqual` vs. `notDeepEqual`. ```js (getUserInput) => $.get(getUserInput('url') + '/_api/get-tests?type=unit&n=6').then( (data) => { assert.equal( data.assertions[1].method, 'notDeepEqual', 'The position of elements within an array does matter' ); }, (xhr) => { throw new Error(xhr.responseText); } ); ``` # --solutions-- ```js /** Backend challenges don't need solutions, because they would need to be tested against a full working project. Please check our contributing guidelines to learn more. */ ```