Files
mongo/jstests/aggregation/bugs/server6556.js
2012-08-03 12:37:21 -04:00

26 lines
1.1 KiB
JavaScript

// ensure strings containing null characters dont end at that null
if (typeof(_threadInject) == "undefined") {
// this is only true on spidermonkey. due to server-6646 this test doesn't work on V8
c = db.s6556;
c.drop();
c.save({foo:"as\0df"});
// compare the whole string, they should match
assert.eq(c.aggregate({$project: {_id: 0, matches: {$eq:["as\0df", "$foo"]}}}).result, [{matches:true}]);
// compare with the substring containing only the up to the null, they should not match
assert.eq(c.aggregate({$project: {_id: 0, matches: {$eq:["as\0df", {$substr:["$foo",0,3]}]}}}).result, [{matches:false}]);
// partial the other way shouldnt work either
assert.eq(c.aggregate({$project: {_id: 0, matches: {$eq:["as", "$foo"]}}}).result, [{matches:false}]);
// neither should one that differs after the null
assert.eq(c.aggregate({$project: {_id: 0, matches: {$eq:["as\0de", "$foo"]}}}).result, [{matches:false}]);
// should assert on fieldpaths with a null
assert.eq(c.aggregate({$project: {_id: 0, matches: {$eq:["as\0df", "$f\0oo"]}}}).code, 16419);
}
else {
print('skipping server6556 on v8');
}