summaryrefslogtreecommitdiffstats
path: root/Lib/lib-tk/test/test_ttk/support.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2015-04-22 05:35:53 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2015-04-22 05:35:53 (GMT)
commitdcb12f46d10b357fd769cd157e2e9786ad7286cc (patch)
treef822dea2a787ee64eb6fbfad39f9382498156347 /Lib/lib-tk/test/test_ttk/support.py
parent656ffdb4de47e462eb4c94377a930511c245fd7b (diff)
downloadcpython-dcb12f46d10b357fd769cd157e2e9786ad7286cc.zip
cpython-dcb12f46d10b357fd769cd157e2e9786ad7286cc.tar.gz
cpython-dcb12f46d10b357fd769cd157e2e9786ad7286cc.tar.bz2
Fixed full Tcl version parsing in tests for pre-final versions.
Diffstat (limited to 'Lib/lib-tk/test/test_ttk/support.py')
-rw-r--r--Lib/lib-tk/test/test_ttk/support.py18
1 files changed, 10 insertions, 8 deletions
diff --git a/Lib/lib-tk/test/test_ttk/support.py b/Lib/lib-tk/test/test_ttk/support.py
index c335f29..91795d9 100644
--- a/Lib/lib-tk/test/test_ttk/support.py
+++ b/Lib/lib-tk/test/test_ttk/support.py
@@ -1,3 +1,4 @@
+import re
import unittest
import Tkinter as tkinter
@@ -61,14 +62,15 @@ def get_tk_patchlevel():
global _tk_patchlevel
if _tk_patchlevel is None:
tcl = tkinter.Tcl()
- patchlevel = []
- for x in tcl.call('info', 'patchlevel').split('.'):
- try:
- x = int(x, 10)
- except ValueError:
- x = -1
- patchlevel.append(x)
- _tk_patchlevel = tuple(patchlevel)
+ patchlevel = tcl.call('info', 'patchlevel')
+ m = re.match(r'(\d+)\.(\d+)([ab.])(\d+)$', patchlevel)
+ major, minor, releaselevel, serial = m.groups()
+ major, minor, serial = int(major), int(minor), int(serial)
+ releaselevel = {'a': 'alpha', 'b': 'beta', '.': 'final'}[releaselevel]
+ if releaselevel == 'final':
+ _tk_patchlevel = major, minor, serial, releaselevel, 0
+ else:
+ _tk_patchlevel = major, minor, 0, releaselevel, serial
return _tk_patchlevel
units = {