LUMIERA.clone/tests/library/diff/tree-mutator-test.cpp
Ichthyostega 48e9b7594a Doxygen: identify all files lacking a @file comment
reason is, only files with a @file comment will be processed
with further documentation commands. For this reason, our Doxygen
documentation is lacking a lot of entries.

HOWTO:
find src -type f \( -name '*.cpp' -or -name '*.hpp' \) -not -exec egrep -q '\*.+@file' {} \; -print -exec sed -i -r -e'\_\*/_,$ { 1,+0 a\
\
\
/** @file §§§\
 ** TODO §§§\
 */
}' {} \;
2016-11-03 18:20:10 +01:00

150 lines
4.3 KiB
C++

/*
TreeMutator(Test) - customisable intermediary to abstract tree changing operations
Copyright (C) Lumiera.org
2015, 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.
* *****************************************************/
/** @file §§§
** unit test TODO §§§
*/
#include "lib/test/run.hpp"
#include "lib/format-util.hpp"
#include "lib/test/test-helper.hpp"
#include "lib/diff/tree-mutator.hpp"
#include "lib/format-cout.hpp"
#include "lib/format-util.hpp"
#include "lib/util.hpp"
#include <string>
#include <vector>
using util::isnil;
using util::join;
using util::typeStr;
using std::string;
using std::vector;
namespace lib {
namespace diff{
namespace test{
/*****************************************************************************//**
* @test Demonstrate a customisable component for flexible bindings
* to enable generic tree changing and mutating operations to
* arbitrary hierarchical data structures.
* - we use lambdas to link into our private implementation
* - this test demonstrates the behaviour of an attribute setter
* - plus some of the _primitive operations_ available on collections
*
* @see TreeMutator
* @see DiffComplexApplication_test a way more complex usage scenario
* @see GenNodeBasic_test
* @see GenericRecordRepresentation_test
*/
class TreeMutator_test : public Test
{
virtual void
run (Arg)
{
simpleAttributeBinding();
simpleCollectionBinding();
}
void
simpleAttributeBinding()
{
MARK_TEST_FUN;
string localData;
auto mutator =
TreeMutator::build()
.change("data", [&](string val)
{
cout << "\"data\" closure received something "<<val<<endl;
localData = val;
});
cout << "concrete TreeMutator size=" << sizeof(mutator)
<< " type="<< typeStr(mutator)
<< endl;
mutator.init();
CHECK (isnil (localData));
string testValue{"that would be acceptable"};
mutator.assignElm ({"lore", testValue});
CHECK ( isnil (localData)); // nothing happens, nothing changed
mutator.assignElm ({"data", testValue});
CHECK (!isnil (localData));
cout << "localData changed to: "<<localData<<endl;
CHECK (localData == "that would be acceptable");
}
void
simpleCollectionBinding()
{
MARK_TEST_FUN;
vector<string> values;
values.push_back("a");
values.push_back("b");
cout << join(values) <<endl;
CHECK (2 == values.size());
CHECK ("a, b" == join(values));
auto mutator =
TreeMutator::build()
.attach (collection(values));
cout << "concrete TreeMutator size=" << sizeof(mutator)
<< " type="<< typeStr(mutator)
<< endl;
mutator.init();
CHECK (isnil (values));
CHECK (mutator.matchSrc (GenNode("a")));
mutator.skipSrc (GenNode("a"));
CHECK (mutator.matchSrc (GenNode("b")));
CHECK (mutator.injectNew (GenNode("c")));
CHECK (mutator.acceptSrc (GenNode("b")));
cout << join(values) <<endl;
CHECK (2 == values.size());
CHECK ("c, b" == join(values));
}
};
/** Register this test class... */
LAUNCHER (TreeMutator_test, "unit common");
}}} // namespace lib::diff::test