summaryrefslogtreecommitdiff
path: root/src/mongo/db
diff options
context:
space:
mode:
Diffstat (limited to 'src/mongo/db')
-rw-r--r--src/mongo/db/commands/SConscript4
-rw-r--r--src/mongo/db/commands/internal_transactions_test_command.idl77
-rw-r--r--src/mongo/db/commands/internal_transactions_test_command_d.cpp66
3 files changed, 147 insertions, 0 deletions
diff --git a/src/mongo/db/commands/SConscript b/src/mongo/db/commands/SConscript
index 6a08a6b7e9e..c6d2d8232e0 100644
--- a/src/mongo/db/commands/SConscript
+++ b/src/mongo/db/commands/SConscript
@@ -142,6 +142,7 @@ env.Library(
'rotate_certificates_command.cpp',
'generic_servers.cpp',
'generic_servers.idl',
+ 'internal_transactions_test_command.idl',
'isself.cpp',
'logical_session_server_status_section.cpp',
'mr_common.cpp',
@@ -512,6 +513,7 @@ env.Library(
"driverHelpers.cpp",
'get_cluster_parameter_command.cpp',
"internal_rename_if_options_and_indexes_match_cmd.cpp",
+ "internal_transactions_test_command_d.cpp",
"fle2_compact_cmd.cpp",
"map_reduce_command.cpp",
"oplog_application_checks.cpp",
@@ -554,6 +556,7 @@ env.Library(
'$BUILD_DIR/mongo/db/catalog/database_holder',
'$BUILD_DIR/mongo/db/catalog/index_key_validate',
'$BUILD_DIR/mongo/db/change_stream_options_manager',
+ '$BUILD_DIR/mongo/db/cluster_transaction_api',
'$BUILD_DIR/mongo/db/commands',
'$BUILD_DIR/mongo/db/curop_failpoint_helpers',
'$BUILD_DIR/mongo/db/dbhelpers',
@@ -581,6 +584,7 @@ env.Library(
'$BUILD_DIR/mongo/db/server_feature_flags',
'$BUILD_DIR/mongo/db/server_options_core',
'$BUILD_DIR/mongo/db/timeseries/timeseries_conversion_util',
+ '$BUILD_DIR/mongo/db/transaction_api',
'$BUILD_DIR/mongo/idl/idl_parser',
'$BUILD_DIR/mongo/util/net/ssl_manager',
'core',
diff --git a/src/mongo/db/commands/internal_transactions_test_command.idl b/src/mongo/db/commands/internal_transactions_test_command.idl
new file mode 100644
index 00000000000..292355cf255
--- /dev/null
+++ b/src/mongo/db/commands/internal_transactions_test_command.idl
@@ -0,0 +1,77 @@
+# Copyright (C) 2022-present MongoDB, Inc.
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the Server Side Public License, version 1,
+# as published by MongoDB, Inc.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# Server Side Public License for more details.
+#
+# You should have received a copy of the Server Side Public License
+# along with this program. If not, see
+# <http://www.mongodb.com/licensing/server-side-public-license>.
+#
+# As a special exception, the copyright holders give permission to link the
+# code of portions of this program with the OpenSSL library under certain
+# conditions as described in each individual source file and distribute
+# linked combinations including the program with the OpenSSL library. You
+# must comply with the Server Side Public License in all respects for
+# all of the code used other than as permitted herein. If you modify file(s)
+# with this exception, you may extend this exception to your version of the
+# file(s), but you are not obligated to do so. If you do not wish to do so,
+# delete this exception statement from your version. If you delete this
+# exception statement from all source files in the program, then also delete
+# it in the license file.
+#
+
+global:
+ cpp_namespace: "mongo"
+
+imports:
+ - "mongo/idl/basic_types.idl"
+
+structs:
+ TestInternalTransactionsCommandReply:
+ description: "Response for internal transaction command."
+ strict: false
+ fields:
+ responses:
+ description: "List of responses to commands in the transaction."
+ type: array<object>
+
+ TestInternalTransactionsCommandInfo:
+ description: "A command, its database name, and other test options."
+ strict: false
+ fields:
+ dbName:
+ type: string
+ command:
+ type: object
+ # TODO SERVER-64986: Remove assertSucceeds parameter.
+ assertSucceeds:
+ type: bool
+ default: true
+ exhaustCursor:
+ type: bool
+ optional: true
+
+commands:
+ testInternalTransactions:
+ command_name: testInternalTransactions
+ description: "The 'testInternalTransactions' command."
+ namespace: ignored
+ api_version: ""
+ fields:
+ useClusterClient:
+ description: "Whether the transaction API client used should opt into running the
+ 'cluster' versions of commands that enables a non-router node to run
+ the router versions of commands. Only meaningful on mongod because a
+ mongos will always run 'cluster' commands."
+ type: bool
+ default: false
+ commandInfos:
+ description: "List of TestInternalTransactionsCommandInfos to run in a single transaction."
+ type: array<TestInternalTransactionsCommandInfo>
+ reply_type: TestInternalTransactionsCommandReply
diff --git a/src/mongo/db/commands/internal_transactions_test_command_d.cpp b/src/mongo/db/commands/internal_transactions_test_command_d.cpp
new file mode 100644
index 00000000000..6892bbb8e62
--- /dev/null
+++ b/src/mongo/db/commands/internal_transactions_test_command_d.cpp
@@ -0,0 +1,66 @@
+/**
+ * Copyright (C) 2022-present MongoDB, Inc.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the Server Side Public License, version 1,
+ * as published by MongoDB, Inc.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * Server Side Public License for more details.
+ *
+ * You should have received a copy of the Server Side Public License
+ * along with this program. If not, see
+ * <http://www.mongodb.com/licensing/server-side-public-license>.
+ *
+ * As a special exception, the copyright holders give permission to link the
+ * code of portions of this program with the OpenSSL library under certain
+ * conditions as described in each individual source file and distribute
+ * linked combinations including the program with the OpenSSL library. You
+ * must comply with the Server Side Public License in all respects for
+ * all of the code used other than as permitted herein. If you modify file(s)
+ * with this exception, you may extend this exception to your version of the
+ * file(s), but you are not obligated to do so. If you do not wish to do so,
+ * delete this exception statement from your version. If you delete this
+ * exception statement from all source files in the program, then also delete
+ * it in the license file.
+ */
+
+#define MONGO_LOGV2_DEFAULT_COMPONENT ::mongo::logv2::LogComponent::kCommand
+
+#include "mongo/db/cluster_transaction_api.h"
+#include "mongo/db/transaction_participant_resource_yielder.h"
+#include "mongo/s/commands/internal_transactions_test_command.h"
+
+namespace mongo {
+namespace {
+
+class InternalTransactionsTestCommandD
+ : public InternalTransactionsTestCommandBase<InternalTransactionsTestCommandD> {
+public:
+ static txn_api::TransactionWithRetries getTxn(OperationContext* opCtx,
+ ExecutorPtr executor,
+ StringData commandName,
+ bool useClusterClient) {
+ // If a sharded mongod is acting as a mongos, it will need special routing behaviors.
+ if (useClusterClient) {
+ return txn_api::TransactionWithRetries(
+ opCtx,
+ executor,
+ std::make_unique<txn_api::details::SEPTransactionClient>(
+ opCtx,
+ executor,
+ std::make_unique<txn_api::details::ClusterSEPTransactionClientBehaviors>(
+ opCtx->getServiceContext())),
+ TransactionParticipantResourceYielder::make(commandName));
+ }
+
+ return txn_api::TransactionWithRetries(
+ opCtx, executor, TransactionParticipantResourceYielder::make(commandName));
+ }
+};
+
+MONGO_REGISTER_TEST_COMMAND(InternalTransactionsTestCommandD);
+} // namespace
+} // namespace mongo