summaryrefslogtreecommitdiff
path: root/lib/python2.7/lib-tk/test
diff options
context:
space:
mode:
Diffstat (limited to 'lib/python2.7/lib-tk/test')
-rw-r--r--lib/python2.7/lib-tk/test/README14
-rw-r--r--lib/python2.7/lib-tk/test/runtktests.py114
-rw-r--r--lib/python2.7/lib-tk/test/test_tkinter/__init__.py0
-rw-r--r--lib/python2.7/lib-tk/test/test_tkinter/test_loadtk.py45
-rw-r--r--lib/python2.7/lib-tk/test/test_tkinter/test_text.py39
-rw-r--r--lib/python2.7/lib-tk/test/test_ttk/__init__.py0
-rw-r--r--lib/python2.7/lib-tk/test/test_ttk/support.py33
-rw-r--r--lib/python2.7/lib-tk/test/test_ttk/test_extensions.py274
-rw-r--r--lib/python2.7/lib-tk/test/test_ttk/test_functions.py458
-rw-r--r--lib/python2.7/lib-tk/test/test_ttk/test_style.py91
-rw-r--r--lib/python2.7/lib-tk/test/test_ttk/test_widgets.py1158
11 files changed, 0 insertions, 2226 deletions
diff --git a/lib/python2.7/lib-tk/test/README b/lib/python2.7/lib-tk/test/README
deleted file mode 100644
index 79cd16c..0000000
--- a/lib/python2.7/lib-tk/test/README
+++ /dev/null
@@ -1,14 +0,0 @@
-Writing new tests
-=================
-
-Precaution
-----------
-
- New tests should always use only one Tk window at once, like all the
- current tests do. This means that you have to destroy the current window
- before creating another one, and clean up after the test. The motivation
- behind this is that some tests may depend on having its window focused
- while it is running to work properly, and it may be hard to force focus
- on your window across platforms (right now only test_traversal at
- test_ttk.test_widgets.NotebookTest depends on this).
-
diff --git a/lib/python2.7/lib-tk/test/runtktests.py b/lib/python2.7/lib-tk/test/runtktests.py
deleted file mode 100644
index 95e1728..0000000
--- a/lib/python2.7/lib-tk/test/runtktests.py
+++ /dev/null
@@ -1,114 +0,0 @@
-"""
-Use this module to get and run all tk tests.
-
-Tkinter tests should live in a package inside the directory where this file
-lives, like test_tkinter.
-Extensions also should live in packages following the same rule as above.
-"""
-
-import os
-import sys
-import unittest
-import importlib
-import test.test_support
-
-this_dir_path = os.path.abspath(os.path.dirname(__file__))
-
-_tk_unavailable = None
-
-def check_tk_availability():
- """Check that Tk is installed and available."""
- global _tk_unavailable
-
- if _tk_unavailable is None:
- _tk_unavailable = False
- if sys.platform == 'darwin':
- # The Aqua Tk implementations on OS X can abort the process if
- # being called in an environment where a window server connection
- # cannot be made, for instance when invoked by a buildbot or ssh
- # process not running under the same user id as the current console
- # user. To avoid that, raise an exception if the window manager
- # connection is not available.
- from ctypes import cdll, c_int, pointer, Structure
- from ctypes.util import find_library
-
- app_services = cdll.LoadLibrary(find_library("ApplicationServices"))
-
- if app_services.CGMainDisplayID() == 0:
- _tk_unavailable = "cannot run without OS X window manager"
- else:
- class ProcessSerialNumber(Structure):
- _fields_ = [("highLongOfPSN", c_int),
- ("lowLongOfPSN", c_int)]
- psn = ProcessSerialNumber()
- psn_p = pointer(psn)
- if ( (app_services.GetCurrentProcess(psn_p) < 0) or
- (app_services.SetFrontProcess(psn_p) < 0) ):
- _tk_unavailable = "cannot run without OS X gui process"
- else: # not OS X
- import Tkinter
- try:
- Tkinter.Button()
- except Tkinter.TclError as msg:
- # assuming tk is not available
- _tk_unavailable = "tk not available: %s" % msg
-
- if _tk_unavailable:
- raise unittest.SkipTest(_tk_unavailable)
- return
-
-def is_package(path):
- for name in os.listdir(path):
- if name in ('__init__.py', '__init__.pyc', '__init.pyo'):
- return True
- return False
-
-def get_tests_modules(basepath=this_dir_path, gui=True, packages=None):
- """This will import and yield modules whose names start with test_
- and are inside packages found in the path starting at basepath.
-
- If packages is specified it should contain package names that want
- their tests colleted.
- """
- py_ext = '.py'
-
- for dirpath, dirnames, filenames in os.walk(basepath):
- for dirname in list(dirnames):
- if dirname[0] == '.':
- dirnames.remove(dirname)
-
- if is_package(dirpath) and filenames:
- pkg_name = dirpath[len(basepath) + len(os.sep):].replace('/', '.')
- if packages and pkg_name not in packages:
- continue
-
- filenames = filter(
- lambda x: x.startswith('test_') and x.endswith(py_ext),
- filenames)
-
- for name in filenames:
- try:
- yield importlib.import_module(
- ".%s" % name[:-len(py_ext)], pkg_name)
- except test.test_support.ResourceDenied:
- if gui:
- raise
-
-def get_tests(text=True, gui=True, packages=None):
- """Yield all the tests in the modules found by get_tests_modules.
-
- If nogui is True, only tests that do not require a GUI will be
- returned."""
- attrs = []
- if text:
- attrs.append('tests_nogui')
- if gui:
- attrs.append('tests_gui')
- for module in get_tests_modules(gui=gui, packages=packages):
- for attr in attrs:
- for test in getattr(module, attr, ()):
- yield test
-
-if __name__ == "__main__":
- test.test_support.use_resources = ['gui']
- test.test_support.run_unittest(*get_tests())
diff --git a/lib/python2.7/lib-tk/test/test_tkinter/__init__.py b/lib/python2.7/lib-tk/test/test_tkinter/__init__.py
deleted file mode 100644
index e69de29..0000000
--- a/lib/python2.7/lib-tk/test/test_tkinter/__init__.py
+++ /dev/null
diff --git a/lib/python2.7/lib-tk/test/test_tkinter/test_loadtk.py b/lib/python2.7/lib-tk/test/test_tkinter/test_loadtk.py
deleted file mode 100644
index 32c640d..0000000
--- a/lib/python2.7/lib-tk/test/test_tkinter/test_loadtk.py
+++ /dev/null
@@ -1,45 +0,0 @@
-import os
-import sys
-import unittest
-from test import test_support
-from Tkinter import Tcl, TclError
-
-test_support.requires('gui')
-
-class TkLoadTest(unittest.TestCase):
-
- @unittest.skipIf('DISPLAY' not in os.environ, 'No $DISPLAY set.')
- def testLoadTk(self):
- tcl = Tcl()
- self.assertRaises(TclError,tcl.winfo_geometry)
- tcl.loadtk()
- self.assertEqual('1x1+0+0', tcl.winfo_geometry())
- tcl.destroy()
-
- def testLoadTkFailure(self):
- old_display = None
- if sys.platform.startswith(('win', 'darwin', 'cygwin')):
- # no failure possible on windows?
-
- # XXX Maybe on tk older than 8.4.13 it would be possible,
- # see tkinter.h.
- return
- with test_support.EnvironmentVarGuard() as env:
- if 'DISPLAY' in os.environ:
- del env['DISPLAY']
- # on some platforms, deleting environment variables
- # doesn't actually carry through to the process level
- # because they don't support unsetenv
- # If that's the case, abort.
- display = os.popen('echo $DISPLAY').read().strip()
- if display:
- return
-
- tcl = Tcl()
- self.assertRaises(TclError, tcl.winfo_geometry)
- self.assertRaises(TclError, tcl.loadtk)
-
-tests_gui = (TkLoadTest, )
-
-if __name__ == "__main__":
- test_support.run_unittest(*tests_gui)
diff --git a/lib/python2.7/lib-tk/test/test_tkinter/test_text.py b/lib/python2.7/lib-tk/test/test_tkinter/test_text.py
deleted file mode 100644
index e6c08be..0000000
--- a/lib/python2.7/lib-tk/test/test_tkinter/test_text.py
+++ /dev/null
@@ -1,39 +0,0 @@
-import unittest
-import Tkinter
-from test.test_support import requires, run_unittest
-from ttk import setup_master
-
-requires('gui')
-
-class TextTest(unittest.TestCase):
-
- def setUp(self):
- self.root = setup_master()
- self.text = Tkinter.Text(self.root)
-
- def tearDown(self):
- self.text.destroy()
-
-
- def test_search(self):
- text = self.text
-
- # pattern and index are obligatory arguments.
- self.assertRaises(Tkinter.TclError, text.search, None, '1.0')
- self.assertRaises(Tkinter.TclError, text.search, 'a', None)
- self.assertRaises(Tkinter.TclError, text.search, None, None)
-
- # Invalid text index.
- self.assertRaises(Tkinter.TclError, text.search, '', 0)
-
- # Check if we are getting the indices as strings -- you are likely
- # to get Tcl_Obj under Tk 8.5 if Tkinter doesn't convert it.
- text.insert('1.0', 'hi-test')
- self.assertEqual(text.search('-test', '1.0', 'end'), '1.2')
- self.assertEqual(text.search('test', '1.0', 'end'), '1.3')
-
-
-tests_gui = (TextTest, )
-
-if __name__ == "__main__":
- run_unittest(*tests_gui)
diff --git a/lib/python2.7/lib-tk/test/test_ttk/__init__.py b/lib/python2.7/lib-tk/test/test_ttk/__init__.py
deleted file mode 100644
index e69de29..0000000
--- a/lib/python2.7/lib-tk/test/test_ttk/__init__.py
+++ /dev/null
diff --git a/lib/python2.7/lib-tk/test/test_ttk/support.py b/lib/python2.7/lib-tk/test/test_ttk/support.py
deleted file mode 100644
index 57e7803..0000000
--- a/lib/python2.7/lib-tk/test/test_ttk/support.py
+++ /dev/null
@@ -1,33 +0,0 @@
-import Tkinter
-
-def get_tk_root():
- try:
- root = Tkinter._default_root
- except AttributeError:
- # it is possible to disable default root in Tkinter, although
- # I haven't seen people doing it (but apparently someone did it
- # here).
- root = None
-
- if root is None:
- # create a new master only if there isn't one already
- root = Tkinter.Tk()
-
- return root
-
-def root_deiconify():
- root = get_tk_root()
- root.deiconify()
-
-def root_withdraw():
- root = get_tk_root()
- root.withdraw()
-
-
-def simulate_mouse_click(widget, x, y):
- """Generate proper events to click at the x, y position (tries to act
- like an X server)."""
- widget.event_generate('<Enter>', x=0, y=0)
- widget.event_generate('<Motion>', x=x, y=y)
- widget.event_generate('<ButtonPress-1>', x=x, y=y)
- widget.event_generate('<ButtonRelease-1>', x=x, y=y)
diff --git a/lib/python2.7/lib-tk/test/test_ttk/test_extensions.py b/lib/python2.7/lib-tk/test/test_ttk/test_extensions.py
deleted file mode 100644
index 6e46cbc..0000000
--- a/lib/python2.7/lib-tk/test/test_ttk/test_extensions.py
+++ /dev/null
@@ -1,274 +0,0 @@
-import sys
-import unittest
-import Tkinter
-import ttk
-from test.test_support import requires, run_unittest
-
-import support
-
-requires('gui')
-
-class LabeledScaleTest(unittest.TestCase):
-
- def setUp(self):
- support.root_deiconify()
-
- def tearDown(self):
- support.root_withdraw()
-
-
- def test_widget_destroy(self):
- # automatically created variable
- x = ttk.LabeledScale()
- var = x._variable._name
- x.destroy()
- self.assertRaises(Tkinter.TclError, x.tk.globalgetvar, var)
-
- # manually created variable
- myvar = Tkinter.DoubleVar()
- name = myvar._name
- x = ttk.LabeledScale(variable=myvar)
- x.destroy()
- self.assertEqual(x.tk.globalgetvar(name), myvar.get())
- del myvar
- self.assertRaises(Tkinter.TclError, x.tk.globalgetvar, name)
-
- # checking that the tracing callback is properly removed
- myvar = Tkinter.IntVar()
- # LabeledScale will start tracing myvar
- x = ttk.LabeledScale(variable=myvar)
- x.destroy()
- # Unless the tracing callback was removed, creating a new
- # LabeledScale with the same var will cause an error now. This
- # happens because the variable will be set to (possibly) a new
- # value which causes the tracing callback to be called and then
- # it tries calling instance attributes not yet defined.
- ttk.LabeledScale(variable=myvar)
- if hasattr(sys, 'last_type'):
- self.assertFalse(sys.last_type == Tkinter.TclError)
-
-
- def test_initialization(self):
- # master passing
- x = ttk.LabeledScale()
- self.assertEqual(x.master, Tkinter._default_root)
- x.destroy()
- master = Tkinter.Frame()
- x = ttk.LabeledScale(master)
- self.assertEqual(x.master, master)
- x.destroy()
-
- # variable initialization/passing
- passed_expected = ((2.5, 2), ('0', 0), (0, 0), (10, 10),
- (-1, -1), (sys.maxint + 1, sys.maxint + 1))
- for pair in passed_expected:
- x = ttk.LabeledScale(from_=pair[0])
- self.assertEqual(x.value, pair[1])
- x.destroy()
- x = ttk.LabeledScale(from_='2.5')
- self.assertRaises(ValueError, x._variable.get)
- x.destroy()
- x = ttk.LabeledScale(from_=None)
- self.assertRaises(ValueError, x._variable.get)
- x.destroy()
- # variable should have its default value set to the from_ value
- myvar = Tkinter.DoubleVar(value=20)
- x = ttk.LabeledScale(variable=myvar)
- self.assertEqual(x.value, 0)
- x.destroy()
- # check that it is really using a DoubleVar
- x = ttk.LabeledScale(variable=myvar, from_=0.5)
- self.assertEqual(x.value, 0.5)
- self.assertEqual(x._variable._name, myvar._name)
- x.destroy()
-
- # widget positionment
- def check_positions(scale, scale_pos, label, label_pos):
- self.assertEqual(scale.pack_info()['side'], scale_pos)
- self.assertEqual(label.place_info()['anchor'], label_pos)
- x = ttk.LabeledScale(compound='top')
- check_positions(x.scale, 'bottom', x.label, 'n')
- x.destroy()
- x = ttk.LabeledScale(compound='bottom')
- check_positions(x.scale, 'top', x.label, 's')
- x.destroy()
- x = ttk.LabeledScale(compound='unknown') # invert default positions
- check_positions(x.scale, 'top', x.label, 's')
- x.destroy()
- x = ttk.LabeledScale() # take default positions
- check_positions(x.scale, 'bottom', x.label, 'n')
- x.destroy()
-
- # extra, and invalid, kwargs
- self.assertRaises(Tkinter.TclError, ttk.LabeledScale, a='b')
-
-
- def test_horizontal_range(self):
- lscale = ttk.LabeledScale(from_=0, to=10)
- lscale.pack()
- lscale.wait_visibility()
- lscale.update()
-
- linfo_1 = lscale.label.place_info()
- prev_xcoord = lscale.scale.coords()[0]
- self.assertEqual(prev_xcoord, int(linfo_1['x']))
- # change range to: from -5 to 5. This should change the x coord of
- # the scale widget, since 0 is at the middle of the new
- # range.
- lscale.scale.configure(from_=-5, to=5)
- # The following update is needed since the test doesn't use mainloop,
- # at the same time this shouldn't affect test outcome
- lscale.update()
- curr_xcoord = lscale.scale.coords()[0]
- self.assertTrue(prev_xcoord != curr_xcoord)
- # the label widget should have been repositioned too
- linfo_2 = lscale.label.place_info()
- self.assertEqual(lscale.label['text'], 0)
- self.assertEqual(curr_xcoord, int(linfo_2['x']))
- # change the range back
- lscale.scale.configure(from_=0, to=10)
- self.assertTrue(prev_xcoord != curr_xcoord)
- self.assertEqual(prev_xcoord, int(linfo_1['x']))
-
- lscale.destroy()
-
-
- def test_variable_change(self):
- x = ttk.LabeledScale()
- x.pack()
- x.wait_visibility()
- x.update()
-
- curr_xcoord = x.scale.coords()[0]
- newval = x.value + 1
- x.value = newval
- # The following update is needed since the test doesn't use mainloop,
- # at the same time this shouldn't affect test outcome
- x.update()
- self.assertEqual(x.label['text'], newval)
- self.assertTrue(x.scale.coords()[0] > curr_xcoord)
- self.assertEqual(x.scale.coords()[0],
- int(x.label.place_info()['x']))
-
- # value outside range
- x.value = x.scale['to'] + 1 # no changes shouldn't happen
- x.update()
- self.assertEqual(x.label['text'], newval)
- self.assertEqual(x.scale.coords()[0],
- int(x.label.place_info()['x']))
-
- x.destroy()
-
-
- def test_resize(self):
- x = ttk.LabeledScale()
- x.pack(expand=True, fill='both')
- x.wait_visibility()
- x.update()
-
- width, height = x.master.winfo_width(), x.master.winfo_height()
- width_new, height_new = width * 2, height * 2
-
- x.value = 3
- x.update()
- x.master.wm_geometry("%dx%d" % (width_new, height_new))
- self.assertEqual(int(x.label.place_info()['x']),
- x.scale.coords()[0])
-
- # Reset geometry
- x.master.wm_geometry("%dx%d" % (width, height))
- x.destroy()
-
-
-class OptionMenuTest(unittest.TestCase):
-
- def setUp(self):
- support.root_deiconify()
- self.textvar = Tkinter.StringVar()
-
- def tearDown(self):
- del self.textvar
- support.root_withdraw()
-
-
- def test_widget_destroy(self):
- var = Tkinter.StringVar()
- optmenu = ttk.OptionMenu(None, var)
- name = var._name
- optmenu.update_idletasks()
- optmenu.destroy()
- self.assertEqual(optmenu.tk.globalgetvar(name), var.get())
- del var
- self.assertRaises(Tkinter.TclError, optmenu.tk.globalgetvar, name)
-
-
- def test_initialization(self):
- self.assertRaises(Tkinter.TclError,
- ttk.OptionMenu, None, self.textvar, invalid='thing')
-
- optmenu = ttk.OptionMenu(None, self.textvar, 'b', 'a', 'b')
- self.assertEqual(optmenu._variable.get(), 'b')
-
- self.assertTrue(optmenu['menu'])
- self.assertTrue(optmenu['textvariable'])
-
- optmenu.destroy()
-
-
- def test_menu(self):
- items = ('a', 'b', 'c')
- default = 'a'
- optmenu = ttk.OptionMenu(None, self.textvar, default, *items)
- found_default = False
- for i in range(len(items)):
- value = optmenu['menu'].entrycget(i, 'value')
- self.assertEqual(value, items[i])
- if value == default:
- found_default = True
- self.assertTrue(found_default)
- optmenu.destroy()
-
- # default shouldn't be in menu if it is not part of values
- default = 'd'
- optmenu = ttk.OptionMenu(None, self.textvar, default, *items)
- curr = None
- i = 0
- while True:
- last, curr = curr, optmenu['menu'].entryconfigure(i, 'value')
- if last == curr:
- # no more menu entries
- break
- self.assertFalse(curr == default)
- i += 1
- self.assertEqual(i, len(items))
-
- # check that variable is updated correctly
- optmenu.pack()
- optmenu.wait_visibility()
- optmenu['menu'].invoke(0)
- self.assertEqual(optmenu._variable.get(), items[0])
-
- # changing to an invalid index shouldn't change the variable
- self.assertRaises(Tkinter.TclError, optmenu['menu'].invoke, -1)
- self.assertEqual(optmenu._variable.get(), items[0])
-
- optmenu.destroy()
-
- # specifying a callback
- success = []
- def cb_test(item):
- self.assertEqual(item, items[1])
- success.append(True)
- optmenu = ttk.OptionMenu(None, self.textvar, 'a', command=cb_test,
- *items)
- optmenu['menu'].invoke(1)
- if not success:
- self.fail("Menu callback not invoked")
-
- optmenu.destroy()
-
-
-tests_gui = (LabeledScaleTest, OptionMenuTest)
-
-if __name__ == "__main__":
- run_unittest(*tests_gui)
diff --git a/lib/python2.7/lib-tk/test/test_ttk/test_functions.py b/lib/python2.7/lib-tk/test/test_ttk/test_functions.py
deleted file mode 100644
index b8f08a5..0000000
--- a/lib/python2.7/lib-tk/test/test_ttk/test_functions.py
+++ /dev/null
@@ -1,458 +0,0 @@
-# -*- encoding: utf-8 -*-
-import sys
-import unittest
-import ttk
-
-class MockTclObj(object):
- typename = 'test'
-
- def __init__(self, val):
- self.val = val
-
- def __str__(self):
- return unicode(self.val)
-
-
-class MockStateSpec(object):
- typename = 'StateSpec'
-
- def __init__(self, *args):
- self.val = args
-
- def __str__(self):
- return ' '.join(self.val)
-
-
-class InternalFunctionsTest(unittest.TestCase):
-
- def test_format_optdict(self):
- def check_against(fmt_opts, result):
- for i in range(0, len(fmt_opts), 2):
- self.assertEqual(result.pop(fmt_opts[i]), fmt_opts[i + 1])
- if result:
- self.fail("result still got elements: %s" % result)
-
- # passing an empty dict should return an empty object (tuple here)
- self.assertFalse(ttk._format_optdict({}))
-
- # check list formatting
- check_against(
- ttk._format_optdict({'fg': 'blue', 'padding': [1, 2, 3, 4]}),
- {'-fg': 'blue', '-padding': '1 2 3 4'})
-
- # check tuple formatting (same as list)
- check_against(
- ttk._format_optdict({'test': (1, 2, '', 0)}),
- {'-test': '1 2 {} 0'})
-
- # check untouched values
- check_against(
- ttk._format_optdict({'test': {'left': 'as is'}}),
- {'-test': {'left': 'as is'}})
-
- # check script formatting
- check_against(
- ttk._format_optdict(
- {'test': [1, -1, '', '2m', 0], 'test2': 3,
- 'test3': '', 'test4': 'abc def',
- 'test5': '"abc"', 'test6': '{}',
- 'test7': '} -spam {'}, script=True),
- {'-test': '{1 -1 {} 2m 0}', '-test2': '3',
- '-test3': '{}', '-test4': '{abc def}',
- '-test5': '{"abc"}', '-test6': r'\{\}',
- '-test7': r'\}\ -spam\ \{'})
-
- opts = {u'αβγ': True, u'á': False}
- orig_opts = opts.copy()
- # check if giving unicode keys is fine
- check_against(ttk._format_optdict(opts), {u'-αβγ': True, u'-á': False})
- # opts should remain unchanged
- self.assertEqual(opts, orig_opts)
-
- # passing values with spaces inside a tuple/list
- check_against(
- ttk._format_optdict(
- {'option': ('one two', 'three')}),
- {'-option': '{one two} three'})
- check_against(
- ttk._format_optdict(
- {'option': ('one\ttwo', 'three')}),
- {'-option': '{one\ttwo} three'})
-
- # passing empty strings inside a tuple/list
- check_against(
- ttk._format_optdict(
- {'option': ('', 'one')}),
- {'-option': '{} one'})
-
- # passing values with braces inside a tuple/list
- check_against(
- ttk._format_optdict(
- {'option': ('one} {two', 'three')}),
- {'-option': r'one\}\ \{two three'})
-
- # passing quoted strings inside a tuple/list
- check_against(
- ttk._format_optdict(
- {'option': ('"one"', 'two')}),
- {'-option': '{"one"} two'})
- check_against(
- ttk._format_optdict(
- {'option': ('{one}', 'two')}),
- {'-option': r'\{one\} two'})
-
- # ignore an option
- amount_opts = len(ttk._format_optdict(opts, ignore=(u'á'))) // 2
- self.assertEqual(amount_opts, len(opts) - 1)
-
- # ignore non-existing options
- amount_opts = len(ttk._format_optdict(opts, ignore=(u'á', 'b'))) // 2
- self.assertEqual(amount_opts, len(opts) - 1)
-
- # ignore every option
- self.assertFalse(ttk._format_optdict(opts, ignore=opts.keys()))
-
-
- def test_format_mapdict(self):
- opts = {'a': [('b', 'c', 'val'), ('d', 'otherval'), ('', 'single')]}
- result = ttk._format_mapdict(opts)
- self.assertEqual(len(result), len(opts.keys()) * 2)
- self.assertEqual(result, ('-a', '{b c} val d otherval {} single'))
- self.assertEqual(ttk._format_mapdict(opts, script=True),
- ('-a', '{{b c} val d otherval {} single}'))
-
- self.assertEqual(ttk._format_mapdict({2: []}), ('-2', ''))
-
- opts = {u'üñíćódè': [(u'á', u'vãl')]}
- result = ttk._format_mapdict(opts)
- self.assertEqual(result, (u'-üñíćódè', u'á vãl'))
-
- # empty states
- valid = {'opt': [('', u'', 'hi')]}
- self.assertEqual(ttk._format_mapdict(valid), ('-opt', '{ } hi'))
-
- # when passing multiple states, they all must be strings
- invalid = {'opt': [(1, 2, 'valid val')]}
- self.assertRaises(TypeError, ttk._format_mapdict, invalid)
- invalid = {'opt': [([1], '2', 'valid val')]}
- self.assertRaises(TypeError, ttk._format_mapdict, invalid)
- # but when passing a single state, it can be anything
- valid = {'opt': [[1, 'value']]}
- self.assertEqual(ttk._format_mapdict(valid), ('-opt', '1 value'))
- # special attention to single states which evalute to False
- for stateval in (None, 0, False, '', set()): # just some samples
- valid = {'opt': [(stateval, 'value')]}
- self.assertEqual(ttk._format_mapdict(valid),
- ('-opt', '{} value'))
-
- # values must be iterable
- opts = {'a': None}
- self.assertRaises(TypeError, ttk._format_mapdict, opts)
-
- # items in the value must have size >= 2
- self.assertRaises(IndexError, ttk._format_mapdict,
- {'a': [('invalid', )]})
-
-
- def test_format_elemcreate(self):
- self.assertTrue(ttk._format_elemcreate(None), (None, ()))
-
- ## Testing type = image
- # image type expects at least an image name, so this should raise
- # IndexError since it tries to access the index 0 of an empty tuple
- self.assertRaises(IndexError, ttk._format_elemcreate, 'image')
-
- # don't format returned values as a tcl script
- # minimum acceptable for image type
- self.assertEqual(ttk._format_elemcreate('image', False, 'test'),
- ("test ", ()))
- # specifying a state spec
- self.assertEqual(ttk._format_elemcreate('image', False, 'test',
- ('', 'a')), ("test {} a", ()))
- # state spec with multiple states
- self.assertEqual(ttk._format_elemcreate('image', False, 'test',
- ('a', 'b', 'c')), ("test {a b} c", ()))
- # state spec and options
- res = ttk._format_elemcreate('image', False, 'test',
- ('a', 'b'), a='x', b='y')
- self.assertEqual(res[0], "test a b")
- self.assertEqual(set(res[1]), {"-a", "x", "-b", "y"})
- # format returned values as a tcl script
- # state spec with multiple states and an option with a multivalue
- self.assertEqual(ttk._format_elemcreate('image', True, 'test',
- ('a', 'b', 'c', 'd'), x=[2, 3]), ("{test {a b c} d}", "-x {2 3}"))
-
- ## Testing type = vsapi
- # vsapi type expects at least a class name and a part_id, so this
- # should raise an ValueError since it tries to get two elements from
- # an empty tuple
- self.assertRaises(ValueError, ttk._format_elemcreate, 'vsapi')
-
- # don't format returned values as a tcl script
- # minimum acceptable for vsapi
- self.assertEqual(ttk._format_elemcreate('vsapi', False, 'a', 'b'),
- ("a b ", ()))
- # now with a state spec with multiple states
- self.assertEqual(ttk._format_elemcreate('vsapi', False, 'a', 'b',
- ('a', 'b', 'c')), ("a b {a b} c", ()))
- # state spec and option
- self.assertEqual(ttk._format_elemcreate('vsapi', False, 'a', 'b',
- ('a', 'b'), opt='x'), ("a b a b", ("-opt", "x")))
- # format returned values as a tcl script
- # state spec with a multivalue and an option
- self.assertEqual(ttk._format_elemcreate('vsapi', True, 'a', 'b',
- ('a', 'b', [1, 2]), opt='x'), ("{a b {a b} {1 2}}", "-opt x"))
-
- # Testing type = from
- # from type expects at least a type name
- self.assertRaises(IndexError, ttk._format_elemcreate, 'from')
-
- self.assertEqual(ttk._format_elemcreate('from', False, 'a'),
- ('a', ()))
- self.assertEqual(ttk._format_elemcreate('from', False, 'a', 'b'),
- ('a', ('b', )))
- self.assertEqual(ttk._format_elemcreate('from', True, 'a', 'b'),
- ('{a}', 'b'))
-
-
- def test_format_layoutlist(self):
- def sample(indent=0, indent_size=2):
- return ttk._format_layoutlist(
- [('a', {'other': [1, 2, 3], 'children':
- [('b', {'children':
- [('c', {'children':
- [('d', {'nice': 'opt'})], 'something': (1, 2)
- })]
- })]
- })], indent=indent, indent_size=indent_size)[0]
-
- def sample_expected(indent=0, indent_size=2):
- spaces = lambda amount=0: ' ' * (amount + indent)
- return (
- "%sa -other {1 2 3} -children {\n"
- "%sb -children {\n"
- "%sc -something {1 2} -children {\n"
- "%sd -nice opt\n"
- "%s}\n"
- "%s}\n"
- "%s}" % (spaces(), spaces(indent_size),
- spaces(2 * indent_size), spaces(3 * indent_size),
- spaces(2 * indent_size), spaces(indent_size), spaces()))
-
- # empty layout
- self.assertEqual(ttk._format_layoutlist([])[0], '')
-
- # smallest (after an empty one) acceptable layout
- smallest = ttk._format_layoutlist([('a', None)], indent=0)
- self.assertEqual(smallest,
- ttk._format_layoutlist([('a', '')], indent=0))
- self.assertEqual(smallest[0], 'a')
-
- # testing indentation levels
- self.assertEqual(sample(), sample_expected())
- for i in range(4):
- self.assertEqual(sample(i), sample_expected(i))
- self.assertEqual(sample(i, i), sample_expected(i, i))
-
- # invalid layout format, different kind of exceptions will be
- # raised
-
- # plain wrong format
- self.assertRaises(ValueError, ttk._format_layoutlist,
- ['bad', 'format'])
- self.assertRaises(TypeError, ttk._format_layoutlist, None)
- # _format_layoutlist always expects the second item (in every item)
- # to act like a dict (except when the value evalutes to False).
- self.assertRaises(AttributeError,
- ttk._format_layoutlist, [('a', 'b')])
- # bad children formatting
- self.assertRaises(ValueError, ttk._format_layoutlist,
- [('name', {'children': {'a': None}})])
-
-
- def test_script_from_settings(self):
- # empty options
- self.assertFalse(ttk._script_from_settings({'name':
- {'configure': None, 'map': None, 'element create': None}}))
-
- # empty layout
- self.assertEqual(
- ttk._script_from_settings({'name': {'layout': None}}),
- "ttk::style layout name {\nnull\n}")
-
- configdict = {u'αβγ': True, u'á': False}
- self.assertTrue(
- ttk._script_from_settings({'name': {'configure': configdict}}))
-
- mapdict = {u'üñíćódè': [(u'á', u'vãl')]}
- self.assertTrue(
- ttk._script_from_settings({'name': {'map': mapdict}}))
-
- # invalid image element
- self.assertRaises(IndexError,
- ttk._script_from_settings, {'name': {'element create': ['image']}})
-
- # minimal valid image
- self.assertTrue(ttk._script_from_settings({'name':
- {'element create': ['image', 'name']}}))
-
- image = {'thing': {'element create':
- ['image', 'name', ('state1', 'state2', 'val')]}}
- self.assertEqual(ttk._script_from_settings(image),
- "ttk::style element create thing image {name {state1 state2} val} ")
-
- image['thing']['element create'].append({'opt': 30})
- self.assertEqual(ttk._script_from_settings(image),
- "ttk::style element create thing image {name {state1 state2} val} "
- "-opt 30")
-
- image['thing']['element create'][-1]['opt'] = [MockTclObj(3),
- MockTclObj('2m')]
- self.assertEqual(ttk._script_from_settings(image),
- "ttk::style element create thing image {name {state1 state2} val} "
- "-opt {3 2m}")
-
-
- def test_dict_from_tcltuple(self):
- fakettuple = ('-a', '{1 2 3}', '-something', 'foo')
-
- self.assertEqual(ttk._dict_from_tcltuple(fakettuple, False),
- {'-a': '{1 2 3}', '-something': 'foo'})
-
- self.assertEqual(ttk._dict_from_tcltuple(fakettuple),
- {'a': '{1 2 3}', 'something': 'foo'})
-
- # passing a tuple with a single item should return an empty dict,
- # since it tries to break the tuple by pairs.
- self.assertFalse(ttk._dict_from_tcltuple(('single', )))
-
- sspec = MockStateSpec('a', 'b')
- self.assertEqual(ttk._dict_from_tcltuple(('-a', (sspec, 'val'))),
- {'a': [('a', 'b', 'val')]})
-
- self.assertEqual(ttk._dict_from_tcltuple((MockTclObj('-padding'),
- [MockTclObj('1'), 2, MockTclObj('3m')])),
- {'padding': [1, 2, '3m']})
-
-
- def test_list_from_statespec(self):
- def test_it(sspec, value, res_value, states):
- self.assertEqual(ttk._list_from_statespec(
- (sspec, value)), [states + (res_value, )])
-
- states_even = tuple('state%d' % i for i in range(6))
- statespec = MockStateSpec(*states_even)
- test_it(statespec, 'val', 'val', states_even)
- test_it(statespec, MockTclObj('val'), 'val', states_even)
-
- states_odd = tuple('state%d' % i for i in range(5))
- statespec = MockStateSpec(*states_odd)
- test_it(statespec, 'val', 'val', states_odd)
-
- test_it(('a', 'b', 'c'), MockTclObj('val'), 'val', ('a', 'b', 'c'))
-
-
- def test_list_from_layouttuple(self):
- # empty layout tuple
- self.assertFalse(ttk._list_from_layouttuple(()))
-
- # shortest layout tuple
- self.assertEqual(ttk._list_from_layouttuple(('name', )),
- [('name', {})])
-
- # not so interesting ltuple
- sample_ltuple = ('name', '-option', 'value')
- self.assertEqual(ttk._list_from_layouttuple(sample_ltuple),
- [('name', {'option': 'value'})])
-
- # empty children
- self.assertEqual(ttk._list_from_layouttuple(
- ('something', '-children', ())),
- [('something', {'children': []})]
- )
-
- # more interesting ltuple
- ltuple = (
- 'name', '-option', 'niceone', '-children', (
- ('otherone', '-children', (
- ('child', )), '-otheropt', 'othervalue'
- )
- )
- )
- self.assertEqual(ttk._list_from_layouttuple(ltuple),
- [('name', {'option': 'niceone', 'children':
- [('otherone', {'otheropt': 'othervalue', 'children':
- [('child', {})]
- })]
- })]
- )
-
- # bad tuples
- self.assertRaises(ValueError, ttk._list_from_layouttuple,
- ('name', 'no_minus'))
- self.assertRaises(ValueError, ttk._list_from_layouttuple,
- ('name', 'no_minus', 'value'))
- self.assertRaises(ValueError, ttk._list_from_layouttuple,
- ('something', '-children')) # no children
- self.assertRaises(ValueError, ttk._list_from_layouttuple,
- ('something', '-children', 'value')) # invalid children
-
-
- def test_val_or_dict(self):
- def func(opt, val=None):
- if val is None:
- return "test val"
- return (opt, val)
-
- options = {'test': None}
- self.assertEqual(ttk._val_or_dict(options, func), "test val")
-
- options = {'test': 3}
- self.assertEqual(ttk._val_or_dict(options, func), options)
-
-
- def test_convert_stringval(self):
- tests = (
- (0, 0), ('09', 9), ('a', 'a'), (u'áÚ', u'áÚ'), ([], '[]'),
- (None, 'None')
- )
- for orig, expected in tests:
- self.assertEqual(ttk._convert_stringval(orig), expected)
-
- if sys.getdefaultencoding() == 'ascii':
- self.assertRaises(UnicodeDecodeError,
- ttk._convert_stringval, 'á')
-
-
-class TclObjsToPyTest(unittest.TestCase):
-
- def test_unicode(self):
- adict = {'opt': u'välúè'}
- self.assertEqual(ttk.tclobjs_to_py(adict), {'opt': u'välúè'})
-
- adict['opt'] = MockTclObj(adict['opt'])
- self.assertEqual(ttk.tclobjs_to_py(adict), {'opt': u'välúè'})
-
- def test_multivalues(self):
- adict = {'opt': [1, 2, 3, 4]}
- self.assertEqual(ttk.tclobjs_to_py(adict), {'opt': [1, 2, 3, 4]})
-
- adict['opt'] = [1, 'xm', 3]
- self.assertEqual(ttk.tclobjs_to_py(adict), {'opt': [1, 'xm', 3]})
-
- adict['opt'] = (MockStateSpec('a', 'b'), u'válũè')
- self.assertEqual(ttk.tclobjs_to_py(adict),
- {'opt': [('a', 'b', u'válũè')]})
-
- self.assertEqual(ttk.tclobjs_to_py({'x': ['y z']}),
- {'x': ['y z']})
-
- def test_nosplit(self):
- self.assertEqual(ttk.tclobjs_to_py({'text': 'some text'}),
- {'text': 'some text'})
-
-tests_nogui = (InternalFunctionsTest, TclObjsToPyTest)
-
-if __name__ == "__main__":
- from test.test_support import run_unittest
- run_unittest(*tests_nogui)
diff --git a/lib/python2.7/lib-tk/test/test_ttk/test_style.py b/lib/python2.7/lib-tk/test/test_ttk/test_style.py
deleted file mode 100644
index 630e075..0000000
--- a/lib/python2.7/lib-tk/test/test_ttk/test_style.py
+++ /dev/null
@@ -1,91 +0,0 @@
-import unittest
-import Tkinter
-import ttk
-from test.test_support import requires, run_unittest
-
-import support
-
-requires('gui')
-
-class StyleTest(unittest.TestCase):
-
- def setUp(self):
- self.style = ttk.Style()
-
-
- def test_configure(self):
- style = self.style
- style.configure('TButton', background='yellow')
- self.assertEqual(style.configure('TButton', 'background'),
- 'yellow')
- self.assertTrue(isinstance(style.configure('TButton'), dict))
-
-
- def test_map(self):
- style = self.style
- style.map('TButton', background=[('active', 'background', 'blue')])
- self.assertEqual(style.map('TButton', 'background'),
- [('active', 'background', 'blue')])
- self.assertTrue(isinstance(style.map('TButton'), dict))
-
-
- def test_lookup(self):
- style = self.style
- style.configure('TButton', background='yellow')
- style.map('TButton', background=[('active', 'background', 'blue')])
-
- self.assertEqual(style.lookup('TButton', 'background'), 'yellow')
- self.assertEqual(style.lookup('TButton', 'background',
- ['active', 'background']), 'blue')
- self.assertEqual(style.lookup('TButton', 'optionnotdefined',
- default='iknewit'), 'iknewit')
-
-
- def test_layout(self):
- style = self.style
- self.assertRaises(Tkinter.TclError, style.layout, 'NotALayout')
- tv_style = style.layout('Treeview')
-
- # "erase" Treeview layout
- style.layout('Treeview', '')
- self.assertEqual(style.layout('Treeview'),
- [('null', {'sticky': 'nswe'})]
- )
-
- # restore layout
- style.layout('Treeview', tv_style)
- self.assertEqual(style.layout('Treeview'), tv_style)
-
- # should return a list
- self.assertTrue(isinstance(style.layout('TButton'), list))
-
- # correct layout, but "option" doesn't exist as option
- self.assertRaises(Tkinter.TclError, style.layout, 'Treeview',
- [('name', {'option': 'inexistent'})])
-
-
- def test_theme_use(self):
- self.assertRaises(Tkinter.TclError, self.style.theme_use,
- 'nonexistingname')
-
- curr_theme = self.style.theme_use()
- new_theme = None
- for theme in self.style.theme_names():
- if theme != curr_theme:
- new_theme = theme
- self.style.theme_use(theme)
- break
- else:
- # just one theme available, can't go on with tests
- return
-
- self.assertFalse(curr_theme == new_theme)
- self.assertFalse(new_theme != self.style.theme_use())
-
- self.style.theme_use(curr_theme)
-
-
-tests_gui = (StyleTest, )
-
-if __name__ == "__main__":
- run_unittest(*tests_gui)
diff --git a/lib/python2.7/lib-tk/test/test_ttk/test_widgets.py b/lib/python2.7/lib-tk/test/test_ttk/test_widgets.py
deleted file mode 100644
index 9d06a75..0000000
--- a/lib/python2.7/lib-tk/test/test_ttk/test_widgets.py
+++ /dev/null
@@ -1,1158 +0,0 @@
-import unittest
-import Tkinter
-import ttk
-from test.test_support import requires, run_unittest
-import sys
-
-import support
-from test_functions import MockTclObj, MockStateSpec
-
-requires('gui')
-
-class WidgetTest(unittest.TestCase):
- """Tests methods available in every ttk widget."""
-
- def setUp(self):
- support.root_deiconify()
- self.widget = ttk.Button(width=0, text="Text")
- self.widget.pack()
- self.widget.wait_visibility()
-
- def tearDown(self):
- self.widget.destroy()
- support.root_withdraw()
-
-
- def test_identify(self):
- self.widget.update_idletasks()
- self.assertEqual(self.widget.identify(
- int(self.widget.winfo_width() / 2),
- int(self.widget.winfo_height() / 2)
- ), "label")
- self.assertEqual(self.widget.identify(-1, -1), "")
-
- self.assertRaises(Tkinter.TclError, self.widget.identify, None, 5)
- self.assertRaises(Tkinter.TclError, self.widget.identify, 5, None)
- self.assertRaises(Tkinter.TclError, self.widget.identify, 5, '')
-
-
- def test_widget_state(self):
- # XXX not sure about the portability of all these tests
- self.assertEqual(self.widget.state(), ())
- self.assertEqual(self.widget.instate(['!disabled']), True)
-
- # changing from !disabled to disabled
- self.assertEqual(self.widget.state(['disabled']), ('!disabled', ))
- # no state change
- self.assertEqual(self.widget.state(['disabled']), ())
- # change back to !disable but also active
- self.assertEqual(self.widget.state(['!disabled', 'active']),
- ('!active', 'disabled'))
- # no state changes, again
- self.assertEqual(self.widget.state(['!disabled', 'active']), ())
- self.assertEqual(self.widget.state(['active', '!disabled']), ())
-
- def test_cb(arg1, **kw):
- return arg1, kw
- self.assertEqual(self.widget.instate(['!disabled'],
- test_cb, "hi", **{"msg": "there"}),
- ('hi', {'msg': 'there'}))
-
- # attempt to set invalid statespec
- currstate = self.widget.state()
- self.assertRaises(Tkinter.TclError, self.widget.instate,
- ['badstate'])
- self.assertRaises(Tkinter.TclError, self.widget.instate,
- ['disabled', 'badstate'])
- # verify that widget didn't change its state
- self.assertEqual(currstate, self.widget.state())
-
- # ensuring that passing None as state doesn't modify current state
- self.widget.state(['active', '!disabled'])
- self.assertEqual(self.widget.state(), ('active', ))
-
-
-class ButtonTest(unittest.TestCase):
-
- def test_invoke(self):
- success = []
- btn = ttk.Button(command=lambda: success.append(1))
- btn.invoke()
- self.assertTrue(success)
-
-
-class CheckbuttonTest(unittest.TestCase):
-
- def test_invoke(self):
- success = []
- def cb_test():
- success.append(1)
- return "cb test called"
-
- cbtn = ttk.Checkbutton(command=cb_test)
- # the variable automatically created by ttk.Checkbutton is actually
- # undefined till we invoke the Checkbutton
- self.assertEqual(cbtn.state(), ('alternate', ))
- self.assertRaises(Tkinter.TclError, cbtn.tk.globalgetvar,
- cbtn['variable'])
-
- res = cbtn.invoke()
- self.assertEqual(res, "cb test called")
- self.assertEqual(cbtn['onvalue'],
- cbtn.tk.globalgetvar(cbtn['variable']))
- self.assertTrue(success)
-
- cbtn['command'] = ''
- res = cbtn.invoke()
- self.assertEqual(res, '')
- self.assertFalse(len(success) > 1)
- self.assertEqual(cbtn['offvalue'],
- cbtn.tk.globalgetvar(cbtn['variable']))
-
-
-class ComboboxTest(unittest.TestCase):
-
- def setUp(self):
- support.root_deiconify()
- self.combo = ttk.Combobox()
-
- def tearDown(self):
- self.combo.destroy()
- support.root_withdraw()
-
- def _show_drop_down_listbox(self):
- width = self.combo.winfo_width()
- self.combo.event_generate('<ButtonPress-1>', x=width - 5, y=5)
- self.combo.event_generate('<ButtonRelease-1>', x=width - 5, y=5)
- self.combo.update_idletasks()
-
-
- def test_virtual_event(self):
- success = []
-
- self.combo['values'] = [1]
- self.combo.bind('<<ComboboxSelected>>',
- lambda evt: success.append(True))
- self.combo.pack()
- self.combo.wait_visibility()
-
- height = self.combo.winfo_height()
- self._show_drop_down_listbox()
- self.combo.update()
- self.combo.event_generate('<Return>')
- self.combo.update()
-
- self.assertTrue(success)
-
-
- def test_postcommand(self):
- success = []
-
- self.combo['postcommand'] = lambda: success.append(True)
- self.combo.pack()
- self.combo.wait_visibility()
-
- self._show_drop_down_listbox()
- self.assertTrue(success)
-
- # testing postcommand removal
- self.combo['postcommand'] = ''
- self._show_drop_down_listbox()
- self.assertEqual(len(success), 1)
-
-
- def test_values(self):
- def check_get_current(getval, currval):
- self.assertEqual(self.combo.get(), getval)
- self.assertEqual(self.combo.current(), currval)
-
- check_get_current('', -1)
-
- self.combo['values'] = ['a', 1, 'c']
-
- self.combo.set('c')
- check_get_current('c', 2)
-
- self.combo.current(0)
- check_get_current('a', 0)
-
- self.combo.set('d')
- check_get_current('d', -1)
-
- # testing values with empty string
- self.combo.set('')
- self.combo['values'] = (1, 2, '', 3)
- check_get_current('', 2)
-
- # testing values with empty string set through configure
- self.combo.configure(values=[1, '', 2])
- self.assertEqual(self.combo['values'], ('1', '', '2'))
-
- # testing values with spaces
- self.combo['values'] = ['a b', 'a\tb', 'a\nb']
- self.assertEqual(self.combo['values'], ('a b', 'a\tb', 'a\nb'))
-
- # testing values with special characters
- self.combo['values'] = [r'a\tb', '"a"', '} {']
- self.assertEqual(self.combo['values'], (r'a\tb', '"a"', '} {'))
-
- # out of range
- self.assertRaises(Tkinter.TclError, self.combo.current,
- len(self.combo['values']))
- # it expects an integer (or something that can be converted to int)
- self.assertRaises(Tkinter.TclError, self.combo.current, '')
-
- # testing creating combobox with empty string in values
- combo2 = ttk.Combobox(values=[1, 2, ''])
- self.assertEqual(combo2['values'], ('1', '2', ''))
- combo2.destroy()
-
-
-class EntryTest(unittest.TestCase):
-
- def setUp(self):
- support.root_deiconify()
- self.entry = ttk.Entry()
-
- def tearDown(self):
- self.entry.destroy()
- support.root_withdraw()
-
-
- def test_bbox(self):
- self.assertEqual(len(self.entry.bbox(0)), 4)
- for item in self.entry.bbox(0):
- self.assertTrue(isinstance(item, int))
-
- self.assertRaises(Tkinter.TclError, self.entry.bbox, 'noindex')
- self.assertRaises(Tkinter.TclError, self.entry.bbox, None)
-
-
- def test_identify(self):
- self.entry.pack()
- self.entry.wait_visibility()
- self.entry.update_idletasks()
-
- self.assertEqual(self.entry.identify(5, 5), "textarea")
- self.assertEqual(self.entry.identify(-1, -1), "")
-
- self.assertRaises(Tkinter.TclError, self.entry.identify, None, 5)
- self.assertRaises(Tkinter.TclError, self.entry.identify, 5, None)
- self.assertRaises(Tkinter.TclError, self.entry.identify, 5, '')
-
-
- def test_validation_options(self):
- success = []
- test_invalid = lambda: success.append(True)
-
- self.entry['validate'] = 'none'
- self.entry['validatecommand'] = lambda: False
-
- self.entry['invalidcommand'] = test_invalid
- self.entry.validate()
- self.assertTrue(success)
-
- self.entry['invalidcommand'] = ''
- self.entry.validate()
- self.assertEqual(len(success), 1)
-
- self.entry['invalidcommand'] = test_invalid
- self.entry['validatecommand'] = lambda: True
- self.entry.validate()
- self.assertEqual(len(success), 1)
-
- self.entry['validatecommand'] = ''
- self.entry.validate()
- self.assertEqual(len(success), 1)
-
- self.entry['validatecommand'] = True
- self.assertRaises(Tkinter.TclError, self.entry.validate)
-
-
- def test_validation(self):
- validation = []
- def validate(to_insert):
- if not 'a' <= to_insert.lower() <= 'z':
- validation.append(False)
- return False
- validation.append(True)
- return True
-
- self.entry['validate'] = 'key'
- self.entry['validatecommand'] = self.entry.register(validate), '%S'
-
- self.entry.insert('end', 1)
- self.entry.insert('end', 'a')
- self.assertEqual(validation, [False, True])
- self.assertEqual(self.entry.get(), 'a')
-
-
- def test_revalidation(self):
- def validate(content):
- for letter in content:
- if not 'a' <= letter.lower() <= 'z':
- return False
- return True
-
- self.entry['validatecommand'] = self.entry.register(validate), '%P'
-
- self.entry.insert('end', 'avocado')
- self.assertEqual(self.entry.validate(), True)
- self.assertEqual(self.entry.state(), ())
-
- self.entry.delete(0, 'end')
- self.assertEqual(self.entry.get(), '')
-
- self.entry.insert('end', 'a1b')
- self.assertEqual(self.entry.validate(), False)
- self.assertEqual(self.entry.state(), ('invalid', ))
-
- self.entry.delete(1)
- self.assertEqual(self.entry.validate(), True)
- self.assertEqual(self.entry.state(), ())
-
-
-class PanedwindowTest(unittest.TestCase):
-
- def setUp(self):
- support.root_deiconify()
- self.paned = ttk.Panedwindow()
-
- def tearDown(self):
- self.paned.destroy()
- support.root_withdraw()
-
-
- def test_add(self):
- # attempt to add a child that is not a direct child of the paned window
- label = ttk.Label(self.paned)
- child = ttk.Label(label)
- self.assertRaises(Tkinter.TclError, self.paned.add, child)
- label.destroy()
- child.destroy()
- # another attempt
- label = ttk.Label()
- child = ttk.Label(label)
- self.assertRaises(Tkinter.TclError, self.paned.add, child)
- child.destroy()
- label.destroy()
-
- good_child = ttk.Label()
- self.paned.add(good_child)
- # re-adding a child is not accepted
- self.assertRaises(Tkinter.TclError, self.paned.add, good_child)
-
- other_child = ttk.Label(self.paned)
- self.paned.add(other_child)
- self.assertEqual(self.paned.pane(0), self.paned.pane(1))
- self.assertRaises(Tkinter.TclError, self.paned.pane, 2)
- good_child.destroy()
- other_child.destroy()
- self.assertRaises(Tkinter.TclError, self.paned.pane, 0)
-
-
- def test_forget(self):
- self.assertRaises(Tkinter.TclError, self.paned.forget, None)
- self.assertRaises(Tkinter.TclError, self.paned.forget, 0)
-
- self.paned.add(ttk.Label())
- self.paned.forget(0)
- self.assertRaises(Tkinter.TclError, self.paned.forget, 0)
-
-
- def test_insert(self):
- self.assertRaises(Tkinter.TclError, self.paned.insert, None, 0)
- self.assertRaises(Tkinter.TclError, self.paned.insert, 0, None)
- self.assertRaises(Tkinter.TclError, self.paned.insert, 0, 0)
-
- child = ttk.Label()
- child2 = ttk.Label()
- child3 = ttk.Label()
-
- self.assertRaises(Tkinter.TclError, self.paned.insert, 0, child)
-
- self.paned.insert('end', child2)
- self.paned.insert(0, child)
- self.assertEqual(self.paned.panes(), (str(child), str(child2)))
-
- self.paned.insert(0, child2)
- self.assertEqual(self.paned.panes(), (str(child2), str(child)))
-
- self.paned.insert('end', child3)
- self.assertEqual(self.paned.panes(),
- (str(child2), str(child), str(child3)))
-
- # reinserting a child should move it to its current position
- panes = self.paned.panes()
- self.paned.insert('end', child3)
- self.assertEqual(panes, self.paned.panes())
-
- # moving child3 to child2 position should result in child2 ending up
- # in previous child position and child ending up in previous child3
- # position
- self.paned.insert(child2, child3)
- self.assertEqual(self.paned.panes(),
- (str(child3), str(child2), str(child)))
-
-
- def test_pane(self):
- self.assertRaises(Tkinter.TclError, self.paned.pane, 0)
-
- child = ttk.Label()
- self.paned.add(child)
- self.assertTrue(isinstance(self.paned.pane(0), dict))
- self.assertEqual(self.paned.pane(0, weight=None), 0)
- # newer form for querying a single option
- self.assertEqual(self.paned.pane(0, 'weight'), 0)
- self.assertEqual(self.paned.pane(0), self.paned.pane(str(child)))
-
- self.assertRaises(Tkinter.TclError, self.paned.pane, 0,
- badoption='somevalue')
-
-
- def test_sashpos(self):
- self.assertRaises(Tkinter.TclError, self.paned.sashpos, None)
- self.assertRaises(Tkinter.TclError, self.paned.sashpos, '')
- self.assertRaises(Tkinter.TclError, self.paned.sashpos, 0)
-
- child = ttk.Label(self.paned, text='a')
- self.paned.add(child, weight=1)
- self.assertRaises(Tkinter.TclError, self.paned.sashpos, 0)
- child2 = ttk.Label(self.paned, text='b')
- self.paned.add(child2)
- self.assertRaises(Tkinter.TclError, self.paned.sashpos, 1)
-
- self.paned.pack(expand=True, fill='both')
- self.paned.wait_visibility()
-
- curr_pos = self.paned.sashpos(0)
- self.paned.sashpos(0, 1000)
- self.assertTrue(curr_pos != self.paned.sashpos(0))
- self.assertTrue(isinstance(self.paned.sashpos(0), int))
-
-
-class RadiobuttonTest(unittest.TestCase):
-
- def test_invoke(self):
- success = []
- def cb_test():
- success.append(1)
- return "cb test called"
-
- myvar = Tkinter.IntVar()
- cbtn = ttk.Radiobutton(command=cb_test, variable=myvar, value=0)
- cbtn2 = ttk.Radiobutton(command=cb_test, variable=myvar, value=1)
-
- res = cbtn.invoke()
- self.assertEqual(res, "cb test called")
- self.assertEqual(cbtn['value'], myvar.get())
- self.assertEqual(myvar.get(),
- cbtn.tk.globalgetvar(cbtn['variable']))
- self.assertTrue(success)
-
- cbtn2['command'] = ''
- res = cbtn2.invoke()
- self.assertEqual(res, '')
- self.assertFalse(len(success) > 1)
- self.assertEqual(cbtn2['value'], myvar.get())
- self.assertEqual(myvar.get(),
- cbtn.tk.globalgetvar(cbtn['variable']))
-
- self.assertEqual(str(cbtn['variable']), str(cbtn2['variable']))
-
-
-
-class ScaleTest(unittest.TestCase):
-
- def setUp(self):
- support.root_deiconify()
- self.scale = ttk.Scale()
- self.scale.pack()
- self.scale.update()
-
- def tearDown(self):
- self.scale.destroy()
- support.root_withdraw()
-
-
- def test_custom_event(self):
- failure = [1, 1, 1] # will need to be empty
-
- funcid = self.scale.bind('<<RangeChanged>>', lambda evt: failure.pop())
-
- self.scale['from'] = 10
- self.scale['from_'] = 10
- self.scale['to'] = 3
-
- self.assertFalse(failure)
-
- failure = [1, 1, 1]
- self.scale.configure(from_=2, to=5)
- self.scale.configure(from_=0, to=-2)
- self.scale.configure(to=10)
-
- self.assertFalse(failure)
-
-
- def test_get(self):
- scale_width = self.scale.winfo_width()
- self.assertEqual(self.scale.get(scale_width, 0), self.scale['to'])
-
- self.assertEqual(self.scale.get(0, 0), self.scale['from'])
- self.assertEqual(self.scale.get(), self.scale['value'])
- self.scale['value'] = 30
- self.assertEqual(self.scale.get(), self.scale['value'])
-
- self.assertRaises(Tkinter.TclError, self.scale.get, '', 0)
- self.assertRaises(Tkinter.TclError, self.scale.get, 0, '')
-
-
- def test_set(self):
- # set restricts the max/min values according to the current range
- max = self.scale['to']
- new_max = max + 10
- self.scale.set(new_max)
- self.assertEqual(self.scale.get(), max)
- min = self.scale['from']
- self.scale.set(min - 1)
- self.assertEqual(self.scale.get(), min)
-
- # changing directly the variable doesn't impose this limitation tho
- var = Tkinter.DoubleVar()
- self.scale['variable'] = var
- var.set(max + 5)
- self.assertEqual(self.scale.get(), var.get())
- self.assertEqual(self.scale.get(), max + 5)
- del var
-
- # the same happens with the value option
- self.scale['value'] = max + 10
- self.assertEqual(self.scale.get(), max + 10)
- self.assertEqual(self.scale.get(), self.scale['value'])
-
- # nevertheless, note that the max/min values we can get specifying
- # x, y coords are the ones according to the current range
- self.assertEqual(self.scale.get(0, 0), min)
- self.assertEqual(self.scale.get(self.scale.winfo_width(), 0), max)
-
- self.assertRaises(Tkinter.TclError, self.scale.set, None)
-
-
-class NotebookTest(unittest.TestCase):
-
- def setUp(self):
- support.root_deiconify()
- self.nb = ttk.Notebook(padding=0)
- self.child1 = ttk.Label()
- self.child2 = ttk.Label()
- self.nb.add(self.child1, text='a')
- self.nb.add(self.child2, text='b')
-
- def tearDown(self):
- self.child1.destroy()
- self.child2.destroy()
- self.nb.destroy()
- support.root_withdraw()
-
-
- def test_tab_identifiers(self):
- self.nb.forget(0)
- self.nb.hide(self.child2)
- self.assertRaises(Tkinter.TclError, self.nb.tab, self.child1)
- self.assertEqual(self.nb.index('end'), 1)
- self.nb.add(self.child2)
- self.assertEqual(self.nb.index('end'), 1)
- self.nb.select(self.child2)
-
- self.assertTrue(self.nb.tab('current'))
- self.nb.add(self.child1, text='a')
-
- self.nb.pack()
- self.nb.wait_visibility()
- if sys.platform == 'darwin':
- tb_idx = "@20,5"
- else:
- tb_idx = "@5,5"
- self.assertEqual(self.nb.tab(tb_idx), self.nb.tab('current'))
-
- for i in range(5, 100, 5):
- try:
- if self.nb.tab('@%d, 5' % i, text=None) == 'a':
- break
- except Tkinter.TclError:
- pass
-
- else:
- self.fail("Tab with text 'a' not found")
-
-
- def test_add_and_hidden(self):
- self.assertRaises(Tkinter.TclError, self.nb.hide, -1)
- self.assertRaises(Tkinter.TclError, self.nb.hide, 'hi')
- self.assertRaises(Tkinter.TclError, self.nb.hide, None)
- self.assertRaises(Tkinter.TclError, self.nb.add, None)
- self.assertRaises(Tkinter.TclError, self.nb.add, ttk.Label(),
- unknown='option')
-
- tabs = self.nb.tabs()
- self.nb.hide(self.child1)
- self.nb.add(self.child1)
- self.assertEqual(self.nb.tabs(), tabs)
-
- child = ttk.Label()
- self.nb.add(child, text='c')
- tabs = self.nb.tabs()
-
- curr = self.nb.index('current')
- # verify that the tab gets readded at its previous position
- child2_index = self.nb.index(self.child2)
- self.nb.hide(self.child2)
- self.nb.add(self.child2)
- self.assertEqual(self.nb.tabs(), tabs)
- self.assertEqual(self.nb.index(self.child2), child2_index)
- self.assertTrue(str(self.child2) == self.nb.tabs()[child2_index])
- # but the tab next to it (not hidden) is the one selected now
- self.assertEqual(self.nb.index('current'), curr + 1)
-
-
- def test_forget(self):
- self.assertRaises(Tkinter.TclError, self.nb.forget, -1)
- self.assertRaises(Tkinter.TclError, self.nb.forget, 'hi')
- self.assertRaises(Tkinter.TclError, self.nb.forget, None)
-
- tabs = self.nb.tabs()
- child1_index = self.nb.index(self.child1)
- self.nb.forget(self.child1)
- self.assertFalse(str(self.child1) in self.nb.tabs())
- self.assertEqual(len(tabs) - 1, len(self.nb.tabs()))
-
- self.nb.add(self.child1)
- self.assertEqual(self.nb.index(self.child1), 1)
- self.assertFalse(child1_index == self.nb.index(self.child1))
-
-
- def test_index(self):
- self.assertRaises(Tkinter.TclError, self.nb.index, -1)
- self.assertRaises(Tkinter.TclError, self.nb.index, None)
-
- self.assertTrue(isinstance(self.nb.index('end'), int))
- self.assertEqual(self.nb.index(self.child1), 0)
- self.assertEqual(self.nb.index(self.child2), 1)
- self.assertEqual(self.nb.index('end'), 2)
-
-
- def test_insert(self):
- # moving tabs
- tabs = self.nb.tabs()
- self.nb.insert(1, tabs[0])
- self.assertEqual(self.nb.tabs(), (tabs[1], tabs[0]))
- self.nb.insert(self.child1, self.child2)
- self.assertEqual(self.nb.tabs(), tabs)
- self.nb.insert('end', self.child1)
- self.assertEqual(self.nb.tabs(), (tabs[1], tabs[0]))
- self.nb.insert('end', 0)
- self.assertEqual(self.nb.tabs(), tabs)
- # bad moves
- self.assertRaises(Tkinter.TclError, self.nb.insert, 2, tabs[0])
- self.assertRaises(Tkinter.TclError, self.nb.insert, -1, tabs[0])
-
- # new tab
- child3 = ttk.Label()
- self.nb.insert(1, child3)
- self.assertEqual(self.nb.tabs(), (tabs[0], str(child3), tabs[1]))
- self.nb.forget(child3)
- self.assertEqual(self.nb.tabs(), tabs)
- self.nb.insert(self.child1, child3)
- self.assertEqual(self.nb.tabs(), (str(child3), ) + tabs)
- self.nb.forget(child3)
- self.assertRaises(Tkinter.TclError, self.nb.insert, 2, child3)
- self.assertRaises(Tkinter.TclError, self.nb.insert, -1, child3)
-
- # bad inserts
- self.assertRaises(Tkinter.TclError, self.nb.insert, 'end', None)
- self.assertRaises(Tkinter.TclError, self.nb.insert, None, 0)
- self.assertRaises(Tkinter.TclError, self.nb.insert, None, None)
-
-
- def test_select(self):
- self.nb.pack()
- self.nb.wait_visibility()
-
- success = []
- tab_changed = []
-
- self.child1.bind('<Unmap>', lambda evt: success.append(True))
- self.nb.bind('<<NotebookTabChanged>>',
- lambda evt: tab_changed.append(True))
-
- self.assertEqual(self.nb.select(), str(self.child1))
- self.nb.select(self.child2)
- self.assertTrue(success)
- self.assertEqual(self.nb.select(), str(self.child2))
-
- self.nb.update()
- self.assertTrue(tab_changed)
-
-
- def test_tab(self):
- self.assertRaises(Tkinter.TclError, self.nb.tab, -1)
- self.assertRaises(Tkinter.TclError, self.nb.tab, 'notab')
- self.assertRaises(Tkinter.TclError, self.nb.tab, None)
-
- self.assertTrue(isinstance(self.nb.tab(self.child1), dict))
- self.assertEqual(self.nb.tab(self.child1, text=None), 'a')
- # newer form for querying a single option
- self.assertEqual(self.nb.tab(self.child1, 'text'), 'a')
- self.nb.tab(self.child1, text='abc')
- self.assertEqual(self.nb.tab(self.child1, text=None), 'abc')
- self.assertEqual(self.nb.tab(self.child1, 'text'), 'abc')
-
-
- def test_tabs(self):
- self.assertEqual(len(self.nb.tabs()), 2)
-
- self.nb.forget(self.child1)
- self.nb.forget(self.child2)
-
- self.assertEqual(self.nb.tabs(), ())
-
-
- def test_traversal(self):
- self.nb.pack()
- self.nb.wait_visibility()
-
- self.nb.select(0)
-
- support.simulate_mouse_click(self.nb, 5, 5)
- self.nb.focus_force()
- self.nb.event_generate('<Control-Tab>')
- self.assertEqual(self.nb.select(), str(self.child2))
- self.nb.focus_force()
- self.nb.event_generate('<Shift-Control-Tab>')
- self.assertEqual(self.nb.select(), str(self.child1))
- self.nb.focus_force()
- self.nb.event_generate('<Shift-Control-Tab>')
- self.assertEqual(self.nb.select(), str(self.child2))
-
- self.nb.tab(self.child1, text='a', underline=0)
- self.nb.enable_traversal()
- self.nb.focus_force()
- support.simulate_mouse_click(self.nb, 5, 5)
- if sys.platform == 'darwin':
- self.nb.event_generate('<Option-a>')
- else:
- self.nb.event_generate('<Alt-a>')
- self.assertEqual(self.nb.select(), str(self.child1))
-
-
-class TreeviewTest(unittest.TestCase):
-
- def setUp(self):
- support.root_deiconify()
- self.tv = ttk.Treeview(padding=0)
-
- def tearDown(self):
- self.tv.destroy()
- support.root_withdraw()
-
-
- def test_bbox(self):
- self.tv.pack()
- self.assertEqual(self.tv.bbox(''), '')
- self.tv.wait_visibility()
- self.tv.update()
-
- item_id = self.tv.insert('', 'end')
- children = self.tv.get_children()
- self.assertTrue(children)
-
- bbox = self.tv.bbox(children[0])
- self.assertEqual(len(bbox), 4)
- self.assertTrue(isinstance(bbox, tuple))
- for item in bbox:
- if not isinstance(item, int):
- self.fail("Invalid bounding box: %s" % bbox)
- break
-
- # compare width in bboxes
- self.tv['columns'] = ['test']
- self.tv.column('test', width=50)
- bbox_column0 = self.tv.bbox(children[0], 0)
- root_width = self.tv.column('#0', width=None)
- self.assertEqual(bbox_column0[0], bbox[0] + root_width)
-
- # verify that bbox of a closed item is the empty string
- child1 = self.tv.insert(item_id, 'end')
- self.assertEqual(self.tv.bbox(child1), '')
-
-
- def test_children(self):
- # no children yet, should get an empty tuple
- self.assertEqual(self.tv.get_children(), ())
-
- item_id = self.tv.insert('', 'end')
- self.assertTrue(isinstance(self.tv.get_children(), tuple))
- self.assertEqual(self.tv.get_children()[0], item_id)
-
- # add item_id and child3 as children of child2
- child2 = self.tv.insert('', 'end')
- child3 = self.tv.insert('', 'end')
- self.tv.set_children(child2, item_id, child3)
- self.assertEqual(self.tv.get_children(child2), (item_id, child3))
-
- # child3 has child2 as parent, thus trying to set child2 as a children
- # of child3 should result in an error
- self.assertRaises(Tkinter.TclError,
- self.tv.set_children, child3, child2)
-
- # remove child2 children
- self.tv.set_children(child2)
- self.assertEqual(self.tv.get_children(child2), ())
-
- # remove root's children
- self.tv.set_children('')
- self.assertEqual(self.tv.get_children(), ())
-
-
- def test_column(self):
- # return a dict with all options/values
- self.assertTrue(isinstance(self.tv.column('#0'), dict))
- # return a single value of the given option
- self.assertTrue(isinstance(self.tv.column('#0', width=None), int))
- # set a new value for an option
- self.tv.column('#0', width=10)
- # testing new way to get option value
- self.assertEqual(self.tv.column('#0', 'width'), 10)
- self.assertEqual(self.tv.column('#0', width=None), 10)
- # check read-only option
- self.assertRaises(Tkinter.TclError, self.tv.column, '#0', id='X')
-
- self.assertRaises(Tkinter.TclError, self.tv.column, 'invalid')
- invalid_kws = [
- {'unknown_option': 'some value'}, {'stretch': 'wrong'},
- {'anchor': 'wrong'}, {'width': 'wrong'}, {'minwidth': 'wrong'}
- ]
- for kw in invalid_kws:
- self.assertRaises(Tkinter.TclError, self.tv.column, '#0',
- **kw)
-
-
- def test_delete(self):
- self.assertRaises(Tkinter.TclError, self.tv.delete, '#0')
-
- item_id = self.tv.insert('', 'end')
- item2 = self.tv.insert(item_id, 'end')
- self.assertEqual(self.tv.get_children(), (item_id, ))
- self.assertEqual(self.tv.get_children(item_id), (item2, ))
-
- self.tv.delete(item_id)
- self.assertFalse(self.tv.get_children())
-
- # reattach should fail
- self.assertRaises(Tkinter.TclError,
- self.tv.reattach, item_id, '', 'end')
-
- # test multiple item delete
- item1 = self.tv.insert('', 'end')
- item2 = self.tv.insert('', 'end')
- self.assertEqual(self.tv.get_children(), (item1, item2))
-
- self.tv.delete(item1, item2)
- self.assertFalse(self.tv.get_children())
-
-
- def test_detach_reattach(self):
- item_id = self.tv.insert('', 'end')
- item2 = self.tv.insert(item_id, 'end')
-
- # calling detach without items is valid, although it does nothing
- prev = self.tv.get_children()
- self.tv.detach() # this should do nothing
- self.assertEqual(prev, self.tv.get_children())
-
- self.assertEqual(self.tv.get_children(), (item_id, ))
- self.assertEqual(self.tv.get_children(item_id), (item2, ))
-
- # detach item with children
- self.tv.detach(item_id)
- self.assertFalse(self.tv.get_children())
-
- # reattach item with children
- self.tv.reattach(item_id, '', 'end')
- self.assertEqual(self.tv.get_children(), (item_id, ))
- self.assertEqual(self.tv.get_children(item_id), (item2, ))
-
- # move a children to the root
- self.tv.move(item2, '', 'end')
- self.assertEqual(self.tv.get_children(), (item_id, item2))
- self.assertEqual(self.tv.get_children(item_id), ())
-
- # bad values
- self.assertRaises(Tkinter.TclError,
- self.tv.reattach, 'nonexistent', '', 'end')
- self.assertRaises(Tkinter.TclError,
- self.tv.detach, 'nonexistent')
- self.assertRaises(Tkinter.TclError,
- self.tv.reattach, item2, 'otherparent', 'end')
- self.assertRaises(Tkinter.TclError,
- self.tv.reattach, item2, '', 'invalid')
-
- # multiple detach
- self.tv.detach(item_id, item2)
- self.assertEqual(self.tv.get_children(), ())
- self.assertEqual(self.tv.get_children(item_id), ())
-
-
- def test_exists(self):
- self.assertEqual(self.tv.exists('something'), False)
- self.assertEqual(self.tv.exists(''), True)
- self.assertEqual(self.tv.exists({}), False)
-
- # the following will make a tk.call equivalent to
- # tk.call(treeview, "exists") which should result in an error
- # in the tcl interpreter since tk requires an item.
- self.assertRaises(Tkinter.TclError, self.tv.exists, None)
-
-
- def test_focus(self):
- # nothing is focused right now
- self.assertEqual(self.tv.focus(), '')
-
- item1 = self.tv.insert('', 'end')
- self.tv.focus(item1)
- self.assertEqual(self.tv.focus(), item1)
-
- self.tv.delete(item1)
- self.assertEqual(self.tv.focus(), '')
-
- # try focusing inexistent item
- self.assertRaises(Tkinter.TclError, self.tv.focus, 'hi')
-
-
- def test_heading(self):
- # check a dict is returned
- self.assertTrue(isinstance(self.tv.heading('#0'), dict))
-
- # check a value is returned
- self.tv.heading('#0', text='hi')
- self.assertEqual(self.tv.heading('#0', 'text'), 'hi')
- self.assertEqual(self.tv.heading('#0', text=None), 'hi')
-
- # invalid option
- self.assertRaises(Tkinter.TclError, self.tv.heading, '#0',
- background=None)
- # invalid value
- self.assertRaises(Tkinter.TclError, self.tv.heading, '#0',
- anchor=1)
-
- # XXX skipping for now; should be fixed to work with newer ttk
- @unittest.skip("skipping pending resolution of Issue #10734")
- def test_heading_callback(self):
- def simulate_heading_click(x, y):
- support.simulate_mouse_click(self.tv, x, y)
- self.tv.update_idletasks()
-
- success = [] # no success for now
-
- self.tv.pack()
- self.tv.wait_visibility()
- self.tv.heading('#0', command=lambda: success.append(True))
- self.tv.column('#0', width=100)
- self.tv.update()
-
- # assuming that the coords (5, 5) fall into heading #0
- simulate_heading_click(5, 5)
- if not success:
- self.fail("The command associated to the treeview heading wasn't "
- "invoked.")
-
- success = []
- commands = self.tv.master._tclCommands
- self.tv.heading('#0', command=str(self.tv.heading('#0', command=None)))
- self.assertEqual(commands, self.tv.master._tclCommands)
- simulate_heading_click(5, 5)
- if not success:
- self.fail("The command associated to the treeview heading wasn't "
- "invoked.")
-
- # XXX The following raises an error in a tcl interpreter, but not in
- # Python
- #self.tv.heading('#0', command='I dont exist')
- #simulate_heading_click(5, 5)
-
-
- def test_index(self):
- # item 'what' doesn't exist
- self.assertRaises(Tkinter.TclError, self.tv.index, 'what')
-
- self.assertEqual(self.tv.index(''), 0)
-
- item1 = self.tv.insert('', 'end')
- item2 = self.tv.insert('', 'end')
- c1 = self.tv.insert(item1, 'end')
- c2 = self.tv.insert(item1, 'end')
- self.assertEqual(self.tv.index(item1), 0)
- self.assertEqual(self.tv.index(c1), 0)
- self.assertEqual(self.tv.index(c2), 1)
- self.assertEqual(self.tv.index(item2), 1)
-
- self.tv.move(item2, '', 0)
- self.assertEqual(self.tv.index(item2), 0)
- self.assertEqual(self.tv.index(item1), 1)
-
- # check that index still works even after its parent and siblings
- # have been detached
- self.tv.detach(item1)
- self.assertEqual(self.tv.index(c2), 1)
- self.tv.detach(c1)
- self.assertEqual(self.tv.index(c2), 0)
-
- # but it fails after item has been deleted
- self.tv.delete(item1)
- self.assertRaises(Tkinter.TclError, self.tv.index, c2)
-
-
- def test_insert_item(self):
- # parent 'none' doesn't exist
- self.assertRaises(Tkinter.TclError, self.tv.insert, 'none', 'end')
-
- # open values
- self.assertRaises(Tkinter.TclError, self.tv.insert, '', 'end',
- open='')
- self.assertRaises(Tkinter.TclError, self.tv.insert, '', 'end',
- open='please')
- self.assertFalse(self.tv.delete(self.tv.insert('', 'end', open=True)))
- self.assertFalse(self.tv.delete(self.tv.insert('', 'end', open=False)))
-
- # invalid index
- self.assertRaises(Tkinter.TclError, self.tv.insert, '', 'middle')
-
- # trying to duplicate item id is invalid
- itemid = self.tv.insert('', 'end', 'first-item')
- self.assertEqual(itemid, 'first-item')
- self.assertRaises(Tkinter.TclError, self.tv.insert, '', 'end',
- 'first-item')
- self.assertRaises(Tkinter.TclError, self.tv.insert, '', 'end',
- MockTclObj('first-item'))
-
- # unicode values
- value = u'\xe1ba'
- item = self.tv.insert('', 'end', values=(value, ))
- self.assertEqual(self.tv.item(item, 'values'), (value, ))
- self.assertEqual(self.tv.item(item, values=None), (value, ))
-
- self.tv.item(item, values=list(self.tv.item(item, values=None)))
- self.assertEqual(self.tv.item(item, values=None), (value, ))
-
- self.assertTrue(isinstance(self.tv.item(item), dict))
-
- # erase item values
- self.tv.item(item, values='')
- self.assertFalse(self.tv.item(item, values=None))
-
- # item tags
- item = self.tv.insert('', 'end', tags=[1, 2, value])
- self.assertEqual(self.tv.item(item, tags=None), ('1', '2', value))
- self.tv.item(item, tags=[])
- self.assertFalse(self.tv.item(item, tags=None))
- self.tv.item(item, tags=(1, 2))
- self.assertEqual(self.tv.item(item, tags=None), ('1', '2'))
-
- # values with spaces
- item = self.tv.insert('', 'end', values=('a b c',
- '%s %s' % (value, value)))
- self.assertEqual(self.tv.item(item, values=None),
- ('a b c', '%s %s' % (value, value)))
-
- # text
- self.assertEqual(self.tv.item(
- self.tv.insert('', 'end', text="Label here"), text=None),
- "Label here")
- self.assertEqual(self.tv.item(
- self.tv.insert('', 'end', text=value), text=None),
- value)
-
-
- def test_set(self):
- self.tv['columns'] = ['A', 'B']
- item = self.tv.insert('', 'end', values=['a', 'b'])
- self.assertEqual(self.tv.set(item), {'A': 'a', 'B': 'b'})
-
- self.tv.set(item, 'B', 'a')
- self.assertEqual(self.tv.item(item, values=None), ('a', 'a'))
-
- self.tv['columns'] = ['B']
- self.assertEqual(self.tv.set(item), {'B': 'a'})
-
- self.tv.set(item, 'B', 'b')
- self.assertEqual(self.tv.set(item, column='B'), 'b')
- self.assertEqual(self.tv.item(item, values=None), ('b', 'a'))
-
- self.tv.set(item, 'B', 123)
- self.assertEqual(self.tv.set(item, 'B'), 123)
- self.assertEqual(self.tv.item(item, values=None), (123, 'a'))
- self.assertEqual(self.tv.set(item), {'B': 123})
-
- # inexistent column
- self.assertRaises(Tkinter.TclError, self.tv.set, item, 'A')
- self.assertRaises(Tkinter.TclError, self.tv.set, item, 'A', 'b')
-
- # inexistent item
- self.assertRaises(Tkinter.TclError, self.tv.set, 'notme')
-
-
- def test_tag_bind(self):
- events = []
- item1 = self.tv.insert('', 'end', tags=['call'])
- item2 = self.tv.insert('', 'end', tags=['call'])
- self.tv.tag_bind('call', '<ButtonPress-1>',
- lambda evt: events.append(1))
- self.tv.tag_bind('call', '<ButtonRelease-1>',
- lambda evt: events.append(2))
-
- self.tv.pack()
- self.tv.wait_visibility()
- self.tv.update()
-
- pos_y = set()
- found = set()
- for i in range(0, 100, 10):
- if len(found) == 2: # item1 and item2 already found
- break
- item_id = self.tv.identify_row(i)
- if item_id and item_id not in found:
- pos_y.add(i)
- found.add(item_id)
-
- self.assertEqual(len(pos_y), 2) # item1 and item2 y pos
- for y in pos_y:
- support.simulate_mouse_click(self.tv, 0, y)
-
- # by now there should be 4 things in the events list, since each
- # item had a bind for two events that were simulated above
- self.assertEqual(len(events), 4)
- for evt in zip(events[::2], events[1::2]):
- self.assertEqual(evt, (1, 2))
-
-
- def test_tag_configure(self):
- # Just testing parameter passing for now
- self.assertRaises(TypeError, self.tv.tag_configure)
- self.assertRaises(Tkinter.TclError, self.tv.tag_configure,
- 'test', sky='blue')
- self.tv.tag_configure('test', foreground='blue')
- self.assertEqual(str(self.tv.tag_configure('test', 'foreground')),
- 'blue')
- self.assertEqual(str(self.tv.tag_configure('test', foreground=None)),
- 'blue')
- self.assertTrue(isinstance(self.tv.tag_configure('test'), dict))
-
-
-tests_gui = (
- WidgetTest, ButtonTest, CheckbuttonTest, RadiobuttonTest,
- ComboboxTest, EntryTest, PanedwindowTest, ScaleTest, NotebookTest,
- TreeviewTest
- )
-
-if __name__ == "__main__":
- run_unittest(*tests_gui)