summaryrefslogtreecommitdiff
path: root/jstests/noPassthrough/client_metadata_log.js
blob: f1b90492ce6532ff23e0a3dc717ac18d25307c81 (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
55
56
57
58
59
60
61
62
63
64
65
66
/**
 * Test that verifies client metadata is logged into log file on new connections.
 * @tags: [requires_sharding]
 */
(function() {
    'use strict';

    let checkLog = function(conn) {
        let coll = conn.getCollection("test.foo");
        assert.writeOK(coll.insert({_id: 1}));

        print(`Checking ${conn.fullOptions.logFile} for client metadata message`);
        let log = cat(conn.fullOptions.logFile);

        assert(
            /received client metadata from .*: { application: { name: ".*" }, driver: { name: ".*", version: ".*" }, os: { type: ".*", name: ".*", architecture: ".*", version: ".*" } }/
                .test(log),
            "'received client metadata' log line missing in log file!\n" + "Log file contents: " +
                conn.fullOptions.logFile +
                "\n************************************************************\n" + log +
                "\n************************************************************");
    };

    // Test MongoD
    let testMongoD = function() {
        let conn = MongoRunner.runMongod({useLogFiles: true});
        assert.neq(null, conn, 'mongod was unable to start up');

        checkLog(conn);

        MongoRunner.stopMongod(conn);
    };

    // Test MongoS
    let testMongoS = function() {
        let options = {
            mongosOptions: {useLogFiles: true},
        };

        let st = new ShardingTest({shards: 1, mongos: 1, other: options});

        checkLog(st.s0);

        // Validate db.currentOp() contains mongos information
        let curOp = st.s0.adminCommand({currentOp: 1});
        print(tojson(curOp));

        var inprogSample = null;
        for (let inprog of curOp.inprog) {
            if (inprog.hasOwnProperty("clientMetadata") &&
                inprog.clientMetadata.hasOwnProperty("mongos")) {
                inprogSample = inprog;
                break;
            }
        }

        assert.neq(inprogSample.clientMetadata.mongos.host, "unknown");
        assert.neq(inprogSample.clientMetadata.mongos.client, "unknown");
        assert.neq(inprogSample.clientMetadata.mongos.version, "unknown");

        st.stop();
    };

    testMongoD();
    testMongoS();
})();