// // Copyright 2014 Ettus Research LLC // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // #include "graph.hpp" #include #include using namespace uhd::rfnoc; class source_node : public test_node { public: typedef boost::shared_ptr sptr; source_node(const std::string &test_id, size_t output_port) : test_node(test_id) , active_rx_streamer_on_port(0) , _output_port(output_port) {}; void set_rx_streamer(bool active, const size_t port) { if (active) { std::cout << "[source_node] Someone is registering a rx streamer on port " << port << std::endl; active_rx_streamer_on_port = port; } } size_t active_rx_streamer_on_port; protected: size_t _request_output_port( const size_t, const uhd::device_addr_t & ) const { return _output_port; } const size_t _output_port; }; /* class result_node */ class sink_node : public test_node { public: typedef boost::shared_ptr sptr; sink_node(const std::string &test_id, size_t input_port) : test_node(test_id) , active_tx_streamer_on_port(0) , _input_port(input_port) {}; void set_tx_streamer(bool active, const size_t port) { if (active) { std::cout << "[sink_node] Someone is registering a tx streamer on port " << port << std::endl; active_tx_streamer_on_port = port; } } size_t active_tx_streamer_on_port; protected: size_t _request_input_port( const size_t, const uhd::device_addr_t & ) const { return _input_port; } const size_t _input_port; }; /* class result_node */ #define MAKE_SOURCE_NODE(name, port) source_node::sptr name(new source_node(#name, port)); #define MAKE_SINK_NODE(name, port) sink_node::sptr name(new sink_node(#name, port)); BOOST_AUTO_TEST_CASE(test_simple_connect) { MAKE_SOURCE_NODE(node_A, 42); MAKE_SINK_NODE(node_B, 23); size_t src_port = node_A->connect_downstream(node_B, 1); size_t dst_port = node_B->connect_upstream(node_A, 2); BOOST_CHECK_EQUAL(src_port, 42); BOOST_CHECK_EQUAL(dst_port, 23); node_A->set_downstream_port(src_port, dst_port); node_B->set_upstream_port(dst_port, src_port); BOOST_CHECK_EQUAL(node_A->get_downstream_port(src_port), dst_port); BOOST_CHECK_EQUAL(node_B->get_upstream_port(dst_port), src_port); BOOST_REQUIRE_THROW(node_A->get_downstream_port(999), uhd::value_error); } BOOST_AUTO_TEST_CASE(test_fail) { MAKE_SOURCE_NODE(node_A, 42); MAKE_SINK_NODE(node_B, ANY_PORT); node_A->connect_downstream(node_B, 1); BOOST_REQUIRE_THROW(node_B->connect_upstream(node_A, 2), uhd::type_error); } BOOST_AUTO_TEST_CASE(test_set_streamers) { MAKE_SOURCE_NODE(node_A, 0); MAKE_NODE(node_B); MAKE_SINK_NODE(node_C, 0); size_t src_port_A = node_A->connect_downstream(node_B, 0); size_t src_port_B = node_B->connect_downstream(node_C, 0); size_t dst_port_B = node_B->connect_upstream(node_A, 0); size_t dst_port_C = node_C->connect_upstream(node_B, 0); std::cout << "src_port_A: " << src_port_A << std::endl; std::cout << "src_port_B: " << src_port_B << std::endl; std::cout << "dst_port_B: " << dst_port_B << std::endl; std::cout << "dst_port_C: " << dst_port_C << std::endl; node_A->set_downstream_port(src_port_A, dst_port_B); node_B->set_upstream_port(dst_port_B, src_port_A); node_B->set_downstream_port(src_port_B, dst_port_C); node_C->set_upstream_port(dst_port_C, src_port_B); node_A->set_tx_streamer(true, 0); node_C->set_rx_streamer(true, 0); BOOST_CHECK_EQUAL(node_A->active_rx_streamer_on_port, src_port_A); BOOST_CHECK_EQUAL(node_C->active_tx_streamer_on_port, dst_port_C); }