Skip to content

Commit e3e053c

Browse files
datastore: re-use query object for continuation queries
1 parent 8e51135 commit e3e053c

2 files changed

Lines changed: 21 additions & 7 deletions

File tree

packages/datastore/src/request.js

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -518,6 +518,8 @@ DatastoreRequest.prototype.runQuery = function(query, options, callback) {
518518
return;
519519
}
520520

521+
query = extend(true, new Query(), query);
522+
521523
var limiter = common.util.createLimiter(makeRequest, options);
522524
var stream = limiter.stream;
523525

@@ -586,16 +588,16 @@ DatastoreRequest.prototype.runQuery = function(query, options, callback) {
586588
// The query is "NOT_FINISHED". Get the rest of the results.
587589
var offset = query.offsetVal === -1 ? 0 : query.offsetVal;
588590

589-
var continuationQuery = extend(true, new Query(), query)
591+
query
590592
.start(info.endCursor)
591593
.offset(offset - resp.batch.skippedResults);
592594

593595
var limit = query.limitVal;
594596
if (limit && limit > -1) {
595-
continuationQuery.limit(limit - resp.batch.entityResults.length);
597+
query.limit(limit - resp.batch.entityResults.length);
596598
}
597599

598-
limiter.makeRequest(continuationQuery);
600+
limiter.makeRequest(query);
599601
});
600602
}
601603

packages/datastore/test/request.js

Lines changed: 16 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -589,12 +589,25 @@ describe('Request', function() {
589589
request.runQuery({}, options, assert.ifError);
590590
});
591591

592+
it('should clone the query', function(done) {
593+
var query = new FakeQuery();
594+
query.namespace = 'namespace';
595+
query = extend(true, new FakeQuery(), query);
596+
597+
overrides.entity.queryToQueryProto = function(query_) {
598+
assert.notStrictEqual(query_, query);
599+
assert.deepEqual(query_, query);
600+
done();
601+
};
602+
603+
request.runQuery(query, assert.ifError);
604+
});
605+
592606
it('should make correct request', function(done) {
593607
var query = { namespace: 'namespace' };
594608
var queryProto = {};
595609

596-
overrides.entity.queryToQueryProto = function(query_) {
597-
assert.strictEqual(query_, query);
610+
overrides.entity.queryToQueryProto = function() {
598611
return queryProto;
599612
};
600613

@@ -693,7 +706,6 @@ describe('Request', function() {
693706
});
694707

695708
it('should re-run query if not finished', function(done) {
696-
var continuationQuery;
697709
var query = {
698710
limitVal: 1,
699711
offsetVal: 8
@@ -769,7 +781,7 @@ describe('Request', function() {
769781

770782
overrides.entity.queryToQueryProto = function(query_) {
771783
if (timesRequestCalled > 1) {
772-
assert.strictEqual(query_, continuationQuery);
784+
assert.strictEqual(query_, query);
773785
}
774786
return queryProto;
775787
};

0 commit comments

Comments
 (0)