Commit dcb12f46 authored by Serhiy Storchaka's avatar Serhiy Storchaka

Fixed full Tcl version parsing in tests for pre-final versions.

parent 656ffdb4
import re
import unittest import unittest
import Tkinter as tkinter import Tkinter as tkinter
...@@ -61,14 +62,15 @@ def get_tk_patchlevel(): ...@@ -61,14 +62,15 @@ def get_tk_patchlevel():
global _tk_patchlevel global _tk_patchlevel
if _tk_patchlevel is None: if _tk_patchlevel is None:
tcl = tkinter.Tcl() tcl = tkinter.Tcl()
patchlevel = [] patchlevel = tcl.call('info', 'patchlevel')
for x in tcl.call('info', 'patchlevel').split('.'): m = re.match(r'(\d+)\.(\d+)([ab.])(\d+)$', patchlevel)
try: major, minor, releaselevel, serial = m.groups()
x = int(x, 10) major, minor, serial = int(major), int(minor), int(serial)
except ValueError: releaselevel = {'a': 'alpha', 'b': 'beta', '.': 'final'}[releaselevel]
x = -1 if releaselevel == 'final':
patchlevel.append(x) _tk_patchlevel = major, minor, serial, releaselevel, 0
_tk_patchlevel = tuple(patchlevel) else:
_tk_patchlevel = major, minor, 0, releaselevel, serial
return _tk_patchlevel return _tk_patchlevel
units = { units = {
......
...@@ -22,7 +22,7 @@ class StandardTtkOptionsTests(StandardOptionsTests): ...@@ -22,7 +22,7 @@ class StandardTtkOptionsTests(StandardOptionsTests):
widget = self.create() widget = self.create()
self.assertEqual(widget['class'], '') self.assertEqual(widget['class'], '')
errmsg='attempt to change read-only option' errmsg='attempt to change read-only option'
if get_tk_patchlevel() < (8, 6, 0): # actually this was changed in 8.6b3 if get_tk_patchlevel() < (8, 6, 0, 'beta', 3):
errmsg='Attempt to change read-only option' errmsg='Attempt to change read-only option'
self.checkInvalidParam(widget, 'class', 'Foo', errmsg=errmsg) self.checkInvalidParam(widget, 'class', 'Foo', errmsg=errmsg)
widget2 = self.create(class_='Foo') widget2 = self.create(class_='Foo')
...@@ -553,7 +553,7 @@ class PanedWindowTest(AbstractWidgetTest, unittest.TestCase): ...@@ -553,7 +553,7 @@ class PanedWindowTest(AbstractWidgetTest, unittest.TestCase):
widget = self.create() widget = self.create()
self.assertEqual(str(widget['orient']), 'vertical') self.assertEqual(str(widget['orient']), 'vertical')
errmsg='attempt to change read-only option' errmsg='attempt to change read-only option'
if get_tk_patchlevel() < (8, 6, 0): # actually this was changed in 8.6b3 if get_tk_patchlevel() < (8, 6, 0, 'beta', 3):
errmsg='Attempt to change read-only option' errmsg='Attempt to change read-only option'
self.checkInvalidParam(widget, 'orient', 'horizontal', self.checkInvalidParam(widget, 'orient', 'horizontal',
errmsg=errmsg) errmsg=errmsg)
......
import unittest import unittest
import re
import sys import sys
import os import os
from test import test_support from test import test_support
...@@ -18,27 +19,22 @@ try: ...@@ -18,27 +19,22 @@ try:
except ImportError: except ImportError:
INT_MAX = PY_SSIZE_T_MAX = sys.maxsize INT_MAX = PY_SSIZE_T_MAX = sys.maxsize
tcl_version = _tkinter.TCL_VERSION.split('.') tcl_version = tuple(map(int, _tkinter.TCL_VERSION.split('.')))
try:
for i in range(len(tcl_version)):
tcl_version[i] = int(tcl_version[i])
except ValueError:
pass
tcl_version = tuple(tcl_version)
_tk_patchlevel = None _tk_patchlevel = None
def get_tk_patchlevel(): def get_tk_patchlevel():
global _tk_patchlevel global _tk_patchlevel
if _tk_patchlevel is None: if _tk_patchlevel is None:
tcl = Tcl() tcl = Tcl()
patchlevel = [] patchlevel = tcl.call('info', 'patchlevel')
for x in tcl.call('info', 'patchlevel').split('.'): m = re.match(r'(\d+)\.(\d+)([ab.])(\d+)$', patchlevel)
try: major, minor, releaselevel, serial = m.groups()
x = int(x, 10) major, minor, serial = int(major), int(minor), int(serial)
except ValueError: releaselevel = {'a': 'alpha', 'b': 'beta', '.': 'final'}[releaselevel]
x = -1 if releaselevel == 'final':
patchlevel.append(x) _tk_patchlevel = major, minor, serial, releaselevel, 0
_tk_patchlevel = tuple(patchlevel) else:
_tk_patchlevel = major, minor, 0, releaselevel, serial
return _tk_patchlevel return _tk_patchlevel
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment