whitebox-Channels.C
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038 #ifndef TESTSUITE_WHITEBOX_CHANNELS_C_DEFINED
00039 #define TESTSUITE_WHITEBOX_CHANNELS_C_DEFINED
00040
00041 #include "Channels/ChannelFacet.H"
00042 #include "Channels/ComplexChannel.H"
00043 #include "Channels/SingleChannel.H"
00044 #include "Component/ModelManager.H"
00045 #include "Component/ParamMap.H"
00046 #include "TestSuite/TestSuite.H"
00047
00048 #include <sstream>
00049
00050 namespace
00051 {
00052 class DummyFacet : public ChannelFacet
00053 {
00054 public:
00055 DummyFacet(int m) : magic(m) {}
00056
00057 virtual ~DummyFacet() {}
00058
00059 virtual void writeTo(ParamMap& pmap) const
00060 {
00061 pmap.putIntParam("magic", magic);
00062 }
00063
00064 virtual void readFrom(const ParamMap& pmap)
00065 {
00066 pmap.queryIntParam("magic", magic);
00067 }
00068
00069 int magic;
00070 };
00071 }
00072
00073 static void Channels_xx_facets_xx_1(TestSuite& suite)
00074 {
00075 ModelManager m("");
00076
00077 nub::ref<SingleChannel> c
00078 (new SingleChannel
00079 (m, "dummy", "dummy", UNKNOWN,
00080 rutz::make_shared(new GaussianPyrBuilder<float>(5))));
00081
00082 m.addSubComponent(c);
00083 m.exportOptions(MC_RECURSE);
00084
00085 m.start();
00086
00087 REQUIRE_EQ(c->hasFacet<DummyFacet>(), false);
00088 REQUIRE_EQ(c->hasFacet<int>(), false);
00089
00090 rutz::shared_ptr<DummyFacet> f(new DummyFacet(42));
00091
00092 c->setFacet(f);
00093
00094 REQUIRE_EQ(c->hasFacet<DummyFacet>(), true);
00095 REQUIRE_EQ(c->hasFacet<int>(), false);
00096 REQUIRE_EQ(c->getFacet<DummyFacet>()->magic, 42);
00097
00098 ParamMap pmap;
00099 c->writeTo(pmap);
00100 std::ostringstream oss;
00101 pmap.format(oss);
00102
00103 REQUIRE_EQ(oss.str(),
00104 std::string("(anonymous\\ namespace)::DummyFacet {\n"
00105 "\tmagic 42\n"
00106 "}\n"
00107 "descriptivename dummy\n"));
00108
00109 f->magic = 39;
00110 REQUIRE_EQ(f->magic, 39);
00111
00112 ParamMap pmap2;
00113 std::istringstream iss(oss.str());
00114 pmap2.load(iss);
00115 c->readFrom(pmap2);
00116 REQUIRE_EQ(f->magic, 42);
00117 }
00118
00119
00120
00121
00122
00123
00124
00125 int main(int argc, const char** argv)
00126 {
00127 TestSuite suite;
00128
00129 suite.ADD_TEST(Channels_xx_facets_xx_1);
00130
00131 suite.parseAndRun(argc, argv);
00132
00133 return 0;
00134 }
00135
00136
00137
00138
00139
00140
00141
00142
00143 #endif // TESTSUITE_WHITEBOX_CHANNELS_C_DEFINED