// -*- C++ -*- //===-- all_of.pass.cpp ---------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "support/pstl_test_config.h" #include #include #include "support/utils.h" /* TODO: consider implementing the following tests for a better code coverage - correctness - bad input argument (if applicable) - data corruption around/of input and output - correctly work with nested parallelism - check that algorithm does not require anything more than is described in its requirements section */ using namespace TestUtils; struct test_all_of { template void operator()(ExecutionPolicy&& exec, Iterator begin, Iterator end, Predicate pred, bool expected) { auto actualr = std::all_of(exec, begin, end, pred); EXPECT_EQ(expected, actualr, "result for all_of"); } }; template struct Parity { bool parity; public: Parity(bool parity_) : parity(parity_) {} bool operator()(T value) const { return (size_t(value) ^ parity) % 2 == 0; } }; template void test(size_t bits) { for (size_t n = 0; n <= 100000; n = n <= 16 ? n + 1 : size_t(3.1415 * n)) { // Sequence of odd values Sequence in(n, [n, bits](size_t) { return T(2 * HashBits(n, bits - 1) ^ 1); }); // Even value, or false when T is bool. T spike(2 * HashBits(n, bits - 1)); Sequence inCopy(in); invoke_on_all_policies(test_all_of(), in.begin(), in.end(), Parity(1), true); invoke_on_all_policies(test_all_of(), in.cbegin(), in.cend(), Parity(1), true); EXPECT_EQ(in, inCopy, "all_of modified input sequence"); if (n > 0) { // Sprinkle in a miss in[2 * n / 3] = spike; invoke_on_all_policies(test_all_of(), in.begin(), in.end(), Parity(1), false); invoke_on_all_policies(test_all_of(), in.cbegin(), in.cend(), Parity(1), false); // Sprinkle in a few more misses in[n / 2] = spike; in[n / 3] = spike; invoke_on_all_policies(test_all_of(), in.begin(), in.end(), Parity(1), false); invoke_on_all_policies(test_all_of(), in.cbegin(), in.cend(), Parity(1), false); } } } struct test_non_const { template void operator()(Policy&& exec, Iterator iter) { auto is_even = [&](float64_t v) { uint32_t i = (uint32_t)v; return i % 2 == 0; }; all_of(exec, iter, iter, non_const(is_even)); } }; int32_t main() { test(8 * sizeof(int32_t)); test(8 * sizeof(uint16_t)); test(53); #if !_PSTL_ICC_16_17_TEST_REDUCTION_BOOL_TYPE_RELEASE_64_BROKEN test(1); #endif test_algo_basic_single(run_for_rnd_fw()); std::cout << done() << std::endl; return 0; }