summaryrefslogtreecommitdiff
path: root/src/mongo/db/s/sharding_ddl_coordinator_service.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/mongo/db/s/sharding_ddl_coordinator_service.cpp')
-rw-r--r--src/mongo/db/s/sharding_ddl_coordinator_service.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/mongo/db/s/sharding_ddl_coordinator_service.cpp b/src/mongo/db/s/sharding_ddl_coordinator_service.cpp
index 1c01f4882dc..27d44ea57a3 100644
--- a/src/mongo/db/s/sharding_ddl_coordinator_service.cpp
+++ b/src/mongo/db/s/sharding_ddl_coordinator_service.cpp
@@ -165,6 +165,22 @@ void ShardingDDLCoordinatorService::waitForCoordinatorsOfGivenTypeToComplete(
});
}
+void ShardingDDLCoordinatorService::waitForOngoingCoordinatorsToFinish(OperationContext* opCtx) {
+ std::vector<SharedSemiFuture<void>> futuresToWait;
+
+ const auto instances = getAllInstances(opCtx);
+ for (const auto& instance : instances) {
+ auto typedInstance = checked_pointer_cast<ShardingDDLCoordinator>(instance);
+ // TODO: SERVER-63724 Wait only for coordinators that don't have the user-write-blocking
+ // bypass enabled.
+ futuresToWait.emplace_back(typedInstance->getCompletionFuture());
+ }
+
+ for (auto&& future : futuresToWait) {
+ future.wait(opCtx);
+ }
+}
+
void ShardingDDLCoordinatorService::_afterStepDown() {
stdx::lock_guard lg(_mutex);
_state = State::kPaused;