X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Ftest_boost_threads.cpp;h=7af983d4bdf477ee750ca6ddab98635e4fa9ae44;hb=e1c7fdb3e2ff41fb43ea3dd2c540b6d568dee851;hp=08af85606bc4fee6066a0dc42a72560b4be26f58;hpb=83ff1cfb6e933cc70a5c3c8f331f92c941325188;p=metaproxy-moved-to-github.git diff --git a/src/test_boost_threads.cpp b/src/test_boost_threads.cpp index 08af856..7af983d 100644 --- a/src/test_boost_threads.cpp +++ b/src/test_boost_threads.cpp @@ -1,96 +1,103 @@ +/* $Id: test_boost_threads.cpp,v 1.8 2006-06-10 14:29:12 adam Exp $ + Copyright (c) 2005-2006, Index Data. + See the LICENSE file for details + */ + +#include "config.hpp" #include #include + +#define BOOST_AUTO_TEST_MAIN +#include + #include #include -boost::mutex io_mutex; // The iostreams are not guaranteed to be thread-safe! - class counter { public: counter() : count(0) { } - int increment() { - boost::mutex::scoped_lock scoped_lock(mutex); - return ++count; - } - - private: - boost::mutex mutex; - int count; + int increment() { + boost::mutex::scoped_lock scoped_lock(mutex); + return ++count; + } + +private: + boost::mutex mutex; + int count; }; counter c; -void change_count() -{ - int i = c.increment(); - boost::mutex::scoped_lock scoped_lock(io_mutex); - std::cout << "count == " << i << std::endl; -} - - class worker { public: void operator() (void) { - int i = c.increment(); - - i = c.increment(); - - i = c.increment(); - boost::mutex::scoped_lock scoped_lock(io_mutex); - std::cout << "count == " << i << std::endl; + c.increment(); } - virtual ~worker() { std::cout << "destroyed\n"; } }; +#define USE_GROUP 1 -int main(int, char*[]) +BOOST_AUTO_UNIT_TEST( thread_group ) { - try - { - const int num_threads = 4; - boost::thread_group thrds; - - std::list thread_list; - - for (int i=0; i < num_threads; ++i) - { - // thrds.create_thread(&change_count); - worker *w = new worker; + try + { + const int num_threads = 4; + boost::thread_group thrds; + + for (int i=0; i < num_threads; ++i) + { + worker w; + thrds.add_thread(new boost::thread(w)); + } + thrds.join_all(); + } + catch (...) + { + BOOST_CHECK(false); + } + BOOST_CHECK(c.increment() == 5); +} - boost::thread *thr = new boost::thread(*w); - thrds.add_thread(thr); +BOOST_AUTO_UNIT_TEST( thread_list ) +{ + try + { + const int num_threads = 4; + std::list thread_list; + + for (int i=0; i < num_threads; ++i) + { + worker w; + thread_list.push_back(new boost::thread(w)); + } + std::list::iterator it; + for (it = thread_list.begin(); it != thread_list.end(); it++) + { + (*it)->join(); + delete *it; + } - thread_list.push_back(thr); - } - - thrds.join_all(); -#if 0 - std::list::iterator it; - for (it = thread_list.begin(); it != thread_list.end(); it++) - { - delete *it; - *it = 0; - } -#endif - } - catch (std::exception &e) - { - std::cout << e.what() << "\n"; - exit(1); - } - exit(0); + } + catch (...) + { + BOOST_CHECK(false); + } + BOOST_CHECK(c.increment() == 10); } + + /* * Local variables: * c-basic-offset: 4 * indent-tabs-mode: nil + * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */