| //===- llvm/unittest/Support/ParallelTest.cpp -----------------------------===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| /// |
| /// \file |
| /// Parallel.h unit tests. |
| /// |
| //===----------------------------------------------------------------------===// |
| |
| #include "llvm/Support/Parallel.h" |
| #include "gtest/gtest.h" |
| #include <array> |
| #include <random> |
| |
| uint32_t array[1024 * 1024]; |
| |
| using namespace llvm; |
| |
| // Tests below are hanging up on mingw. Investigating. |
| #if !defined(__MINGW32__) |
| |
| TEST(Parallel, sort) { |
| std::mt19937 randEngine; |
| std::uniform_int_distribution<uint32_t> dist; |
| |
| for (auto &i : array) |
| i = dist(randEngine); |
| |
| sort(parallel::par, std::begin(array), std::end(array)); |
| ASSERT_TRUE(std::is_sorted(std::begin(array), std::end(array))); |
| } |
| |
| TEST(Parallel, parallel_for) { |
| // We need to test the case with a TaskSize > 1. We are white-box testing |
| // here. The TaskSize is calculated as (End - Begin) / 1024 at the time of |
| // writing. |
| uint32_t range[2050]; |
| std::fill(range, range + 2050, 1); |
| for_each_n(parallel::par, 0, 2049, [&range](size_t I) { ++range[I]; }); |
| |
| uint32_t expected[2049]; |
| std::fill(expected, expected + 2049, 2); |
| ASSERT_TRUE(std::equal(range, range + 2049, expected)); |
| // Check that we don't write past the end of the requested range. |
| ASSERT_EQ(range[2049], 1u); |
| } |
| |
| #endif |