Skip to content

Commit

Permalink
Returning cursor conflicts with the executor
Browse files Browse the repository at this point in the history
  • Loading branch information
louischatriot committed Jan 25, 2014
1 parent 8a98dda commit b8f641e
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 3 deletions.
10 changes: 9 additions & 1 deletion lib/cursor.js
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,11 @@ Cursor.prototype.sort = function(sortQuery) {

/**
* Get all matching elements
* This is an internal function, use exec which uses the executor
*
* @param {Function} callback - Signature: err, results
*/
Cursor.prototype.exec = function(callback) {
Cursor.prototype.exec = function(callback) {
var candidates = this.db.getCandidates(this.query)
, res = [], added = 0, skipped = 0, self = this
, i
Expand Down Expand Up @@ -93,6 +95,12 @@ Cursor.prototype.sort = function(sortQuery) {
return callback(null, res);
};

// Cursor.prototype.exec = function () {
// console.log("=============IN EXEC");
// this.db.executor.push({ this: this, fn: this._exec, arguments: arguments });
// };



// Interface
module.exports = Cursor;
2 changes: 0 additions & 2 deletions lib/datastore.js
Original file line number Diff line number Diff line change
Expand Up @@ -462,8 +462,6 @@ Datastore.prototype._update = function (query, updateQuery, options, cb) {
if (doc) {
return cb();
} else {
// The upserted document is the query (since for now queries have the same structure as
// documents), modified by the updateQuery
return self._insert(model.modify(query, updateQuery), function (err) {
if (err) { return callback(err); }
return callback(null, 1, true);
Expand Down
4 changes: 4 additions & 0 deletions test/cursor.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -531,6 +531,10 @@ describe('Cursor', function () {
}
], done);
});

it.skip('Multiple consecutive sorts', function(done) {
done();
});

}); // ===== End of 'Sorting' =====

Expand Down
19 changes: 19 additions & 0 deletions test/db.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -602,6 +602,25 @@ describe('Database', function () {
});
});
});

it.only('Can use sort, skip and limit if the callback is not passed to find but to exec', function (done) {
d.insert({ a: 2, hello: 'world' }, function () {
d.insert({ a: 24, hello: 'earth' }, function () {
d.insert({ a: 13, hello: 'blueplanet' }, function () {
d.insert({ a: 15, hello: 'home' }, function () {
d.find({}).sort({ a: 1 }).limit(2).exec(function (err, docs) {
assert.isNull(err);
docs.length.should.equal(2);
docs[0].hello.should.equal('world');
docs[1].hello.should.equal('blueplanet');
done();
});
});
});
});
});
});


}); // ==== End of 'Find' ==== //

Expand Down

0 comments on commit b8f641e

Please sign in to comment.