Ver Fonte

EAGLESIX-2701 merged in Add and Add

Tony Ennis há 11 anos atrás
pai
commit
624f041e97

+ 2 - 0
lib/pipeline/expressions/OrExpression.js

@@ -25,6 +25,8 @@ proto.getOpName = function getOpName(){
 	return klass.opName;
 };
 
+proto.isAssociativeAndCommutative = function isAssociativeAndCommutative() { return true; }
+
 /**
  * Takes an array of one or more values and returns true if any of the values in the array are true. Otherwise $or returns false.
  * @method evaluateInternal

+ 21 - 21
test/lib/pipeline/expressions/OrExpression_test.js

@@ -42,47 +42,47 @@ module.exports = {
 
 		"#evaluateInternalInternal()": {
 
-			"should return false if no operors were given; {$or:[]}": function testEmpty(){
+			"should return false if no operrors were given; {$or:[]}": function testEmpty(){
 				assert.equal(Expression.parseOperand({$or:[]}).evaluateInternal(), false);
 			},
 
-			"should return true if operors is one true; {$or:[true]}": function testTrue(){
+			"should return true if operrors is one true; {$or:[true]}": function testTrue(){
 				assert.equal(Expression.parseOperand({$or:[true]}).evaluateInternal(), true);
 			},
 
-			"should return false if operors is one false; {$or:[false]}": function testFalse(){
+			"should return false if operrors is one false; {$or:[false]}": function testFalse(){
 				assert.equal(Expression.parseOperand({$or:[false]}).evaluateInternal(), false);
 			},
 
-			"should return true if operors are true or true; {$or:[true,true]}": function testTrueTrue(){
+			"should return true if operrors are true or true; {$or:[true,true]}": function testTrueTrue(){
 				assert.equal(Expression.parseOperand({$or:[true,true]}).evaluateInternal(), true);
 			},
 
-			"should return true if operors are true or false; {$or:[true,false]}": function testTrueFalse(){
+			"should return true if operrors are true or false; {$or:[true,false]}": function testTrueFalse(){
 				assert.equal(Expression.parseOperand({$or:[true,false]}).evaluateInternal(), true);
 			},
 
-			"should return true if operors are false or true; {$or:[false,true]}": function testFalseTrue(){
+			"should return true if operrors are false or true; {$or:[false,true]}": function testFalseTrue(){
 				assert.equal(Expression.parseOperand({$or:[false,true]}).evaluateInternal(), true);
 			},
 
-			"should return false if operors are false or false; {$or:[false,false]}": function testFalseFalse(){
+			"should return false if operrors are false or false; {$or:[false,false]}": function testFalseFalse(){
 				assert.equal(Expression.parseOperand({$or:[false,false]}).evaluateInternal(), false);
 			},
 
-			"should return false if operors are false, false, or false; {$or:[false,false,false]}": function testFalseFalseFalse(){
+			"should return false if operrors are false, false, or false; {$or:[false,false,false]}": function testFalseFalseFalse(){
 				assert.equal(Expression.parseOperand({$or:[false,false,false]}).evaluateInternal(), false);
 			},
 
-			"should return false if operors are false, false, or false; {$or:[false,false,true]}": function testFalseFalseTrue(){
+			"should return false if operrors are false, false, or false; {$or:[false,false,true]}": function testFalseFalseTrue(){
 				assert.equal(Expression.parseOperand({$or:[false,false,true]}).evaluateInternal(), true);
 			},
 
-			"should return true if operors are 0 or 1; {$or:[0,1]}": function testZeroOne(){
+			"should return true if operrors are 0 or 1; {$or:[0,1]}": function testZeroOne(){
 				assert.equal(Expression.parseOperand({$or:[0,1]}).evaluateInternal(), true);
 			},
 
-			"should return false if operors are 0 or false; {$or:[0,false]}": function testZeroFalse(){
+			"should return false if operrors are 0 or false; {$or:[0,false]}": function testZeroFalse(){
 				assert.equal(Expression.parseOperand({$or:[0,false]}).evaluateInternal(), false);
 			},
 
@@ -95,43 +95,43 @@ module.exports = {
 		"#optimize()": {
 
 			"should optimize a constant expression to a constant; {$or:[1]} == true": function testOptimizeConstantExpression(){
-				assert.deepEqual(Expression.parseOperand({$or:[1]}).optimize().toJSON(true), {$const:true});
+				assert.deepEqual(Expression.parseOperand({$or:[1]}).optimize(), {$const:true});
 			},
 
 			"should not optimize a non-constant expression; {$or:['$a']}; SERVER-6192": function testNonConstant(){
-				assert.deepEqual(Expression.parseOperand({$or:['$a']}).optimize().toJSON(), {$or:['$a']});
+				assert.deepEqual(Expression.parseOperand({$or:['$a']}).optimize(), {$or:['$a']});
 			},
 
 			"should optimize an expression with a path or a '1' (is entirely constant); {$or:['$a',1]}": function testNonConstantOne(){
-				assert.deepEqual(Expression.parseOperand({$or:['$a',1]}).optimize().toJSON(true), {$const:true});
+				assert.deepEqual(Expression.parseOperand({$or:['$a',1]}).optimize(), {$const:true});
 			},
 
 			"should optimize an expression with a field path or a '0'; {$or:['$a',0]}": function testNonConstantZero(){
-				assert.deepEqual(Expression.parseOperand({$or:['$a',0]}).optimize().toJSON(), {$and:['$a']});
+				assert.deepEqual(Expression.parseOperand({$or:['$a',0]}).optimize(), {$and:['$a']});
 			},
 
 			"should optimize an expression with two field paths or '1' (is entirely constant); {$or:['$a','$b',1]}": function testNonConstantNonConstantOne(){
-				assert.deepEqual(Expression.parseOperand({$or:['$a','$b',1]}).optimize().toJSON(true), {$const:true});
+				assert.deepEqual(Expression.parseOperand({$or:['$a','$b',1]}).optimize(), {$const:true});
 			},
 
 			"should optimize an expression with two field paths or '0'; {$or:['$a','$b',0]}": function testNonConstantNonConstantZero(){
-				assert.deepEqual(Expression.parseOperand({$or:['$a','$b',0]}).optimize().toJSON(), {$or:['$a','$b']});
+				assert.deepEqual(Expression.parseOperand({$or:['$a','$b',0]}).optimize(), {$or:['$a','$b']});
 			},
 
 			"should optimize an expression with '0', '1', or a field path; {$or:[0,1,'$a']}": function testZeroOneNonConstant(){
-				assert.deepEqual(Expression.parseOperand({$or:[0,1,'$a']}).optimize().toJSON(true), {$const:true});
+				assert.deepEqual(Expression.parseOperand({$or:[0,1,'$a']}).optimize(), {$const:true});
 			},
 
 			"should optimize an expression with '0', '0', or a field path; {$or:[0,0,'$a']}": function testZeroZeroNonConstant(){
-				assert.deepEqual(Expression.parseOperand({$or:[0,0,'$a']}).optimize().toJSON(), {$and:['$a']});
+				assert.deepEqual(Expression.parseOperand({$or:[0,0,'$a']}).optimize(), {$and:['$a']});
 			},
 
 			"should optimize nested $or expressions properly or optimize out values evaluating to false; {$or:[0,{$or:[0]},'$a','$b']}": function testNested(){
-				assert.deepEqual(Expression.parseOperand({$or:[0,{$or:[0]},'$a','$b']}).optimize().toJSON(), {$or:['$a','$b']});
+				assert.deepEqual(Expression.parseOperand({$or:[0,{$or:[0]},'$a','$b']}).optimize(), {$or:['$a','$b']});
 			},
 
 			"should optimize nested $or expressions containing a nested value evaluating to false; {$or:[0,{$or:[{$or:[1]}]},'$a','$b']}": function testNestedOne(){
-				assert.deepEqual(Expression.parseOperand({$or:[0,{$or:[{$or:[1]}]},'$a','$b']}).optimize().toJSON(true), {$const:true});
+				assert.deepEqual(Expression.parseOperand({$or:[0,{$or:[{$or:[1]}]},'$a','$b']}).optimize(), {$const:true});
 			}
 
 		}