2 #include "audiographer/identity_vertex.h"
4 using namespace AudioGrapher;
6 class IdentityVertexTest : public CppUnit::TestFixture
8 CPPUNIT_TEST_SUITE (IdentityVertexTest);
9 CPPUNIT_TEST (testProcess);
10 CPPUNIT_TEST (testRemoveOutput);
11 CPPUNIT_TEST (testClearOutputs);
12 CPPUNIT_TEST_SUITE_END ();
18 random_data = TestUtils::init_random_data(frames);
20 zero_data = new float[frames];
21 memset (zero_data, 0, frames * sizeof(float));
23 sink_a.reset (new VectorSink<float>());
24 sink_b.reset (new VectorSink<float>());
29 delete [] random_data;
35 vertex.reset (new IdentityVertex<float>());
36 vertex->add_output (sink_a);
37 vertex->add_output (sink_b);
39 nframes_t frames_output = 0;
41 ProcessContext<float> c (random_data, frames, 1);
44 frames_output = sink_a->get_data().size();
45 CPPUNIT_ASSERT_EQUAL (frames, frames_output);
47 frames_output = sink_b->get_data().size();
48 CPPUNIT_ASSERT_EQUAL (frames, frames_output);
50 CPPUNIT_ASSERT (TestUtils::array_equals (random_data, sink_a->get_array(), frames));
51 CPPUNIT_ASSERT (TestUtils::array_equals (random_data, sink_b->get_array(), frames));
54 void testRemoveOutput()
56 vertex.reset (new IdentityVertex<float>());
57 vertex->add_output (sink_a);
58 vertex->add_output (sink_b);
60 ProcessContext<float> c (random_data, frames, 1);
63 vertex->remove_output (sink_a);
64 ProcessContext<float> zc (zero_data, frames, 1);
67 CPPUNIT_ASSERT (TestUtils::array_equals (random_data, sink_a->get_array(), frames));
68 CPPUNIT_ASSERT (TestUtils::array_equals (zero_data, sink_b->get_array(), frames));
71 void testClearOutputs()
73 vertex.reset (new IdentityVertex<float>());
74 vertex->add_output (sink_a);
75 vertex->add_output (sink_b);
77 ProcessContext<float> c (random_data, frames, 1);
80 vertex->clear_outputs ();
81 ProcessContext<float> zc (zero_data, frames, 1);
84 CPPUNIT_ASSERT (TestUtils::array_equals (random_data, sink_a->get_array(), frames));
85 CPPUNIT_ASSERT (TestUtils::array_equals (random_data, sink_b->get_array(), frames));
89 boost::shared_ptr<IdentityVertex<float> > vertex;
90 boost::shared_ptr<VectorSink<float> > sink_a;
91 boost::shared_ptr<VectorSink<float> > sink_b;
98 CPPUNIT_TEST_SUITE_REGISTRATION (IdentityVertexTest);