Skip to content
This repository has been archived by the owner on Dec 17, 2018. It is now read-only.

Commit

Permalink
Merge pull request #20 from feathersjs/multi-patch
Browse files Browse the repository at this point in the history
Add tests for proper multi patch
  • Loading branch information
daffl authored Sep 21, 2016
2 parents 9c14ffa + af1add3 commit 925e379
Showing 1 changed file with 64 additions and 7 deletions.
71 changes: 64 additions & 7 deletions src/common-tests.js
Original file line number Diff line number Diff line change
Expand Up @@ -456,26 +456,83 @@ function common(app, errors, serviceName = 'people', idProp = 'id') {
});

it('patches multiple instances', () => {
return app.service(serviceName).create({
const service = app.service(serviceName);
const params = {
query: { created: true }
};

return service.create({
name: 'Dave',
age: 29,
created: true
}).then(() =>
app.service(serviceName).create({
service.create({
name: 'David',
age: 3,
created: true
})
).then(() =>
app.service(serviceName).patch(null, {
service.patch(null, {
age: 2
}, {
query: { created: true }
}
}, params
)).then(data => {
expect(data.length).to.equal(2);
expect(data[0].age).to.equal(2);
expect(data[1].age).to.equal(2);
});
}).then(() => service.remove(null, params));
});

it('patches multiple instances and returns the actually changed items', () => {
const service = app.service(serviceName);
const params = {
query: { age: { $lt: 10 } }
};

return service.create({
name: 'Dave',
age: 8,
created: true
}).then(() =>
service.create({
name: 'David',
age: 4,
created: true
})
).then(() =>
service.patch(null, {
age: 2
}, params
)).then(data => {
expect(data.length).to.equal(2);
expect(data[0].age).to.equal(2);
expect(data[1].age).to.equal(2);
}).then(() => service.remove(null, params));
});

it('patches multiple even if query changed', () => {
const service = app.service(serviceName);

return service.create({
name: 'Dave',
age: 2,
created: true
}).then(() =>
service.create({
name: 'David',
age: 2,
created: true
})
).then(() =>
service.patch(null, {
age: 8
}, { query: { age: 2 } }
)).then(data => {
expect(data.length).to.equal(2);
expect(data[0].age).to.equal(8);
expect(data[1].age).to.equal(8);
}).then(() => service.remove(null, {
query: { age: 8 }
}));
});

it('returns NotFound error for non-existing id', () => {
Expand Down

0 comments on commit 925e379

Please sign in to comment.