/*
-----------------------------------------------------------------------
Copyright 2012 iMinds-Vision Lab, University of Antwerp
Contact: astra@ua.ac.be
Website: http://astra.ua.ac.be
This file is part of the
All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox").
The ASTRA Toolbox 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.
The ASTRA Toolbox 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 the ASTRA Toolbox. If not, see .
-----------------------------------------------------------------------
$Id$
*/
#define BOOST_TEST_DYN_LINK
#include
#include
#include "astra/AstraObjectManager.h"
namespace astra {
DEFINE_SINGLETON(CAstraObjectManager);
}
BOOST_AUTO_TEST_CASE( testAstraObjectManager )
{
astra::CAstraObjectManager man;
int i1 = man.store(new int(1));
BOOST_REQUIRE(man.hasIndex(i1));
BOOST_CHECK(*(man.get(i1)) == 1);
int i2 = man.store(new int(2));
BOOST_REQUIRE(man.hasIndex(i2));
BOOST_CHECK(*(man.get(i1)) == 1);
BOOST_CHECK(*(man.get(i2)) == 2);
man.remove(i1);
BOOST_CHECK(!man.hasIndex(i1));
BOOST_REQUIRE(man.hasIndex(i2));
int i3 = man.store(new int(3));
BOOST_REQUIRE(man.hasIndex(i3));
BOOST_CHECK(*(man.get(i2)) == 2);
BOOST_CHECK(*(man.get(i3)) == 3);
int* pi4 = new int(4);
int i4 = man.store(pi4);
BOOST_REQUIRE(man.hasIndex(i4));
BOOST_CHECK(*(man.get(i2)) == 2);
BOOST_CHECK(*(man.get(i3)) == 3);
BOOST_CHECK(*(man.get(i4)) == 4);
BOOST_CHECK(man.getIndex(pi4) == i4);
man.clear();
BOOST_CHECK(!man.hasIndex(i1));
BOOST_CHECK(!man.hasIndex(i2));
BOOST_CHECK(!man.hasIndex(i3));
BOOST_CHECK(!man.hasIndex(i4));
BOOST_CHECK(!man.getIndex(pi4));
}