1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
|
// -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
#include <BALL/CONCEPT/classTest.h>
///////////////////////////
#include <BALL/CONCEPT/autoDeletable.h>
///////////////////////////
using namespace BALL;
class A
: public AutoDeletable
{
};
START_TEST(AutoDeletable)
/////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////
A* a_ptr;
A* array_ptr;
CHECK(void* operator new(size_t size) throw())
a_ptr = new A;
array_ptr = new A[12];
RESULT
A a;
A array[12];
CHECK(~AutoDeletable() throw())
delete a_ptr;
delete [] array_ptr;
RESULT
a_ptr = new A;
array_ptr = new A[12];
CHECK(bool isAutoDeletable() const throw())
TEST_EQUAL(a.isAutoDeletable(), false)
TEST_EQUAL(a_ptr->isAutoDeletable(), true)
TEST_EQUAL(array_ptr->isAutoDeletable(), false)
TEST_EQUAL(array->isAutoDeletable(), false)
RESULT
CHECK(void setAutoDeletable(bool enable) throw())
TEST_EQUAL(a.isAutoDeletable(), false)
a.setAutoDeletable(true);
TEST_EQUAL(a.isAutoDeletable(), true)
a.setAutoDeletable(false);
TEST_EQUAL(a.isAutoDeletable(), false)
TEST_EQUAL(a_ptr->isAutoDeletable(), true)
a_ptr->setAutoDeletable(false);
TEST_EQUAL(a_ptr->isAutoDeletable(), false)
a_ptr->setAutoDeletable(true);
TEST_EQUAL(a_ptr->isAutoDeletable(), true)
RESULT
delete a_ptr;
delete [] array_ptr;
CHECK(void operator delete(void* ptr) throw())
// ???
RESULT
CHECK(void operator delete(void* ptr, void*) throw())
// ???
RESULT
CHECK(void* operator new(size_t size, void* ptr) throw())
// ???
RESULT
/////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////
END_TEST
|