* feat(learn): add mocha and chai instructions * test: added one new lesson * rename added file and add tests * add meta to prettierignore, fix formatting * add unit-test numbering * add examples from boilerplate Co-authored-by: Randell Dawson <rdawson@onepathtech.com> * remove code comments, add description * elaborate test testStrings Co-authored-by: Randell Dawson <rdawson@onepathtech.com>
61 lines
2.1 KiB
Markdown
61 lines
2.1 KiB
Markdown
---
|
|
id: 587d824c367417b2b2512c4c
|
|
title: Assert Deep Equality with .deepEqual and .notDeepEqual
|
|
challengeType: 2
|
|
forumTopicId: 301587
|
|
---
|
|
|
|
## Description
|
|
|
|
<section id='description'>
|
|
|
|
As a reminder, this project is being built upon the following starter project on <a href="https://repl.it/github/freeCodeCamp/boilerplate-mochachai">Repl.it</a>, or cloned from <a href='https://github.com/freeCodeCamp/boilerplate-mochachai/'>GitHub</a>.
|
|
|
|
`deepEqual()` asserts that two objects are deep equal.
|
|
|
|
</section>
|
|
|
|
## Instructions
|
|
|
|
<section id='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.
|
|
|
|
</section>
|
|
|
|
## Tests
|
|
|
|
<section id='tests'>
|
|
|
|
```yml
|
|
tests:
|
|
- text: All tests should pass.
|
|
testString: getUserInput => $.get(getUserInput('url') + '/_api/get-tests?type=unit&n=6').then(data => {assert.equal(data.state,'passed'); }, xhr => { throw new Error(xhr.responseText); })
|
|
- text: You should choose the correct method for the first assertion - `deepEqual` vs. `notDeepEqual`.
|
|
testString: 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); })
|
|
- text: You should choose the correct method for the second assertion - `deepEqual` vs. `notDeepEqual`.
|
|
testString: 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); })
|
|
```
|
|
|
|
</section>
|
|
|
|
## Challenge Seed
|
|
|
|
<section id='challengeSeed'>
|
|
|
|
</section>
|
|
|
|
## Solution
|
|
|
|
<section id='solution'>
|
|
|
|
```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.
|
|
*/
|
|
```
|
|
|
|
</section>
|