]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-45280: Add test for empty `NamedTuple` in `test_typing` (GH-28559) (GH-28570)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Sun, 26 Sep 2021 17:09:29 +0000 (10:09 -0700)
committerGitHub <noreply@github.com>
Sun, 26 Sep 2021 17:09:29 +0000 (19:09 +0200)
Co-authored-by: Dong-hee Na <donghee.na92@gmail.com>
(cherry picked from commit f56268a2cd38b3fe2be1e4361d3d8b581e73559b)

Co-authored-by: Nikita Sobolev <mail@sobolevn.me>
Lib/test/test_typing.py
Misc/NEWS.d/next/Tests/2021-09-25-11-05-31.bpo-45280.3MA6lC.rst [new file with mode: 0644]

index df6b3b76d6ddf59b4bc1e66e67312e0371a7594b..1163d6f70aef177de656d8f2d9d4abdc28302286 100644 (file)
@@ -3818,6 +3818,19 @@ class NamedTupleTests(BaseTestCase):
         self.assertEqual(a.typename, 'foo')
         self.assertEqual(a.fields, [('bar', tuple)])
 
+    def test_empty_namedtuple(self):
+        NT = NamedTuple('NT')
+
+        class CNT(NamedTuple):
+            pass  # empty body
+
+        for struct in [NT, CNT]:
+            with self.subTest(struct=struct):
+                self.assertEqual(struct._fields, ())
+                self.assertEqual(struct._field_defaults, {})
+                self.assertEqual(struct.__annotations__, {})
+                self.assertIsInstance(struct(), struct)
+
     def test_namedtuple_errors(self):
         with self.assertRaises(TypeError):
             NamedTuple.__new__()
diff --git a/Misc/NEWS.d/next/Tests/2021-09-25-11-05-31.bpo-45280.3MA6lC.rst b/Misc/NEWS.d/next/Tests/2021-09-25-11-05-31.bpo-45280.3MA6lC.rst
new file mode 100644 (file)
index 0000000..71691f5
--- /dev/null
@@ -0,0 +1 @@
+Add a test case for empty :class:`typing.NamedTuple`.