Files
freeCodeCamp/curriculum/challenges/english/05-apis-and-microservices/mongodb-and-mongoose/delete-many-documents-with-model.remove.md

62 lines
1.7 KiB
Markdown
Raw Normal View History

2018-10-25 20:29:56 +02:00
---
id: 587d7fb8367417b2b2512c11
title: Delete Many Documents with model.remove()
challengeType: 2
forumTopicId: 301538
2018-10-25 20:29:56 +02:00
---
## Description
2018-10-25 20:29:56 +02:00
<section id='description'>
`Model.remove()` is useful to delete all the documents matching given criteria.
2018-10-25 20:29:56 +02:00
</section>
## Instructions
2018-10-25 20:29:56 +02:00
<section id='instructions'>
Modify the `removeManyPeople` function to delete all the people whose name is within the variable `nameToRemove`, using `Model.remove()`. Pass it to a query document with the `name` field set, and a callback.
**Note:** The `Model.remove()` doesnt return the deleted document, but a JSON object containing the outcome of the operation, and the number of items affected. Dont forget to pass it to the `done()` callback, since we use it in tests.
2018-10-25 20:29:56 +02:00
</section>
## Tests
2018-10-25 20:29:56 +02:00
<section id='tests'>
```yml
tests:
- text: Deleting many items at once should succeed
testString: |
getUserInput => $.ajax({url: getUserInput('url') + '/_api/remove-many-people', type: 'POST', contentType:'application/json', data: JSON.stringify([{name: 'Mary', age: 16, favoriteFoods: ['lollipop']}, {name: 'Mary', age: 21, favoriteFoods: ['steak']}])}).then(data => {
assert.isTrue(!!data.ok, 'The mongo stats are not what expected');
assert.equal(data.n, 2, 'The number of items affected is not what expected');
assert.equal(data.count, 0, 'the db items count is not what expected');
}, xhr => { throw new Error(xhr.responseText); })
2018-10-25 20:29:56 +02:00
```
</section>
## Challenge Seed
2018-10-25 20:29:56 +02:00
<section id='challengeSeed'>
</section>
## Solution
2018-10-25 20:29:56 +02:00
<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.
*/
2018-10-25 20:29:56 +02:00
```
2018-10-25 20:29:56 +02:00
</section>