source: molecuilder/src/unittests/CacheableTest.cpp@ 495a53

Last change on this file since 495a53 was 5dba7a, checked in by Tillmann Crueger <crueger@…>, 15 years ago

Made the periodentafel use STL-containers instead of custom llists

  • Property mode set to 100644
File size: 1.5 KB
Line 
1/*
2 * CacheableTest.cpp
3 *
4 * Created on: Feb 2, 2010
5 * Author: crueger
6 */
7
8#include "CacheableTest.hpp"
9
10#include <cppunit/CompilerOutputter.h>
11#include <cppunit/extensions/TestFactoryRegistry.h>
12#include <cppunit/ui/text/TestRunner.h>
13
14#include <boost/bind.hpp>
15
16#include "Patterns/Cacheable.hpp"
17
18#ifdef HAVE_TESTRUNNER
19#include "UnitTestMain.hpp"
20#endif /*HAVE_TESTRUNNER*/
21
22/********************************************** Test classes **************************************/
23
24// Registers the fixture into the 'registry'
25CPPUNIT_TEST_SUITE_REGISTRATION( CacheableTest );
26
27class threeNumbers : public Observable {
28public:
29 int x;
30 int y;
31 int z;
32 Cacheable<int> sum;
33 bool hasRecalced;
34
35 void setX(int _x){
36 OBSERVE;
37 x = _x;
38 }
39
40 void setY
41 (int _y){
42 OBSERVE;
43 y = _y;
44 }
45
46 void setZ(int _z){
47 OBSERVE;
48 z = _z;
49 }
50
51 int calcSum(){
52 hasRecalced = true;
53 return x+y+z;
54 }
55
56 threeNumbers(int _x,int _y, int _z) :
57 x(_x),y(_y),z(_z),
58 sum(this,boost::bind(&threeNumbers::calcSum,this)),
59 hasRecalced(false)
60 {}
61};
62
63
64
65
66void CacheableTest::setUp(){
67 numbers = new threeNumbers(1,2,3);
68}
69
70void CacheableTest::tearDown(){
71 delete numbers;
72}
73
74void CacheableTest::doesRecalcTest()
75{
76 CPPUNIT_ASSERT_EQUAL( 6, *(numbers->sum));
77 CPPUNIT_ASSERT_EQUAL( true, numbers->hasRecalced);
78 numbers->hasRecalced=false;
79 numbers->setX(4);
80 CPPUNIT_ASSERT_EQUAL( false, numbers->hasRecalced);
81 CPPUNIT_ASSERT_EQUAL( 9, *(numbers->sum));
82 CPPUNIT_ASSERT_EQUAL( true, numbers->hasRecalced);
83}
Note: See TracBrowser for help on using the repository browser.