Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
affb9b25
Commit
affb9b25
authored
Nov 09, 2013
by
Serhiy Storchaka
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix Tkinter tests on Tk 8.5 with patchlevel < 8.5.11 (issue #19085).
parent
2915933f
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
31 additions
and
23 deletions
+31
-23
Lib/tkinter/test/support.py
Lib/tkinter/test/support.py
+15
-0
Lib/tkinter/test/test_tkinter/test_widgets.py
Lib/tkinter/test/test_tkinter/test_widgets.py
+8
-3
Lib/tkinter/test/widget_tests.py
Lib/tkinter/test/widget_tests.py
+8
-20
No files found.
Lib/tkinter/test/support.py
View file @
affb9b25
...
...
@@ -86,6 +86,21 @@ def requires_tcl(*version):
return
unittest
.
skipUnless
(
tcl_version
>=
version
,
'requires Tcl version >= '
+
'.'
.
join
(
map
(
str
,
version
)))
_tk_patchlevel
=
None
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
)
return
_tk_patchlevel
units
=
{
'c'
:
72
/
2.54
,
# centimeters
'i'
:
72
,
# inches
...
...
Lib/tkinter/test/test_tkinter/test_widgets.py
View file @
affb9b25
...
...
@@ -3,7 +3,8 @@ import tkinter
import
os
from
test.support
import
requires
from
tkinter.test.support
import
tcl_version
,
requires_tcl
,
widget_eq
from
tkinter.test.support
import
(
tcl_version
,
requires_tcl
,
get_tk_patchlevel
,
widget_eq
)
from
tkinter.test.widget_tests
import
(
add_standard_options
,
noconv
,
pixels_round
,
AbstractWidgetTest
,
StandardOptionsTests
,
IntegerSizeTests
,
PixelSizeTests
)
...
...
@@ -539,7 +540,7 @@ class TextTest(AbstractWidgetTest, unittest.TestCase):
def
test_selectborderwidth
(
self
):
widget
=
self
.
create
()
self
.
checkPixelsParam
(
widget
,
'selectborderwidth'
,
1.3
,
2.6
,
-
2
,
'10p'
,
conv
=
False
,
1.3
,
2.6
,
-
2
,
'10p'
,
conv
=
noconv
,
keep_orig
=
tcl_version
>=
(
8
,
5
))
def
test_spacing1
(
self
):
...
...
@@ -580,7 +581,11 @@ class TextTest(AbstractWidgetTest, unittest.TestCase):
def
test_tabs
(
self
):
widget
=
self
.
create
()
self
.
checkParam
(
widget
,
'tabs'
,
(
10.2
,
20.7
,
'1i'
,
'2i'
))
if
get_tk_patchlevel
()
<
(
8
,
5
,
11
):
self
.
checkParam
(
widget
,
'tabs'
,
(
10.2
,
20.7
,
'1i'
,
'2i'
),
expected
=
(
'10.2'
,
'20.7'
,
'1i'
,
'2i'
))
else
:
self
.
checkParam
(
widget
,
'tabs'
,
(
10.2
,
20.7
,
'1i'
,
'2i'
))
self
.
checkParam
(
widget
,
'tabs'
,
'10.2 20.7 1i 2i'
,
expected
=
(
'10.2'
,
'20.7'
,
'1i'
,
'2i'
))
self
.
checkParam
(
widget
,
'tabs'
,
'2c left 4c 6c center'
,
...
...
Lib/tkinter/test/widget_tests.py
View file @
affb9b25
...
...
@@ -2,28 +2,19 @@
import
tkinter
from
tkinter.ttk
import
setup_master
,
Scale
from
tkinter.test.support
import
(
tcl_version
,
requires_tcl
,
pixels_conv
,
tcl_obj_eq
)
from
tkinter.test.support
import
(
tcl_version
,
requires_tcl
,
get_tk_patchlevel
,
pixels_conv
,
tcl_obj_eq
)
noconv
=
str
if
tcl_version
<
(
8
,
5
)
else
False
noconv
=
False
if
get_tk_patchlevel
()
<
(
8
,
5
,
11
):
noconv
=
str
pixels_round
=
round
if
tcl_version
[:
2
]
==
(
8
,
5
):
if
get_tk_patchlevel
()[:
3
]
==
(
8
,
5
,
11
):
# Issue #19085: Workaround a bug in Tk
# http://core.tcl.tk/tk/info/3497848
_pixels_round
=
None
def
pixels_round
(
x
):
global
_pixels_round
if
_pixels_round
is
None
:
root
=
setup_master
()
patchlevel
=
root
.
call
(
'info'
,
'patchlevel'
)
patchlevel
=
tuple
(
map
(
int
,
patchlevel
.
split
(
'.'
)))
if
patchlevel
<
(
8
,
5
,
12
):
_pixels_round
=
int
else
:
_pixels_round
=
round
return
_pixels_round
(
x
)
pixels_round
=
int
_sentinel
=
object
()
...
...
@@ -406,10 +397,7 @@ class StandardOptionsTests:
def
test_wraplength
(
self
):
widget
=
self
.
create
()
if
tcl_version
<
(
8
,
5
):
self
.
checkPixelsParam
(
widget
,
'wraplength'
,
100
)
else
:
self
.
checkParams
(
widget
,
'wraplength'
,
100
)
self
.
checkPixelsParam
(
widget
,
'wraplength'
,
100
)
def
test_xscrollcommand
(
self
):
widget
=
self
.
create
()
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment