summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorEric Smith <eric@trueblade.com>2010-01-27 00:28:29 (GMT)
committerEric Smith <eric@trueblade.com>2010-01-27 00:28:29 (GMT)
commitee931b7253fe332125dad0b7ba1681bdebb0a575 (patch)
tree554ff3645e00dd0d7dcb90992eefd3fcc8d2ab26 /Lib/test
parent92e68af56a2b95627c2220c3e190d7e3c2d4643e (diff)
downloadcpython-ee931b7253fe332125dad0b7ba1681bdebb0a575.zip
cpython-ee931b7253fe332125dad0b7ba1681bdebb0a575.tar.gz
cpython-ee931b7253fe332125dad0b7ba1681bdebb0a575.tar.bz2
Issue #7766: Change sys.getwindowsversion() return value to a named tuple and add the additional members returned in an OSVERSIONINFOEX structure. The new members are service_pack_major, service_pack_minor, suite_mask, and product_type.
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_sys.py18
1 files changed, 17 insertions, 1 deletions
diff --git a/Lib/test/test_sys.py b/Lib/test/test_sys.py
index ccef2c0..d9213f1 100644
--- a/Lib/test/test_sys.py
+++ b/Lib/test/test_sys.py
@@ -2,6 +2,7 @@
import unittest, test.test_support
import sys, cStringIO, os
import struct
+import operator
class SysModuleTest(unittest.TestCase):
@@ -205,13 +206,28 @@ class SysModuleTest(unittest.TestCase):
def test_getwindowsversion(self):
if hasattr(sys, "getwindowsversion"):
v = sys.getwindowsversion()
- self.assertIsInstance(v, tuple)
+ self.assertTrue(isinstance(v[:], tuple))
self.assertEqual(len(v), 5)
self.assertIsInstance(v[0], int)
self.assertIsInstance(v[1], int)
self.assertIsInstance(v[2], int)
self.assertIsInstance(v[3], int)
self.assertIsInstance(v[4], str)
+ self.assertRaises(IndexError, operator.getitem, v, 5)
+ self.assertIsInstance(v.major, int)
+ self.assertIsInstance(v.minor, int)
+ self.assertIsInstance(v.build, int)
+ self.assertIsInstance(v.platform, int)
+ self.assertIsInstance(v.service_pack, str)
+ self.assertEqual(v[0], v.major)
+ self.assertEqual(v[1], v.minor)
+ self.assertEqual(v[2], v.build)
+ self.assertEqual(v[3], v.platform)
+ self.assertEqual(v[4], v.service_pack)
+
+ # This is how platform.py calls it. Make sure tuple
+ # still has 5 elements
+ maj, min, buildno, plat, csd = sys.getwindowsversion()
def test_dlopenflags(self):
if hasattr(sys, "setdlopenflags"):