summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLarry Hastings <larry@hastings.org>2014-01-16 22:15:03 (GMT)
committerLarry Hastings <larry@hastings.org>2014-01-16 22:15:03 (GMT)
commit1abd708681d9425b113366ac3f3d734c2904b250 (patch)
tree1b508617aaac737586b71ab8102367721d707a3f
parent2a727916c598c576507e3a7447fc54cc0e01d4a5 (diff)
downloadcpython-1abd708681d9425b113366ac3f3d734c2904b250.zip
cpython-1abd708681d9425b113366ac3f3d734c2904b250.tar.gz
cpython-1abd708681d9425b113366ac3f3d734c2904b250.tar.bz2
Issue #20226: Added tests for new features and regressions.
-rw-r--r--Lib/test/test_pydoc.py5
-rw-r--r--Tools/clinic/clinic_test.py15
2 files changed, 20 insertions, 0 deletions
diff --git a/Lib/test/test_pydoc.py b/Lib/test/test_pydoc.py
index 1025f5a..43548af 100644
--- a/Lib/test/test_pydoc.py
+++ b/Lib/test/test_pydoc.py
@@ -689,6 +689,11 @@ class TestDescriptions(unittest.TestCase):
self.assertIsNone(pydoc.locate(name))
self.assertRaises(ImportError, pydoc.render_doc, name)
+ # test producing signatures from builtins
+ stat_sig = pydoc.render_doc(os.stat)
+ self.assertEqual(pydoc.plain(stat_sig).splitlines()[2],
+ 'stat(path, *, dir_fd=None, follow_symlinks=True)')
+
@unittest.skipUnless(threading, 'Threading required for this test.')
class PydocServerTest(unittest.TestCase):
diff --git a/Tools/clinic/clinic_test.py b/Tools/clinic/clinic_test.py
index 7de5429..6472527 100644
--- a/Tools/clinic/clinic_test.py
+++ b/Tools/clinic/clinic_test.py
@@ -9,6 +9,7 @@ from clinic import DSLParser
import collections
import inspect
from test import support
+import sys
import unittest
from unittest import TestCase
@@ -277,6 +278,20 @@ class ClinicParserTest(TestCase):
p = function.parameters['follow_symlinks']
self.assertEqual(True, p.default)
+ def test_param_with_continuations(self):
+ function = self.parse_function("module os\nos.access\n follow_symlinks: \\\n bool \\\n =\\\n True")
+ p = function.parameters['follow_symlinks']
+ self.assertEqual(True, p.default)
+
+ def test_param_default_expression(self):
+ function = self.parse_function("module os\nos.access\n follow_symlinks: int(c_default='MAXSIZE') = sys.maxsize")
+ p = function.parameters['follow_symlinks']
+ self.assertEqual(sys.maxsize, p.default)
+ self.assertEqual("MAXSIZE", p.converter.c_default)
+
+ s = self.parse_function_should_fail("module os\nos.access\n follow_symlinks: int = sys.maxsize")
+ self.assertEqual(s, "Error on line 0:\nWhen you specify a named constant ('sys.maxsize') as your default value,\nyou MUST specify a valid c_default.\n")
+
def test_param_no_docstring(self):
function = self.parse_function("""
module os