Boost logo

Boost Users :

From: gelbeiche (info_at_[hidden])
Date: 2006-06-08 11:30:39


Hi,

  I tried to use boost unittest lib at my linux box
  (SuSE 10.0 gcc version 4.0.2 ).
  I'm able to compile

  #include
  using boost::unit_test::test_suite;

  // most frequently you implement test cases as a free functions
  void free_test_function()
  {
  BOOST_CHECK( 2 == 1 );
  }

  test_suite*
  init_unit_test_suite( int argc, char* argv[] ) {
  test_suite* test= BOOST_TEST_SUITE( "Example" );

  test->add( BOOST_TEST_CASE( &free_test_function ));

  return test;
  }

  and to link against boost_unit_test_framework.

  make all-am
  make[1]: Entering directory `/home/pberg/boost_example_unittest'
  if g++ -DHAVE_CONFIG_H -I. -I. -I. -I/usr/local/include -g -O2 -MT
  main.o -MD -MP -MF ".deps/main.Tpo" -c -o main.o main.cpp; \ then mv
  -f
  ".deps/main.Tpo" ".deps/main.Po"; else rm -f ".deps/main.Tpo"; exit
  1;
  fi g++ -I/usr/local/include -g -O2 -lboost_unit_test_framework -o
  sharedpointer
  main.o
  /usr/lib/gcc/i586-suse-linux/4.0.2/../../../../i586-suse-linux/bin/ld:
  warning: libstdc++.so.5, needed
  by /usr/local/lib/libboost_unit_test_framework.so, may conflict with
  libstdc++.so.6 make[1]: Leaving directory
  `/home/pberg/boost_example_unittest'

  However at execution time I get:

  porschberg(pberg):/home/pberg/boost_example_unittest> ./sharedpointer
  *** glibc detected *** free(): invalid pointer: 0x0804ba10 ***
  Abgebrochen

  I "valgrinded" the executable and here is the output:

  *** errors detected in test suite "Example"; see standard output for
  details ==30533==
  ==30533== Mismatched free() / delete / delete []
  ==30533== at 0x1B904A69: free (vg_replace_malloc.c:152)
  ==30533== by 0x1BC2FC80: operator delete(void*)
  (in /usr/lib/libstdc++.so.5.0 .7)
  ==30533== by 0x1B95840B: boost::unit_test::test_suite::~test_suite()
  (in /usr /local/lib/libboost_unit_test_framework.so.1.33.1)
  ==30533== by 0x1B9407FA:
  boost::unit_test::framework_impl::~framework_impl()
  (in /usr/local/lib/libboost_unit_test_framework.so.1.33.1) ==30533==
  by 0x1B93DF5E: (within /usr/local/lib/libboost_unit_test_framework.
  so.1.33.1) ==30533== by 0x1BA9D313: exit (in /lib/tls/libc-2.3.5.so)
  ==30533== by 0x1BA87EA7: __libc_start_main
  (in /lib/tls/libc-2.3.5.so) ==30533== by 0x8049120: ??? (start.S:119)
  ==30533== Address 0x1BC5D908 is 0 bytes inside a block of size 52
  alloc'd ==30533== at 0x1B9046D3: operator new(unsigned)
  (vg_replace_malloc.c:132) ==30533== by 0x8049201:
  init_unit_test_suite(int, char**) (main.cpp:12) ==30533== by
  0x1B93EEBD: boost::unit_test::framework::init(int, char**) (in /
  usr/local/lib/libboost_unit_test_framework.so.1.33.1) ==30533== by
  0x1B94CF93: main
  (in /usr/local/lib/libboost_unit_test_framework .so.1.33.1) ==30533==
  ==30533== Mismatched free() / delete / delete []
  ==30533== at 0x1B904A69: free (vg_replace_malloc.c:152)
  ==30533== by 0x1BC2FC80: operator delete(void*)
  (in /usr/lib/libstdc++.so.5.0 .7)
  ==30533== by 0x1B940927:
  boost::unit_test::framework_impl::~framework_impl()
  (in /usr/local/lib/libboost_unit_test_framework.so.1.33.1) ==30533==
  by 0x1B93DF5E: (within /usr/local/lib/libboost_unit_test_framework.
  so.1.33.1) ==30533== by 0x1BA9D313: exit (in /lib/tls/libc-2.3.5.so)
  ==30533== by 0x1BA87EA7: __libc_start_main
  (in /lib/tls/libc-2.3.5.so) ==30533== by 0x8049120: ??? (start.S:119)
  ==30533== Address 0x1BC5D9E8 is 0 bytes inside a block of size 44
  alloc'd ==30533== at 0x1B9046D3: operator new(unsigned)
  (vg_replace_malloc.c:132) ==30533== by 0x804929E:
  init_unit_test_suite(int, char**) (unit_test_suite.hp p:222)
  ==30533== by 0x1B93EEBD: boost::unit_test::framework::init(int,
  char**) (in / usr/local/lib/libboost_unit_test_framework.so.1.33.1)
  ==30533== by 0x1B94CF93: main
  (in /usr/local/lib/libboost_unit_test_framework .so.1.33.1)
  ==30533==
  ==30533== ERROR SUMMARY: 7 errors from 7 contexts (suppressed: 24
  from
  2) ==30533== malloc/free: in use at exit: 9643 bytes in 6 blocks.
  ==30533== malloc/free: 24 allocs, 19 frees, 11593 bytes allocated.
  ==30533== For counts of detected errors, rerun with: -v
  ==30533== searching for pointers to 6 not-freed blocks.
  ==30533== checked 210328 bytes.
  ==30533==
  ==30533== LEAK SUMMARY:
  ==30533== definitely lost: 19 bytes in 1 blocks.
  ==30533== possibly lost: 0 bytes in 0 blocks.
  ==30533== still reachable: 9624 bytes in 5 blocks.
  ==30533== suppressed: 0 bytes in 0 blocks.
  ==30533== Use --leak-check=full to see details of leaked memory.

I looked through the mailing list archives with no luck.
Could someone give a hint ?

Thomas


Boost-users list run by williamkempf at hotmail.com, kalb at libertysoft.com, bjorn.karlsson at readsoft.com, gregod at cs.rpi.edu, wekempf at cox.net