diff options
author | Marcelo Lira <marcelo.lira@openbossa.org> | 2009-08-25 02:56:00 -0300 |
---|---|---|
committer | Marcelo Lira <marcelo.lira@openbossa.org> | 2009-08-25 02:56:00 -0300 |
commit | 2132a3eb82830d0719d19eaadb32e39222948bca (patch) | |
tree | f0de40997a45a36e0c92d52a6beeab0a98ee01b3 /tests/samplebinding/map_test.py | |
parent | 64243890de689d10d04fdcdeedfe16c1ee612fb8 (diff) |
added mapping example to test lib as well as unit tests
Diffstat (limited to 'tests/samplebinding/map_test.py')
-rwxr-xr-x | tests/samplebinding/map_test.py | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/samplebinding/map_test.py b/tests/samplebinding/map_test.py new file mode 100755 index 000000000..d2ac4eaad --- /dev/null +++ b/tests/samplebinding/map_test.py @@ -0,0 +1,46 @@ +#!/usr/bin/python + +'''Test cases for std::map container conversions''' + +import sys +import unittest + +from sample import MapUser + +class ExtendedMapUser(MapUser): + def __init__(self): + MapUser.__init__(self) + self.create_map_called = False + + def createMap(self): + self.create_map_called = True + return {'two' : (complex(2.2, 2.2), 2), + 'three' : (complex(3.3, 3.3), 3), + 'five' : (complex(5.5, 5.5), 5), + 'seven' : (complex(7.7, 7.7), 7)} + +class MapConversionTest(unittest.TestCase): + '''Test case for std::map container conversions''' + + def testReimplementedVirtualMethodCall(self): + '''Test if a Python override of a virtual method is correctly called from C++.''' + mu = ExtendedMapUser() + map_ = mu.callCreateMap() + self.assert_(mu.create_map_called) + self.assertEqual(type(map_), dict) + for key, value in map_.items(): + self.assertEqual(type(key), str) + self.assertEqual(type(value[0]), complex) + self.assertEqual(type(value[1]), int) + + def testConversionInBothDirections(self): + '''Test converting a map from Python to C++ and back again.''' + mu = MapUser() + map_ = {'odds' : [2, 4, 6], 'evens' : [3, 5, 7], 'primes' : [3, 4, 6]} + mu.setMap(map_) + result = mu.getMap() + self.assertEqual(result, map_) + +if __name__ == '__main__': + unittest.main() + |