summaryrefslogtreecommitdiff
path: root/jstests/free_mon/free_mon_register_cmd.js
blob: d3d6dae12d4fa37db59763c6598043dd6d01fc44 (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
// Validate registration works via a command. Validate it can be registered and unregistered
//
load("jstests/free_mon/libs/free_mon.js");

(function() {
    'use strict';

    let mock_web = new FreeMonWebServer();

    mock_web.start();

    let options = {
        setParameter: "cloudFreeMonitoringEndpointURL=" + mock_web.getURL(),
        verbose: 1,
    };

    const conn = MongoRunner.runMongod(options);
    assert.neq(null, conn, 'mongod was unable to start up');

    assert.commandWorked(conn.adminCommand({setFreeMonitoring: 1, action: "enable"}));

    // The command should either timeout or suceed after registration is complete
    const retStatus1 = conn.adminCommand({getFreeMonitoringStatus: 1});
    assert.commandWorked(retStatus1);
    assert.eq(retStatus1.state, "enabled", tojson(retStatus1));

    const stats = mock_web.queryStats();
    print(tojson(stats));

    assert.eq(stats.registers, 1);

    const last_register = mock_web.query("last_register");
    print(tojson(last_register));

    assert.eq(last_register.version, 1);
    assert.eq(last_register.payload.buildInfo.bits, 64);
    assert.eq(last_register.payload.buildInfo.ok, 1);
    assert.eq(last_register.payload.storageEngine.readOnly, false);
    assert.eq(last_register.payload.isMaster.ok, 1);

    mock_web.waitMetrics(2);

    const last_metrics = mock_web.query("last_metrics");
    print(tojson(last_metrics));

    assert.eq(last_metrics.version, 1);

    assert.commandWorked(conn.adminCommand({setFreeMonitoring: 1, action: "disable"}));

    // Wait for unregistration to occur
    assert.soon(function() {
        const regDoc = FreeMonGetRegistration(conn);
        return regDoc.state == "disabled";
    }, "Failed to unregister", 60 * 1000);

    const retStatus2 = conn.adminCommand({getFreeMonitoringStatus: 1});
    assert.commandWorked(retStatus2);
    assert.eq(retStatus2.state, "disabled", tojson(retStatus1));

    MongoRunner.stopMongod(conn);

    mock_web.stop();
})();