151c0b2f7Stbbdev /* 2b15aabb3Stbbdev Copyright (c) 2020-2021 Intel Corporation 351c0b2f7Stbbdev 451c0b2f7Stbbdev Licensed under the Apache License, Version 2.0 (the "License"); 551c0b2f7Stbbdev you may not use this file except in compliance with the License. 651c0b2f7Stbbdev You may obtain a copy of the License at 751c0b2f7Stbbdev 851c0b2f7Stbbdev http://www.apache.org/licenses/LICENSE-2.0 951c0b2f7Stbbdev 1051c0b2f7Stbbdev Unless required by applicable law or agreed to in writing, software 1151c0b2f7Stbbdev distributed under the License is distributed on an "AS IS" BASIS, 1251c0b2f7Stbbdev WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1351c0b2f7Stbbdev See the License for the specific language governing permissions and 1451c0b2f7Stbbdev limitations under the License. 1551c0b2f7Stbbdev */ 1651c0b2f7Stbbdev 17b15aabb3Stbbdev #if __INTEL_COMPILER && _MSC_VER 18b15aabb3Stbbdev #pragma warning(disable : 2586) // decorated name length exceeded, name was truncated 19b15aabb3Stbbdev #endif 2051c0b2f7Stbbdev 21*de0109beSIlya Mishin #define CONFORMANCE_BUFFERING_NODES 22*de0109beSIlya Mishin #define CONFORMANCE_QUEUE_NODE 2351c0b2f7Stbbdev 2451c0b2f7Stbbdev #include "conformance_flowgraph.h" 2551c0b2f7Stbbdev 2651c0b2f7Stbbdev //! \file conformance_priority_queue_node.cpp 2751c0b2f7Stbbdev //! \brief Test for [flow_graph.priority_queue_node] specification 2851c0b2f7Stbbdev 29*de0109beSIlya Mishin //! Test priority_queue_node single_push 3051c0b2f7Stbbdev //! \brief \ref requirement 31*de0109beSIlya Mishin TEST_CASE("priority_queue_node single_push"){ 32*de0109beSIlya Mishin conformance::test_forwarding_single_push<oneapi::tbb::flow::priority_queue_node<int>>(); 3351c0b2f7Stbbdev } 3451c0b2f7Stbbdev 35*de0109beSIlya Mishin //! Test function_node buffering 3651c0b2f7Stbbdev //! \brief \ref requirement 3751c0b2f7Stbbdev TEST_CASE("priority_queue_node buffering"){ 38*de0109beSIlya Mishin conformance::test_buffering<oneapi::tbb::flow::priority_queue_node<int>, int>(); 3951c0b2f7Stbbdev } 4051c0b2f7Stbbdev 41*de0109beSIlya Mishin //! Constructs an empty priority_queue_node that belongs to the same graph g as src. 42*de0109beSIlya Mishin //! Any intermediate state of src, including its links to predecessors and successors, is not copied. 43*de0109beSIlya Mishin //! \brief \ref requirement 4451c0b2f7Stbbdev TEST_CASE("priority_queue_node copy constructor"){ 45*de0109beSIlya Mishin conformance::test_copy_ctor_for_buffering_nodes<oneapi::tbb::flow::priority_queue_node<int>>(); 4651c0b2f7Stbbdev } 4751c0b2f7Stbbdev 4851c0b2f7Stbbdev //! Test inheritance relations 4951c0b2f7Stbbdev //! \brief \ref interface 5051c0b2f7Stbbdev TEST_CASE("priority_queue_node superclasses"){ 51*de0109beSIlya Mishin conformance::test_inheritance<oneapi::tbb::flow::priority_queue_node<int>, int, int>(); 52*de0109beSIlya Mishin conformance::test_inheritance<oneapi::tbb::flow::priority_queue_node<void*>, void*, void*>(); 5351c0b2f7Stbbdev } 5451c0b2f7Stbbdev 55*de0109beSIlya Mishin //! Test priority_queue_node node `try_put()` and `try_get()` 56*de0109beSIlya Mishin //! \brief \ref requirement 57*de0109beSIlya Mishin TEST_CASE("priority_queue_node methods"){ 58*de0109beSIlya Mishin oneapi::tbb::flow::graph g; 59*de0109beSIlya Mishin 60*de0109beSIlya Mishin oneapi::tbb::flow::priority_queue_node<int, std::greater<int>> testing_node(g); 61*de0109beSIlya Mishin 62*de0109beSIlya Mishin testing_node.try_put(2); 63*de0109beSIlya Mishin testing_node.try_put(3); 64*de0109beSIlya Mishin testing_node.try_put(1); 65*de0109beSIlya Mishin g.wait_for_all(); 66*de0109beSIlya Mishin 67*de0109beSIlya Mishin int tmp = -1; 68*de0109beSIlya Mishin CHECK_MESSAGE((testing_node.try_get(tmp)), "Get should succeed"); 69*de0109beSIlya Mishin CHECK_MESSAGE((tmp == 1), "Values should get sorted"); 70*de0109beSIlya Mishin CHECK_MESSAGE((testing_node.try_get(tmp)), "Get should succeed"); 71*de0109beSIlya Mishin CHECK_MESSAGE((tmp == 2), "Values should get sorted"); 72*de0109beSIlya Mishin CHECK_MESSAGE((testing_node.try_get(tmp)), "Get should succeed"); 73*de0109beSIlya Mishin CHECK_MESSAGE((tmp == 3), "Values should get sorted"); 74*de0109beSIlya Mishin } 75