summaryrefslogtreecommitdiff
path: root/jstests/multiVersion/genericSetFCVUsage/setFCV_collmod_transaction_rollback.js
blob: 8a4b276d7b5d0c8eeb43a933ed6fdecfe37873fd (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
/**
 * Ensure that transaction rollback succeeds after an interrupted index ttl update or upgrade
 * collMod command.
 */
(function() {
    'use strict';

    load("jstests/libs/feature_compatibility_version.js");

    let dbpath = MongoRunner.dataPath + "setFCV_collmod_transaction_rollback";
    resetDbpath(dbpath);

    const latest = "latest";

    let conn = MongoRunner.runMongod({dbpath: dbpath, binVersion: latest});
    assert.neq(
        null, conn, "mongod was unable to start up with version=" + latest + " and no data files");
    let adminDB = conn.getDB("admin");

    var collName = "collModTest";
    var coll = adminDB.getCollection(collName);
    var ttlBeforeRollback = 50;

    assert.commandWorked(
        coll.createIndex({b: 1}, {"name": "index1", "expireAfterSeconds": ttlBeforeRollback}));

    // The failpoint causes an interrupt in the collMod's WriteUnitOfWork, thus triggers a rollback.
    assert.commandWorked(
        adminDB.adminCommand({configureFailPoint: "assertAfterIndexUpdate", mode: "alwaysOn"}));

    // Test transaction rollback after index ttl update collMod.
    assert.commandFailedWithCode(
        adminDB.runCommand(
            {"collMod": collName, "index": {"name": "index1", "expireAfterSeconds": 100}}),
        50970);

    const index = coll.getIndexes();
    var ttlAfterRollback = index[1].expireAfterSeconds;
    assert.eq(ttlAfterRollback, ttlBeforeRollback);

    MongoRunner.stopMongod(conn);
})();