/[thuban]/branches/WIP-pyshapelib-bramz/test/test_classification.py
ViewVC logotype

Diff of /branches/WIP-pyshapelib-bramz/test/test_classification.py

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1905 by bh, Fri Oct 31 17:09:58 2003 UTC revision 1910 by bh, Fri Oct 31 18:16:46 2003 UTC
# Line 13  __version__ = "$Revision$" Line 13  __version__ = "$Revision$"
13  # $Source$  # $Source$
14  # $Id$  # $Id$
15    
 from __future__ import nested_scopes  
   
16  import unittest  import unittest
17    
18  import support  import support
19  support.initthuban()  support.initthuban()
20    
 import os  
21  import copy  import copy
22    
23  from Thuban.Model.color import Color, Transparent, Black  from Thuban.Model.color import Color, Transparent, Black
 from Thuban.Model.table import FIELDTYPE_INT, FIELDTYPE_STRING, FIELDTYPE_DOUBLE  
24  from Thuban.Model.classification import \  from Thuban.Model.classification import \
25      Classification, ClassGroup, \      Classification, ClassGroup, \
26      ClassGroupDefault, ClassGroupSingleton, ClassGroupRange,\      ClassGroupDefault, ClassGroupSingleton, ClassGroupRange,\
27      ClassGroupProperties      ClassGroupProperties
28    from Thuban.Model.messages import CLASS_CHANGED
29    
 from Thuban.Model.session import Session  
 from Thuban.Model.layer import Layer  
30  from Thuban.Model.range import Range  from Thuban.Model.range import Range
31    
32    
# Line 251  class TestClassGroupSingleton(unittest.T Line 246  class TestClassGroupSingleton(unittest.T
246          self.assertEqual(group, groupCopy)          self.assertEqual(group, groupCopy)
247    
248    
249  class TestClassification(unittest.TestCase):  class TestClassification(unittest.TestCase, support.SubscriberMixin):
250    
251      """Test cases for Classification"""      """Test cases for Classification"""
252    
253      def setUp(self):      def setUp(self):
254          self.clazz = Classification()          self.clazz = Classification()
255            self.clazz.Subscribe(CLASS_CHANGED, self.subscribe_with_params,
256                                 CLASS_CHANGED)
257            self.clear_messages()
258    
259        def tearDown(self):
260            self.clear_messages()
261            self.clazz.Destroy()
262            del self.clazz
263    
264      def test_defaults(self):      def test_defaults(self):
265          """Test Classification default settings"""          """Test Classification default settings"""
         c = Classification()  
266          self.assertEqual(self.clazz.FindGroup(-1),          self.assertEqual(self.clazz.FindGroup(-1),
267                           self.clazz.GetDefaultGroup())                           self.clazz.GetDefaultGroup())
268          self.assertEqual(self.clazz.GetDefaultLineColor(), Black)          self.assertEqual(self.clazz.GetDefaultLineColor(), Black)
269          self.assertEqual(self.clazz.GetDefaultFill(), Transparent)          self.assertEqual(self.clazz.GetDefaultFill(), Transparent)
270            self.assertEqual(self.clazz.GetDefaultLineWidth(), 1)
271    
272          # The default group is not counted, hence 0 groups          # The default group is not counted, hence 0 groups
273          self.assertEqual(self.clazz.GetNumGroups(), 0)          self.assertEqual(self.clazz.GetNumGroups(), 0)
274    
275            # No messages should have been sent so far
276            self.check_messages([])
277    
278      def test_set_default_properties(self):      def test_set_default_properties(self):
279          """Test Classification.SetDefaultLineColor and SetDefaultFill"""          """Test Classification.SetDefaultLineColor and SetDefaultFill"""
280          c = Classification()          # No messages so far
281            self.check_messages([])
282    
283            # Change the default line color
284          self.clazz.SetDefaultLineColor(red)          self.clazz.SetDefaultLineColor(red)
285          self.assertEqual(self.clazz.GetDefaultLineColor(), red)          self.assertEqual(self.clazz.GetDefaultLineColor(), red)
286          self.assertEqual(self.clazz.GetDefaultFill(), Transparent)          self.assertEqual(self.clazz.GetDefaultFill(), Transparent)
287            self.assertEqual(self.clazz.GetDefaultLineWidth(), 1)
288    
289            self.check_messages([(CLASS_CHANGED,)])
290            self.clear_messages()
291    
292          self.clazz.SetDefaultFill(green)          self.clazz.SetDefaultFill(green)
293          self.assertEqual(self.clazz.GetDefaultFill(), green)          self.assertEqual(self.clazz.GetDefaultFill(), green)
294          self.assertEqual(self.clazz.GetDefaultLineColor(), red)          self.assertEqual(self.clazz.GetDefaultLineColor(), red)
295            self.assertEqual(self.clazz.GetDefaultLineWidth(), 1)
296            self.check_messages([(CLASS_CHANGED,)])
297    
298            self.check_messages([(CLASS_CHANGED,)])
299            self.clear_messages()
300    
301            self.clazz.SetDefaultLineWidth(10)
302            self.assertEqual(self.clazz.GetDefaultFill(), green)
303            self.assertEqual(self.clazz.GetDefaultLineColor(), red)
304            self.assertEqual(self.clazz.GetDefaultLineWidth(), 10)
305            self.check_messages([(CLASS_CHANGED,)])
306    
307        def test_set_default_group(self):
308            """Test Classification.SetDefaultGroup()"""
309            prop = ClassGroupProperties()
310            prop.SetLineColor(blue)
311            prop.SetLineWidth(5)
312            prop.SetFill(red)
313    
314            self.clazz.SetDefaultGroup(ClassGroupDefault(prop))
315            self.assertEqual(self.clazz.GetDefaultFill(), red)
316            self.assertEqual(self.clazz.GetDefaultLineColor(), blue)
317            self.assertEqual(self.clazz.GetDefaultLineWidth(), 5)
318            self.check_messages([(CLASS_CHANGED,)])
319    
320      def test_add_singleton(self):      def test_add_singleton(self):
321          """Test Classification.AppendGroup(ClassGroupSingleton())"""          """Test Classification.AppendGroup(ClassGroupSingleton())"""
         c = Classification()  
322          self.assertEquals(self.clazz.FindGroup(5),          self.assertEquals(self.clazz.FindGroup(5),
323                            self.clazz.GetDefaultGroup())                            self.clazz.GetDefaultGroup())
324    
325          s = ClassGroupSingleton(5)          s = ClassGroupSingleton(5)
326          self.clazz.AppendGroup(s)          self.clazz.AppendGroup(s)
327            self.check_messages([(CLASS_CHANGED,)])
328          self.assertEquals(self.clazz.FindGroup(5), s)          self.assertEquals(self.clazz.FindGroup(5), s)
329          self.assertEquals(self.clazz.FindGroup(0),          self.assertEquals(self.clazz.FindGroup(0),
330                            self.clazz.GetDefaultGroup())                            self.clazz.GetDefaultGroup())
331    
332      def test_add_range(self):      def test_add_range(self):
333          """Test Classification.AppendGroup(ClassGroupRange())"""          """Test Classification.AppendGroup(ClassGroupRange())"""
         c = Classification()  
334          self.assertEquals(self.clazz.FindGroup(0),          self.assertEquals(self.clazz.FindGroup(0),
335                            self.clazz.GetDefaultGroup())                            self.clazz.GetDefaultGroup())
336    
337          r = ClassGroupRange((-10, 10))          r = ClassGroupRange((-10, 10))
338          self.clazz.AppendGroup(r)          self.clazz.AppendGroup(r)
339            self.check_messages([(CLASS_CHANGED,)])
340          self.assertEquals(self.clazz.FindGroup(-11),          self.assertEquals(self.clazz.FindGroup(-11),
341                            self.clazz.GetDefaultGroup())                            self.clazz.GetDefaultGroup())
342          self.assertEquals(self.clazz.FindGroup(-10), r)          self.assertEquals(self.clazz.FindGroup(-10), r)
# Line 311  class TestClassification(unittest.TestCa Line 347  class TestClassification(unittest.TestCa
347    
348      def test_multiple_groups(self):      def test_multiple_groups(self):
349          """Test Classification with multiple groups"""          """Test Classification with multiple groups"""
         c = Classification()  
   
350          # two singletons matching 1 to test whether they're tested in          # two singletons matching 1 to test whether they're tested in
351          # the right order. Use a non default fill on the second to make          # the right order. Use a non default fill on the second to make
352          # it compare unequal to the first.          # it compare unequal to the first.
# Line 329  class TestClassification(unittest.TestCa Line 363  class TestClassification(unittest.TestCa
363          self.clazz.AppendGroup(s2)          self.clazz.AppendGroup(s2)
364          self.clazz.AppendGroup(s1a)          self.clazz.AppendGroup(s1a)
365          self.clazz.AppendGroup(r)          self.clazz.AppendGroup(r)
366            self.check_messages([(CLASS_CHANGED,), (CLASS_CHANGED,),
367                                 (CLASS_CHANGED,), (CLASS_CHANGED,)])
368    
369          self.assertEquals(self.clazz.FindGroup(-11),          self.assertEquals(self.clazz.FindGroup(-11),
370                            self.clazz.GetDefaultGroup())                            self.clazz.GetDefaultGroup())
# Line 340  class TestClassification(unittest.TestCa Line 376  class TestClassification(unittest.TestCa
376          self.assertEquals(self.clazz.FindGroup(10),          self.assertEquals(self.clazz.FindGroup(10),
377                            self.clazz.GetDefaultGroup())                            self.clazz.GetDefaultGroup())
378    
379        def test_insert_group(self):
380            """Test Classification.InsertGroup()"""
381            s1 = ClassGroupSingleton(1)
382            s2 = ClassGroupSingleton(2)
383            r = ClassGroupRange((0, 10))
384    
385            self.clazz.AppendGroup(s1)
386            self.clazz.AppendGroup(r)
387            self.assertEquals(self.clazz.FindGroup(2), r)
388            self.clear_messages()
389    
390            self.clazz.InsertGroup(1, s2)
391            self.assertEquals(self.clazz.FindGroup(2), s2)
392            self.check_messages([(CLASS_CHANGED,)])
393    
394        def test_remove_group(self):
395            """Test Classification.RemoveGroup()"""
396            s1 = ClassGroupSingleton(1)
397            s2 = ClassGroupSingleton(2)
398            r = ClassGroupRange((0, 10))
399    
400            self.clazz.AppendGroup(s1)
401            self.clazz.AppendGroup(s2)
402            self.clazz.AppendGroup(r)
403            self.assertEquals(self.clazz.FindGroup(2), s2)
404            self.clear_messages()
405    
406            self.clazz.RemoveGroup(1)
407            self.assertEquals(self.clazz.FindGroup(2), r)
408            self.check_messages([(CLASS_CHANGED,)])
409    
410        def test_replace_group(self):
411            """Test Classification.ReplaceGroup()"""
412            s1 = ClassGroupSingleton(1)
413            s2 = ClassGroupSingleton(2)
414            r = ClassGroupRange((0, 10))
415    
416            self.clazz.AppendGroup(s2)
417            self.clazz.AppendGroup(r)
418            self.assertEquals(self.clazz.FindGroup(2), s2)
419            self.assertEquals(self.clazz.FindGroup(1), r)
420            self.clear_messages()
421    
422            self.clazz.ReplaceGroup(0, s1)
423            self.assertEquals(self.clazz.FindGroup(2), r)
424            self.assertEquals(self.clazz.FindGroup(1), s1)
425            self.check_messages([(CLASS_CHANGED,)])
426    
427      def test_deepcopy(self):      def test_deepcopy(self):
428          """Test deepcopy(Classification())"""          """Test deepcopy(Classification())"""
429          self.clazz.AppendGroup(ClassGroupSingleton(5))          self.clazz.AppendGroup(ClassGroupSingleton(5))

Legend:
Removed from v.1905  
changed lines
  Added in v.1910

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26