Skip to content

Commit

Permalink
feat: add resource param to enforce query limit
Browse files Browse the repository at this point in the history
  • Loading branch information
0xfede authored and alovicu committed Jul 22, 2022
1 parent d3d967b commit 2f9d9d8
Show file tree
Hide file tree
Showing 3 changed files with 51 additions and 1 deletion.
3 changes: 3 additions & 0 deletions src/mongo/operation/query.ts
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,9 @@ export class QueryMongoOperation extends MongoOperation {
if (typeof job.req.query.limit !== 'undefined') {
job.opts.limit = job.req.query.limit;
}
if ((this.resource.info.queryLimit || 0) > 0 && !(job.opts.limit < this.resource.info.queryLimit!)) {
job.opts.limit = this.resource.info.queryLimit;
}
if (typeof job.req.query.skip !== 'undefined') {
job.opts.skip = job.req.query.skip;
}
Expand Down
1 change: 1 addition & 0 deletions src/mongo/resource.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ export interface MongoResourceDefinition extends ResourceDefinition {
idIsObjectId?: boolean;
createIndexes?: boolean;
escapeProperties?: boolean;
queryLimit?: number;
}

export class MongoResource extends Resource {
Expand Down
48 changes: 47 additions & 1 deletion test/ts/mongo.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,7 @@ describe('mongo', function () {
before(async function () {
db = await MongoClient.connect('mongodb://localhost:27017/local', { useUnifiedTopology: true }).then((c) => c.db());
r1 = new MongoResource(db, { name: 'Test', collection: collectionName });
r2 = new MongoResource(db, { name: 'Other', collection: collectionName, id: 'myid', idIsObjectId: false });
r2 = new MongoResource(db, { name: 'Other', collection: collectionName, id: 'myid', idIsObjectId: false, queryLimit: 5 });
r3 = new MongoResource(db, { name: 'Fake', collection: collectionName }, { '/1': { get: FakeOp1 }, '/2': { get: FakeOp2 } });
r4 = new MongoResource(db, { name: 'Oid', collection: collectionName + '_oid', id: 'myoid', idIsObjectId: true });
r5 = new MongoResource(db, { name: 'Aggregation', collection: collectionName }, { '/': { get: Aggregation } });
Expand Down Expand Up @@ -331,6 +331,19 @@ describe('mongo', function () {
data.should.deep.equal({ myid: 'bbb', 'a.b.c.d': 1 });
});
});

it('should create a record with a date preserving its type', function () {
return request
.post('/dates')
.send({ myid: 'ts', ts: new Date() })
.expect(201)
.expect('Content-Type', /json/)
.then(async ({ body: data }) => {
const ref = await coll.findOne({}, { sort: { _id: -1 } });
await coll.remove({ myid: 'ts' });
ref.ts.should.be.a('Date');
});
});
});

describe('collection', function () {
Expand Down Expand Up @@ -685,6 +698,39 @@ describe('mongo', function () {
});
});

it('should return all objects in the collection (6), up to hardcoded limit', function () {
return request
.get('/others')
.expect(200)
.expect('Content-Type', /json/)
.expect('Results-Matching', '7')
.then(({ body: data }) => {
data.length.should.equal(5);
});
});

it('should return all objects in the collection (7), up to the lower of requested and hardcoded limits', function () {
return request
.get('/others?limit=6')
.expect(200)
.expect('Content-Type', /json/)
.expect('Results-Matching', '7')
.then(({ body: data }) => {
data.length.should.equal(5);
});
});

it('should return all objects in the collection (8), up to the lower of requested and hardcoded limits', function () {
return request
.get('/others?limit=4')
.expect(200)
.expect('Content-Type', /json/)
.expect('Results-Matching', '7')
.then(({ body: data }) => {
data.length.should.equal(4);
});
});

it('should return a single attribute of all objects, in ascending order by id (1)', function () {
return request
.get('/tests?fields=y&sort=myid')
Expand Down

0 comments on commit 2f9d9d8

Please sign in to comment.