wait_all_vector_test.cpp 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. // Copyright (C) 2017 Alain Miniussi & Vincent Chabannes
  2. // Use, modification and distribution is subject to the Boost Software
  3. // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
  4. // http://www.boost.org/LICENSE_1_0.txt)
  5. #include <string>
  6. #include <iostream>
  7. #include <sstream>
  8. #include <vector>
  9. #include <boost/mpi.hpp>
  10. #include <boost/mpi/nonblocking.hpp>
  11. #include <boost/serialization/string.hpp>
  12. #define BOOST_TEST_MODULE mpi_wait_any
  13. #include <boost/test/included/unit_test.hpp>
  14. namespace mpi = boost::mpi;
  15. BOOST_AUTO_TEST_CASE(wait_any)
  16. {
  17. mpi::environment env;
  18. mpi::communicator comm;
  19. int rank = comm.rank();
  20. int const sz = 10;
  21. std::vector<int> data;
  22. std::vector< mpi::request> reqs;
  23. if ( rank == 0 ) {
  24. for ( int i=0; i<sz; ++i ) {
  25. data.push_back( i );
  26. }
  27. reqs.push_back( comm.isend(1, 0, data) );
  28. } else if ( rank == 1 ) {
  29. reqs.push_back( comm.irecv(0, 0, data) );
  30. }
  31. mpi::wait_all( reqs.begin(), reqs.end() );
  32. if ( rank == 1 ) {
  33. BOOST_CHECK(data.size() == sz);
  34. for ( int i=0; i<sz; ++i ) {
  35. BOOST_CHECK(data[i] == i);
  36. }
  37. }
  38. }