summaryrefslogtreecommitdiff
path: root/jstests/core/distinct4.js
blob: a66022ecbaab6fe2f8183540c11256aafc951d13 (plain)
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
53
54
// Vaildate input to distinct command. SERVER-12642

(function() {
"use strict";

var t = db.distinct4;

t.drop();
t.save({a: null});
t.save({a: 1});
t.save({a: 1});
t.save({a: 2});
t.save({a: 3});

// first argument should be a string or error

// from shell helper
assert.throws(function() {
    t.distinct({a: 1});
});

// from command interface
assert.commandFailedWithCode(t.runCommand("distinct", {"key": {a: 1}}), ErrorCodes.TypeMismatch);

// second argument should be a document or error

// from shell helper
assert.throws(function() {
    t.distinct('a', '1');
});

// from command interface
assert.commandFailedWithCode(t.runCommand("distinct", {"key": "a", "query": "a"}),
                             ErrorCodes.TypeMismatch);

// empty query clause should not cause error

// from shell helper
var a = assert.doesNotThrow(function() {
    return t.distinct('a');
});
// [ null, 1, 2, 3 ]
assert.eq(4, a.length, tojson(a));
assert.contains(null, a);
assert.contains(1, a);
assert.contains(2, a);
assert.contains(3, a);

// from command interface
assert.commandWorked(t.runCommand("distinct", {"key": "a"}));

// embedded nulls are prohibited in the key field
assert.commandFailedWithCode(t.runCommand("distinct", {"key": "a\0b"}), 31032);
})();