Skip to content
Snippets Groups Projects
Select Git revision
  • 2841fd315eae0ce80ec35cafa0ce37d358854ddb
  • master default protected
  • develop protected
  • cmake_boost_refactor
  • ubuntu_ci
  • mmtf
  • non-orthogonal-maps
  • no_boost_filesystem
  • data_viewer
  • 2.11.1
  • 2.11.0
  • 2.10.0
  • 2.9.3
  • 2.9.2
  • 2.9.1
  • 2.9.0
  • 2.8.0
  • 2.7.0
  • 2.6.1
  • 2.6.0
  • 2.6.0-rc4
  • 2.6.0-rc3
  • 2.6.0-rc2
  • 2.6.0-rc
  • 2.5.0
  • 2.5.0-rc2
  • 2.5.0-rc
  • 2.4.0
  • 2.4.0-rc2
29 results

testutils.py

Blame
  • Gabriel Studer's avatar
    Studer Gabriel authored
    This commit doesn't make OpenStructure work with Python 3. The goal of this
    commit was to perform an automated port of the Python code and make it compile.
    The performed steps:
    
    - Edited CMakeLists.txt to search for Python with 3.6 as min version 3.6 is the
      Python version shipped by default with Ubuntu 18.04 LTS
    - Add version 3.6 to cmake_support/FindPython.cmake
    - Adapt setup_boost macro in cmake_support/OST.cmake to prefer versioned
      libraries and not first check for boost_python.so. In the example of
      Ubuntu 18.04, libboost_python.so is specific for Python 2 but
      libboost_python3.so is the one we want.
    - apply the following command: 2to3-2.7 -n -w <OST_DIR>
    - adapt base/pymod/wrap_base.cc, gui/pymod/wrap_gui.cc and
      gui/pymod/export_message_widget.cc as PyString functionalities do not exist
      anymore in the Python 3 interpreter (replaced by PyUnicode)
    - adapt gui/src/python_shell/python_interpreter_worker.hh to resolve issue
      discussed in https://stackoverflow.com/questions/23068700/embedding-python3-in-qt-5
      Long story short: Qt does a typedef for "slots" which causes trouble with
      other headers that are pulled in from the Python interpreter
    6e60b71d
    History
    testutils.py 3.40 KiB
    def RunTests():
      '''
      This function behaves as a custom TestLoader for python unittests.
    
      With no system arguments, the default unittest TestRunner is used.
    
      If the first system argument (sys.argv[1]) is set to 'xml', a XMLTestRunner
      is used, which produces a JUnit compatible XML output file. Within the current
      module, each function is identified which is a subclass of unittest.TestCase
      and for each TestCase, a test suite is executed, producing an individual
      output file for each TestCase. The output file has the name,
      'PYTEST-<TestCaseName>.xml'.
    
      Example of a Python testcase:
    
      .. code-block:: python
    
        import unittest
    
        class TestRenumber(unittest.TestCase):
    
          def setUp(self):
            # prepare stuff"
            pass
    
          def testSomeFunction(self):
            # do some asserts
            pass
    
        if __name__ == "__main__":
          from ost import testutils
          testutils.RunTests()
    
      '''
      import unittest
      import sys
      try:
        if len(sys.argv)>1 and sys.argv[1]=='xml':
          import inspect
          import types
          import __main__
          from ost import xmlrunner
          for name, obj in inspect.getmembers(__main__):
            if (isinstance(obj, type) and
                                issubclass(obj, unittest.TestCase)):
              suite = unittest.TestLoader().loadTestsFromTestCase(obj)
              stream = open('PYTEST-%s.xml'%name, 'w')
              xmlrunner.XMLTestRunner(stream).run(suite)
              stream.close()
    
        else:
          unittest.main()
      except Exception as e:
        print(e)
    
    
    def SetDefaultCompoundLib():
      '''
      This function tries to ensure that a default compound library is set.
      When calling scripts with ``ost`` this is not needed, but since unit tests are
      called with ``python`` we need to ensure that it is set. The function is only
      expected to succeed (and return True) if ``COMPOUND_LIB`` was set when
      :ref:`configuring the compilation <cmake-flags>`.
    
      It tries the following:
    
      - get it with :func:`ost.conop.GetDefaultLib`
      - look for ``compounds.chemlib`` in ``$OST_ROOT/share/openstructure``
      - if ``OST_ROOT`` not set in the above, try to guess it based on the path of
        the ``conop`` module
    
      To use this check modify the :func:`RunTests` call to read:
    
      .. code-block:: python
    
        if __name__ == "__main__":
          from ost import testutils
          if testutils.SetDefaultCompoundLib():
            testutils.RunTests()
          else:
            print 'No compound library available. Ignoring test_XXX.py tests.'
    
      :return: True, if a compound library was found and set to be accessed with
               :func:`ost.conop.GetDefaultLib`. False otherwise.
      '''
      import os
      from ost import conop, GetSharedDataPath, SetPrefixPath
      # check if already there
      if conop.GetDefaultLib():
        return True
      else:
        # try to get the shared data path?
        try:
          shared_data_path = GetSharedDataPath()
        except Exception as e:
          SetPrefixPath(os.path.abspath(os.path.join(conop.__path__[0], os.pardir,
                                                     os.pardir, os.pardir,
                                                     os.pardir, os.pardir)))
          shared_data_path = GetSharedDataPath()
        # look for compounds.chemlib in there
        compound_lib_path = os.path.join(shared_data_path, 'compounds.chemlib')
        if os.path.exists(compound_lib_path):
          compound_lib = conop.CompoundLib.Load(compound_lib_path)
          conop.SetDefaultLib(compound_lib)
          return True
        else:
          return False