| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
- "use strict";
- var assert = require("assert"),
- FieldPathExpression = require("../../../../lib/pipeline/expressions/FieldPathExpression"),
- Variables = require("../../../../lib/pipeline/expressions/Variables");
- module.exports = {
- "FieldPathExpression": {
- "constructor()": {
- "should throw Error if empty field path": function testInvalid(){
- assert.throws(function() {
- new FieldPathExpression('');
- });
- }
- },
- "#evaluate()": {
- "should return undefined if field path is missing": function testMissing(){
- assert.strictEqual(FieldPathExpression.create('a').evaluateInternal(new Variables(1, {})), undefined);
- },
- "should return value if field path is present": function testPresent(){
- var vars = new Variables(1, {a:123}),
- fieldPath = FieldPathExpression.create('a'),
- results = fieldPath.evaluateInternal(vars);
- assert.strictEqual(results, 123);
- },
- "should return undefined if field path is nested below null": function testNestedBelowNull(){
- var vars = new Variables(1,{a:null}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.strictEqual(results, undefined);
- },
- "should return undefined if field path is nested below undefined": function NestedBelowUndefined(){
- var vars = new Variables(1,{a:undefined}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.strictEqual(results, undefined);
- },
- "should return undefined if field path is nested below Number": function testNestedBelowInt(){
- var vars = new Variables(1,{a:2}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.strictEqual(results, undefined);
- },
- "should return value if field path is nested": function testNestedValue(){
- var vars = new Variables(1,{a:{b:55}}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.strictEqual(results, 55);
- },
- "should return undefined if field path is nested below empty Object": function testNestedBelowEmptyObject(){
- var vars = new Variables(1,{a:{}}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.strictEqual(results, undefined);
- },
- "should return empty Array if field path is nested below empty Array": function testNestedBelowEmptyArray(){
- var vars = new Variables(1,{a:[]}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.deepEqual(results, []);
- },
- "should return Array with null if field path is nested below Array containing null": function testNestedBelowArrayWithNull(){
- var vars = new Variables(1,{a:[null]}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.deepEqual(results, []);
- },
- "should return Array with undefined if field path is nested below Array containing undefined": function testNestedBelowArrayWithUndefined(){
- var vars = new Variables(1,{a:[undefined]}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.deepEqual(results, []);
- },
- "should throw Error if field path is nested below Array containing a Number": function testNestedBelowArrayWithInt(){
- var vars = new Variables(1,{a:[9]}),
- fieldPath = FieldPathExpression.create('a.b'),
- results = fieldPath.evaluateInternal(vars);
- assert.deepEqual(results, []);
- },
- "should return Array with value if field path is in Object within Array": function testNestedWithinArray(){
- assert.deepEqual(FieldPathExpression.create('a.b').evaluateInternal(new Variables(1,{a:[{b:9}]})), [9]);
- },
- "should return Array with multiple value types if field path is within Array with multiple value types": function testMultipleArrayValues(){
- var path = 'a.b',
- doc = {a:[{b:9},null,undefined,{g:4},{b:20},{}]},
- expected = [9,20];
- assert.deepEqual(FieldPathExpression.create(path).evaluateInternal(new Variables(1,doc)), expected);
- },
- "should return Array with expanded values from nested multiple nested Arrays": function testExpandNestedArrays(){
- var path = 'a.b.c',
- doc = {a:[{b:[{c:1},{c:2}]},{b:{c:3}},{b:[{c:4}]},{b:[{c:[5]}]},{b:{c:[6,7]}}]},
- expected = [[1,2],3,[4],[[5]],[6,7]];
- assert.deepEqual(FieldPathExpression.create(path).evaluateInternal(new Variables(1,doc)), expected);
- },
- "should return null if field path points to a null value": function testPresentNull(){
- assert.strictEqual(FieldPathExpression.create('a').evaluateInternal(new Variables(1,{a:null})), null);
- },
- "should return undefined if field path points to a undefined value": function testPresentUndefined(){
- assert.strictEqual(FieldPathExpression.create('a').evaluateInternal(new Variables(1,{a:undefined})), undefined);
- },
- "should return Number if field path points to a Number value": function testPresentNumber(){
- assert.strictEqual(FieldPathExpression.create('a').evaluateInternal(new Variables(1,{a:42})), 42);
- }
- },
- "#optimize()": {
- "should not optimize anything": function testOptimize(){
- var expr = FieldPathExpression.create('a');
- assert.strictEqual(expr, expr.optimize());
- }
- },
- "#addDependencies()": {
- "should return the field path itself as a dependency": function testDependencies(){
- var deps = {};
- var fpe = FieldPathExpression.create('a.b');
- fpe.addDependencies(deps);
- assert.strictEqual(Object.keys(deps).length, 1);
- assert.ok(deps['a.b']);
- }
- },
- "#toJSON()": {
- "should output path String with a '$'-prefix": function testJson(){
- assert.equal(FieldPathExpression.create('a.b.c').serialize(), "$a.b.c");
- }
- }
- }
- };
- if (!module.parent)(new(require("mocha"))()).ui("exports").reporter("spec").addFile(__filename).run(process.exit);
|