diff options
| author | E-Paine <63801254+E-Paine@users.noreply.github.com> | 2020-10-08 14:30:13 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-10-08 06:30:13 -0700 | 
| commit | aecf036738a404371303e770f4ce4fd9f7d43de7 (patch) | |
| tree | b6dda4aa3061333248da951d71898504a79aa351 /Lib/tkinter/test/test_tkinter/test_widgets.py | |
| parent | 4a9f82f50d957b6cf3fd207de8b583d9137316b8 (diff) | |
| download | cpython-git-aecf036738a404371303e770f4ce4fd9f7d43de7.tar.gz | |
bpo-41306: Allow scale value to not be rounded (GH-21715)
This fixes the test failure with Tk 6.8.10 which is caused by changes to how Tk rounds the `from`, `to` and `tickinterval` arguments. This PR uses `noconv` if the patchlevel is greater than or equal to 8.6.10 (credit to Serhiy for this idea as it is much simpler than what I previously proposed).
Going into more detail for those who want it, the Tk change was made in [commit 591f68c](https://github.com/tcltk/tk/commit/591f68cb382525b72664c6fecaab87742b6cc87a) and means that the arguments listed above are rounded relative to the value of `from`. However, when rounding the `from` argument ([line 623](https://github.com/tcltk/tk/blob/591f68cb382525b72664c6fecaab87742b6cc87a/generic/tkScale.c#L623)), it is rounded relative to itself (i.e. rounding `0`) and therefore the assigned value for `from` is always what is given (no matter what values of `from` and `resolution`).
Automerge-Triggered-By: @pablogsal
Diffstat (limited to 'Lib/tkinter/test/test_tkinter/test_widgets.py')
| -rw-r--r-- | Lib/tkinter/test/test_tkinter/test_widgets.py | 3 | 
1 files changed, 2 insertions, 1 deletions
| diff --git a/Lib/tkinter/test/test_tkinter/test_widgets.py b/Lib/tkinter/test/test_tkinter/test_widgets.py index 721e81369a..b6f792d6c2 100644 --- a/Lib/tkinter/test/test_tkinter/test_widgets.py +++ b/Lib/tkinter/test/test_tkinter/test_widgets.py @@ -940,7 +940,8 @@ class ScaleTest(AbstractWidgetTest, unittest.TestCase):      def test_from(self):          widget = self.create() -        self.checkFloatParam(widget, 'from', 100, 14.9, 15.1, conv=float_round) +        conv = False if get_tk_patchlevel() >= (8, 6, 10) else float_round +        self.checkFloatParam(widget, 'from', 100, 14.9, 15.1, conv=conv)      def test_label(self):          widget = self.create() | 
