Development of an internal social media platform with personalised dashboards for students
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

unittest_pyreverse_diadefs.py 6.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. # Copyright (c) 2008-2010, 2013 LOGILAB S.A. (Paris, FRANCE) <contact@logilab.fr>
  2. # Copyright (c) 2014 Google, Inc.
  3. # Copyright (c) 2014 Arun Persaud <arun@nubati.net>
  4. # Copyright (c) 2015-2017 Claudiu Popa <pcmanticore@gmail.com>
  5. # Copyright (c) 2015 Ionel Cristian Maries <contact@ionelmc.ro>
  6. # Copyright (c) 2016 Derek Gustafson <degustaf@gmail.com>
  7. # Licensed under the GPL: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
  8. # For details: https://github.com/PyCQA/pylint/blob/master/COPYING
  9. """
  10. unit test for the extensions.diadefslib modules
  11. """
  12. import six
  13. import pytest
  14. import astroid
  15. from pylint.pyreverse.inspector import Linker
  16. from pylint.pyreverse.diadefslib import *
  17. from unittest_pyreverse_writer import Config, get_project
  18. def _process_classes(classes):
  19. """extract class names of a list"""
  20. return sorted([(isinstance(c.node, astroid.ClassDef), c.title) for c in classes])
  21. def _process_relations(relations):
  22. """extract relation indices from a relation list"""
  23. result = []
  24. for rel_type, rels in six.iteritems(relations):
  25. for rel in rels:
  26. result.append( (rel_type, rel.from_object.title,
  27. rel.to_object.title) )
  28. result.sort()
  29. return result
  30. @pytest.fixture
  31. def HANDLER():
  32. return DiadefsHandler(Config())
  33. @pytest.fixture(scope='module')
  34. def PROJECT():
  35. return get_project('data')
  36. def test_option_values(HANDLER, PROJECT):
  37. """test for ancestor, associated and module options"""
  38. df_h = DiaDefGenerator(Linker(PROJECT), HANDLER)
  39. cl_config = Config()
  40. cl_config.classes = ['Specialization']
  41. cl_h = DiaDefGenerator(Linker(PROJECT), DiadefsHandler(cl_config) )
  42. assert (0, 0) == df_h._get_levels()
  43. assert False == df_h.module_names
  44. assert (-1, -1) == cl_h._get_levels()
  45. assert True == cl_h.module_names
  46. for hndl in [df_h, cl_h]:
  47. hndl.config.all_ancestors = True
  48. hndl.config.all_associated = True
  49. hndl.config.module_names = True
  50. hndl._set_default_options()
  51. assert (-1, -1) == hndl._get_levels()
  52. assert True == hndl.module_names
  53. handler = DiadefsHandler( Config())
  54. df_h = DiaDefGenerator(Linker(PROJECT), handler)
  55. cl_config = Config()
  56. cl_config.classes = ['Specialization']
  57. cl_h = DiaDefGenerator(Linker(PROJECT), DiadefsHandler(cl_config) )
  58. for hndl in [df_h, cl_h]:
  59. hndl.config.show_ancestors = 2
  60. hndl.config.show_associated = 1
  61. hndl.config.module_names = False
  62. hndl._set_default_options()
  63. assert (2, 1) == hndl._get_levels()
  64. assert False == hndl.module_names
  65. #def test_default_values():
  66. """test efault values for package or class diagrams"""
  67. # TODO : should test difference between default values for package
  68. # or class diagrams
  69. class TestDefaultDiadefGenerator(object):
  70. def test_known_values1(self, HANDLER, PROJECT):
  71. dd = DefaultDiadefGenerator(Linker(PROJECT), HANDLER).visit(PROJECT)
  72. assert len(dd) == 2
  73. keys = [d.TYPE for d in dd]
  74. assert keys == ['package', 'class']
  75. pd = dd[0]
  76. assert pd.title == 'packages No Name'
  77. modules = sorted([(isinstance(m.node, astroid.Module), m.title)
  78. for m in pd.objects])
  79. assert modules == [(True, 'data'),
  80. (True, 'data.clientmodule_test'),
  81. (True, 'data.suppliermodule_test')]
  82. cd = dd[1]
  83. assert cd.title == 'classes No Name'
  84. classes = _process_classes(cd.objects)
  85. assert classes == [(True, 'Ancestor'),
  86. (True, 'DoNothing'),
  87. (True, 'Interface'),
  88. (True, 'Specialization')]
  89. _should_rels = [('association', 'DoNothing', 'Ancestor'),
  90. ('association', 'DoNothing', 'Specialization'),
  91. ('implements', 'Ancestor', 'Interface'),
  92. ('specialization', 'Specialization', 'Ancestor')]
  93. def test_exctract_relations(self, HANDLER, PROJECT):
  94. """test extract_relations between classes"""
  95. cd = DefaultDiadefGenerator(Linker(PROJECT), HANDLER).visit(PROJECT)[1]
  96. cd.extract_relationships()
  97. relations = _process_relations(cd.relationships)
  98. assert relations == self._should_rels
  99. def test_functional_relation_extraction(self):
  100. """functional test of relations extraction;
  101. different classes possibly in different modules"""
  102. # XXX should be catching pyreverse environnement problem but doesn't
  103. # pyreverse doesn't extracts the relations but this test ok
  104. project = get_project('data')
  105. handler = DiadefsHandler(Config())
  106. diadefs = handler.get_diadefs(project, Linker(project, tag=True) )
  107. cd = diadefs[1]
  108. relations = _process_relations(cd.relationships)
  109. assert relations == self._should_rels
  110. def test_known_values2(self, HANDLER):
  111. project = get_project('data.clientmodule_test')
  112. dd = DefaultDiadefGenerator(Linker(project), HANDLER).visit(project)
  113. assert len(dd) == 1
  114. keys = [d.TYPE for d in dd]
  115. assert keys == ['class']
  116. cd = dd[0]
  117. assert cd.title == 'classes No Name'
  118. classes = _process_classes(cd.objects)
  119. assert classes == [(True, 'Ancestor'),
  120. (True, 'Specialization')]
  121. def test_known_values1(HANDLER, PROJECT):
  122. HANDLER.config.classes = ['Specialization']
  123. cdg = ClassDiadefGenerator(Linker(PROJECT), HANDLER)
  124. special = 'data.clientmodule_test.Specialization'
  125. cd = cdg.class_diagram(PROJECT, special)
  126. assert cd.title == special
  127. classes = _process_classes(cd.objects)
  128. assert classes == [(True, 'data.clientmodule_test.Ancestor'),
  129. (True, special),
  130. (True, 'data.suppliermodule_test.DoNothing')]
  131. def test_known_values2(HANDLER, PROJECT):
  132. HANDLER.config.classes = ['Specialization']
  133. HANDLER.config.module_names = False
  134. cd = ClassDiadefGenerator(Linker(PROJECT), HANDLER).class_diagram(PROJECT, 'data.clientmodule_test.Specialization')
  135. assert cd.title == 'data.clientmodule_test.Specialization'
  136. classes = _process_classes(cd.objects)
  137. assert classes == [(True, 'Ancestor'),
  138. (True, 'DoNothing'),
  139. (True, 'Specialization')]