LUMIERA.clone/tests/core/proc/mobject/session/test-scopes.cpp
Ichthyostega c2ea15695e amend harmless PlacementIndex test failures. Test Suite PASS
c++11 uses another hashtable implementation.
This uncovered some poorly written tests, which relied on
objects being returned in a specific order. As far as poissible,
we're using generic query functions now to get our test objects.

But these tests still rely on a specifically crafted test index content,
which as such is acceptable IMHO. The only remaining problem is
that we check the order of generated output in some tests, and this
order is still implementation dependent.
2014-05-11 02:08:53 +02:00

110 lines
3.3 KiB
C++

/*
TEST-SCOPES.cpp - builds a test PlacementIndex containing dummy Placements as nested scopes
Copyright (C) Lumiera.org
2009, Hermann Vosseler <Ichthyostega@web.de>
This program 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 2 of
the License, or (at your option) any later version.
This program 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 this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
* *****************************************************/
#include "proc/mobject/session/test-scopes.hpp"
#include "proc/mobject/session/session-service-mock-index.hpp"
#include "proc/mobject/session/session-service-explore-scope.hpp"
#include "proc/mobject/session/scope-query.hpp"
namespace proc {
namespace mobject {
namespace session {
namespace test {
/** @note this dummy index isn't actively connected to the session;
* the unit tests rely on this dummy index containing
* a specific tree structure of test-dummy MObjects.
*/
PPIdx
build_testScopes()
{
PDum p1(*new TestSubMO21);
PDum p2(*new TestSubMO21);
PDum p3(*new TestSubMO21);
PDum p4(*new TestSubMO21);
PDum p5(*new TestSubMO21);
PDum ps1(*new DummyMO);
PDum ps2(*new TestSubMO2);
PDum ps3(*new TestSubMO1);
// Prepare an (test)Index backing the PlacementRefs
PPIdx index (SessionServiceMockIndex::install());
PMO& root = index->getRoot();
typedef PMO::ID ID;
ID i1 = index->insert (p1, root);
ID i2 = index->insert (p2, i1 );
ID i3 = index->insert (p3, i2 );
ID i4 = index->insert (p4, i3 );
ID i5 = index->insert (p5, i4 );
ID is1 = index->insert (ps1,root);
ID is2 = index->insert (ps2,root);
ID is3 = index->insert (ps3, is2);
return index;
}
namespace {
template<class MO>
PlacementMO&
retrieve_firstElmOfType()
{
return *ContentsQuery<MO>(SessionServiceExploreScope::getScopeRoot())
.resolveBy(SessionServiceExploreScope::getResolver());
}
}
/** @note this test helper only works if build_testScopes is invoked
* beforehand, and the returned smart-ptr to the created test/dummy index
* is retained. Moreover, this function makes assumptions about the actual
* objects created by the former test function.
* @throw lumiera::error::Invalid if the intended start element doesn't exist (anymore)
*/
PlacementMO&
retrieve_startElm()
{
return retrieve_firstElmOfType<TestSubMO1>();
}
PlacementMO&
retrieve_firstTestSubMO21()
{
return retrieve_firstElmOfType<TestSubMO21>();
}
ScopeQuery<MObject>::iterator
explore_testScope (PlacementMO const& scopeTop)
{
return ScopeQuery<MObject>(scopeTop, CHILDREN)
.resolveBy(SessionServiceExploreScope::getResolver());
}
}}}} // namespace proc::mobject::session::test