| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 | 
							- "use strict";
 
- if (!module.parent) return require.cache[__filename] = 0, (new(require("mocha"))()).addFile(__filename).ui("exports").run(process.exit);
 
- var assert = require("assert"),
 
- 	Pipeline = require("../../../lib/pipeline/Pipeline"),
 
- 	PipelineD = require("../../../lib/pipeline/PipelineD"),
 
- 	CursorDocumentSource = require("../../../lib/pipeline/documentSources/CursorDocumentSource");
 
- module.exports = {
 
- 	"PipelineD": {
 
- 		"prepareCursorSource": {
 
- 			"should place a CursorDocumentSource in pipeline": function () {
 
- 				var p = Pipeline.parseCommand({pipeline:[{$match:{a:true}}], aggregate:[]});
 
- 				PipelineD.prepareCursorSource(p, {ns:[1,2,3,4,5]});
 
- 				assert.equal(p.sources[0].constructor, CursorDocumentSource);
 
- 			},
 
- 			"should get projection from all sources": function () {
 
- 				var p = Pipeline.parseCommand({pipeline:[{$project:{a:"$x"}}], aggregate:[]});
 
- 				PipelineD.prepareCursorSource(p, {ns:[1,2,3,4,5]});
 
- 				assert.deepEqual(p.sources[0]._projection, {x:1, _id:1});
 
- 				assert.deepEqual(p.sources[0]._dependencies, {_fields:{_id:true, x:true}});
 
- 			},
 
- 			"should get projection's deps": function () {
 
- 				var cmdObj = {
 
- 					aggregate: [],
 
- 					pipeline: [
 
- 						{$match:{
 
- 							x:{$exists:true},
 
- 							y:{$exists:false}
 
- 						}},
 
- 						{$project:{
 
- 							a:"$a.b.c",
 
- 							b:"$d",
 
- 							c:"$e.f.g"
 
- 						}},
 
- 						{$group:{
 
- 							_id:"$a",
 
- 							x:{$push:"b"}
 
- 						}}
 
- 					]
 
- 				};
 
- 				var p = Pipeline.parseCommand(cmdObj);
 
- 				PipelineD.prepareCursorSource(p, {ns:[1,2,3,4,5]});
 
- 				assert.deepEqual(p.sources[0]._projection, {"a.b.c": 1, d: 1, "e.f.g": 1, _id: 1});
 
- 				assert.deepEqual(p.sources[0]._dependencies, {"_fields":{"_id":true,"a":{"b":{"c":true}},"d":true,"e":{"f":{"g":true}}}});
 
- 			},
 
- 			"should get group's deps": function(){
 
- 				var cmdObj = {
 
- 					aggregate: [],
 
- 					pipeline: [
 
- 						{$match:{
 
- 							x:{$exists:true},
 
- 							y:{$exists:false}
 
- 						}},
 
- 						{$group:{
 
- 							_id:"$a",
 
- 							x:{$push:"$b"},
 
- 							y:{$addToSet:"$x.y.z"},
 
- 							z:{$sum:"$x.y.z.w"}
 
- 						}},
 
- 						{$project:{
 
- 							a:"$a.b.c",
 
- 							b:"$d",
 
- 							c:"$e.f.g"
 
- 						}}
 
- 					]
 
- 				};
 
- 				var p = Pipeline.parseCommand(cmdObj);
 
- 				PipelineD.prepareCursorSource(p, {ns:[1,2,3,4,5]});
 
- 				assert.equal(JSON.stringify(p.sources[0]._projection), JSON.stringify({ a: 1, b: 1, "x.y.z": 1, _id: 0 }));
 
- 				assert.deepEqual(p.sources[0]._dependencies, {"_fields":{"a":true,"b":true,"x":{"y":{"z":true}}}});
 
- 			},
 
- 			"should set the queryObj on the Cursor": function(){
 
- 				var cmdObj = {
 
- 					aggregate: [],
 
- 					pipeline: [
 
- 						{$match:{
 
- 							x:{$exists:true},
 
- 							y:{$exists:false}
 
- 						}}
 
- 					]
 
- 				};
 
- 				var p = Pipeline.parseCommand(cmdObj);
 
- 				PipelineD.prepareCursorSource(p, {ns:[1,2,3,4,5]});
 
- 				assert.deepEqual(p.sources[0]._query, {x:{$exists: true}, y:{$exists:false}});
 
- 			},
 
- 			"should set the sort on the Cursor": function(){
 
- 				var cmdObj = {
 
- 					aggregate: [],
 
- 					pipeline: [
 
- 						{$sort:{
 
- 							x:1,
 
- 							y:-1
 
- 						}}
 
- 					]
 
- 				};
 
- 				var p = Pipeline.parseCommand(cmdObj);
 
- 				PipelineD.prepareCursorSource(p, {ns:[1,2,3,4,5]});
 
- 				assert.deepEqual(p.sources[0]._sort, {x:1, y:-1});
 
- 			},
 
- 			"should set the sort on the Cursor if there is a match first": function(){
 
- 				var cmdObj = {
 
- 					aggregate: [],
 
- 					pipeline: [
 
- 						{$match:{
 
- 							x:{$exists:true},
 
- 							y:{$exists:false}
 
- 						}},
 
- 						{$sort:{
 
- 							x:1,
 
- 							y:-1
 
- 						}}
 
- 					]
 
- 				};
 
- 				var p = Pipeline.parseCommand(cmdObj);
 
- 				PipelineD.prepareCursorSource(p, {ns:[1,2,3,4,5]});
 
- 				assert.deepEqual(p.sources[0]._sort, {x:1, y:-1});
 
- 			},
 
- 			"should coalesce the Cursor with the rest of the pipeline": function(){
 
- 				var cmdObj = {
 
- 					aggregate: [],
 
- 					pipeline: [
 
- 						{$limit:1}
 
- 					]
 
- 				};
 
- 				var p = Pipeline.parseCommand(cmdObj);
 
- 				PipelineD.prepareCursorSource(p, {ns:[1,2,3,4,5]});
 
- 				assert.equal(p.sources[0].getLimit(), 1);
 
- 				assert.equal(p.sources.length, 1);
 
- 			},
 
- 		}
 
- 	}
 
- };
 
 
  |