diff options
| author | Anton Samokhvalov <[email protected]> | 2022-02-10 16:45:17 +0300 | 
|---|---|---|
| committer | Daniil Cherednik <[email protected]> | 2022-02-10 16:45:17 +0300 | 
| commit | d3a398281c6fd1d3672036cb2d63f842d2cb28c5 (patch) | |
| tree | dd4bd3ca0f36b817e96812825ffaf10d645803f2 /contrib/tools/cython/Cython/Build/Tests/TestIpythonMagic.py | |
| parent | 72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff) | |
Restoring authorship annotation for Anton Samokhvalov <[email protected]>. Commit 2 of 2.
Diffstat (limited to 'contrib/tools/cython/Cython/Build/Tests/TestIpythonMagic.py')
| -rw-r--r-- | contrib/tools/cython/Cython/Build/Tests/TestIpythonMagic.py | 136 | 
1 files changed, 68 insertions, 68 deletions
| diff --git a/contrib/tools/cython/Cython/Build/Tests/TestIpythonMagic.py b/contrib/tools/cython/Cython/Build/Tests/TestIpythonMagic.py index 1b67a970c69..24213091b26 100644 --- a/contrib/tools/cython/Cython/Build/Tests/TestIpythonMagic.py +++ b/contrib/tools/cython/Cython/Build/Tests/TestIpythonMagic.py @@ -1,17 +1,17 @@ -# -*- coding: utf-8 -*-  -# tag: ipython  -  -"""Tests for the Cython magics extension."""  -  +# -*- coding: utf-8 -*- +# tag: ipython + +"""Tests for the Cython magics extension.""" +  from __future__ import absolute_import -import os  -import sys  +import os +import sys  from contextlib import contextmanager  from Cython.Build import IpythonMagic  from Cython.TestUtils import CythonTest -  -try:  + +try:      import IPython.testing.globalipapp  except ImportError:      # Disable tests and fake helpers for initialisation below. @@ -21,22 +21,22 @@ else:      def skip_if_not_installed(c):          return c -try:  +try:      # disable IPython history thread before it gets started to avoid having to clean it up -    from IPython.core.history import HistoryManager  -    HistoryManager.enabled = False  -except ImportError:  -    pass  -  +    from IPython.core.history import HistoryManager +    HistoryManager.enabled = False +except ImportError: +    pass +  code = u"""\  def f(x): -    return 2*x  +    return 2*x  """ -  +  cython3_code = u"""\  def f(int x):      return 2 / x -  +  def call(x):      return f(*(x,))  """ @@ -48,72 +48,72 @@ main()  """ -if sys.platform == 'win32':  -    # not using IPython's decorators here because they depend on "nose"  -    try:  -        from unittest import skip as skip_win32  -    except ImportError:  -        # poor dev's silent @unittest.skip()  +if sys.platform == 'win32': +    # not using IPython's decorators here because they depend on "nose" +    try: +        from unittest import skip as skip_win32 +    except ImportError: +        # poor dev's silent @unittest.skip()          def skip_win32(dummy):              def _skip_win32(func):                  return None              return _skip_win32 -else:  +else:      def skip_win32(dummy):          def _skip_win32(func):              def wrapper(*args, **kwargs):                  func(*args, **kwargs)              return wrapper          return _skip_win32 -  -  + +  @skip_if_not_installed -class TestIPythonMagic(CythonTest):  -  +class TestIPythonMagic(CythonTest): +      @classmethod      def setUpClass(cls):          CythonTest.setUpClass()          cls._ip = IPython.testing.globalipapp.get_ipython() -    def setUp(self):  -        CythonTest.setUp(self)  +    def setUp(self): +        CythonTest.setUp(self)          self._ip.extension_manager.load_extension('cython') -  -    def test_cython_inline(self):  + +    def test_cython_inline(self):          ip = self._ip -        ip.ex('a=10; b=20')  -        result = ip.run_cell_magic('cython_inline', '', 'return a+b')  -        self.assertEqual(result, 30)  -  +        ip.ex('a=10; b=20') +        result = ip.run_cell_magic('cython_inline', '', 'return a+b') +        self.assertEqual(result, 30) +      @skip_win32('Skip on Windows') -    def test_cython_pyximport(self):  +    def test_cython_pyximport(self):          ip = self._ip -        module_name = '_test_cython_pyximport'  -        ip.run_cell_magic('cython_pyximport', module_name, code)  -        ip.ex('g = f(10)')  -        self.assertEqual(ip.user_ns['g'], 20.0)  -        ip.run_cell_magic('cython_pyximport', module_name, code)  -        ip.ex('h = f(-10)')  -        self.assertEqual(ip.user_ns['h'], -20.0)  -        try:  -            os.remove(module_name + '.pyx')  -        except OSError:  -            pass  -  -    def test_cython(self):  +        module_name = '_test_cython_pyximport' +        ip.run_cell_magic('cython_pyximport', module_name, code) +        ip.ex('g = f(10)') +        self.assertEqual(ip.user_ns['g'], 20.0) +        ip.run_cell_magic('cython_pyximport', module_name, code) +        ip.ex('h = f(-10)') +        self.assertEqual(ip.user_ns['h'], -20.0) +        try: +            os.remove(module_name + '.pyx') +        except OSError: +            pass + +    def test_cython(self):          ip = self._ip -        ip.run_cell_magic('cython', '', code)  -        ip.ex('g = f(10)')  -        self.assertEqual(ip.user_ns['g'], 20.0)  -  -    def test_cython_name(self):  -        # The Cython module named 'mymodule' defines the function f.  +        ip.run_cell_magic('cython', '', code) +        ip.ex('g = f(10)') +        self.assertEqual(ip.user_ns['g'], 20.0) + +    def test_cython_name(self): +        # The Cython module named 'mymodule' defines the function f.          ip = self._ip -        ip.run_cell_magic('cython', '--name=mymodule', code)  -        # This module can now be imported in the interactive namespace.  -        ip.ex('import mymodule; g = mymodule.f(10)')  -        self.assertEqual(ip.user_ns['g'], 20.0)  -  +        ip.run_cell_magic('cython', '--name=mymodule', code) +        # This module can now be imported in the interactive namespace. +        ip.ex('import mymodule; g = mymodule.f(10)') +        self.assertEqual(ip.user_ns['g'], 20.0) +      def test_cython_language_level(self):          # The Cython cell defines the functions f() and call().          ip = self._ip @@ -152,15 +152,15 @@ class TestIPythonMagic(CythonTest):          self.assertEqual(ip.user_ns['h'], 2.0 / 10.0)      @skip_win32('Skip on Windows') -    def test_extlibs(self):  +    def test_extlibs(self):          ip = self._ip          code = u""" -from libc.math cimport sin  -x = sin(0.0)  +from libc.math cimport sin +x = sin(0.0)          """ -        ip.user_ns['x'] = 1  -        ip.run_cell_magic('cython', '-l m', code)  -        self.assertEqual(ip.user_ns['x'], 0)  +        ip.user_ns['x'] = 1 +        ip.run_cell_magic('cython', '-l m', code) +        self.assertEqual(ip.user_ns['x'], 0)      def test_cython_verbose(self): | 
