1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
|
/*
* SERVER-6240: verify assertion on attempt to perform date extraction from missing or null value
*
* This test validates the SERVER-6240 ticket. uassert when attempting to extract a date from a
* null value. Prevously verify'd.
*
* This test also validates the error cases for SERVER-6239 (support $add and $subtract with dates)
*/
/*
* 1) Clear then populate testing db
* 2) Run an aggregation that uses a date value in various math operations
* 3) Assert that we get the correct error
*/
// Load test utilities
load('jstests/aggregation/extras/utils.js');
// Clear db
db.s6240.drop();
// Populate db
db.s6240.save({date:new Date()});
// Aggregate using a date value in various math operations
// Add
assertErrorCode(db.s6240,
{$project: {add: {$add: ["$date", "$date"]}}},
16612);
// Divide
assertErrorCode(db.s6240,
{$project: {divide: {$divide: ["$date", 2]}}},
16609);
// Mod
assertErrorCode(db.s6240,
{$project: {mod: {$mod: ["$date", 2]}}},
16611);
// Multiply
assertErrorCode(db.s6240,
{$project: {multiply: {$multiply: ["$date", 2]}}},
16555);
// Subtract
assertErrorCode(db.s6240,
{$project: {subtract: {$subtract: [2, "$date"]}}},
16556);
|