/* * All or portions of this file Copyright (c) Amazon.com, Inc. or its affiliates or * its licensors. * * For complete copyright and license terms please see the LICENSE at the root of this * distribution (the "License"). All use of this software is governed by the License, * or, if provided, by the license below or the license accompanying this file. Do not * remove or modify any license notices. This file is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * */ #include #include #include #include #include #include namespace UnitTest { using namespace AZ; void ThreadTester::Dispatch(size_t threadCountMax, ThreadFunction threadFunction) { AZStd::mutex mutex; AZStd::vector threads; AZStd::atomic threadCount(threadCountMax); AZStd::condition_variable cv; for (size_t i = 0; i < threadCountMax; ++i) { threads.emplace_back([threadFunction, &threadCount, &cv, i]() { threadFunction(i); threadCount--; cv.notify_one(); }); } bool timedOut = false; // Used to detect a deadlock. If we wait for more than 5 seconds, it's likely a deadlock has occurred while (threadCount > 0 && !timedOut) { AZStd::unique_lock lock(mutex); timedOut = (AZStd::cv_status::timeout == cv.wait_until(lock, AZStd::chrono::system_clock::now() + AZStd::chrono::seconds(5))); } EXPECT_TRUE(threadCount == 0); for (auto& thread : threads) { thread.join(); } } }