Commit fb371afa authored by Terry Jan Reedy's avatar Terry Jan Reedy

Issue #18104: revise docstrings, remove obsolete comments.

parent 4c5eced9
'''Run a human test of Idle wndow, dialog, and other widget classes. '''Run human tests of Idle's window, dialog, and popup widgets.
run(klass) runs a test for one class. run(test): run *test*, a callable that causes a widget to be displayed.
runall() runs all the defined tests runall(): run all tests defined in this file.
Let X be a global name bound to a widget callable. End the module with
The file wih the widget class should end with
if __name__ == '__main__': if __name__ == '__main__':
<unittest, if there is one> <unittest, if there is one>
from idlelib.idle_test.htest import run from idlelib.idle_test.htest import run
run(X) run(X)
where X is a global object of the module. X must be a callable with a
.__name__ attribute that accepts a 'parent' attribute. X will usually be
a widget class, but a callable instance with .__name__ or a wrapper
function also work. The name of wrapper functions, like _Editor_Window,
should start with '_'.
This file must then contain an instance of this template. The X object must have a .__name__ attribute and a 'parent' parameter.
X will often be a widget class, but a callable instance with .__name__
or a wrapper function also work. The name of wrapper functions, like
'_Editor_Window', should start with '_'.
This file must contain a matching instance of the folling template,
with X.__name__ prepended, as in '_Editor_window_spec ...'.
_spec = { _spec = {
'file': '', 'file': '',
'kwds': {'title': ''}, 'kwds': {'title': ''},
'msg': "" 'msg': ""
} }
with X.__name__ prepended to _spec.
File (no .py) is used in runall() to import the file and get the class. file (no .py): used in runall() to import the file and get X.
Kwds is passed to X (**kwds) after 'parent' is added, to initialize X. kwds: passed to X (**kwds), after 'parent' is added, to initialize X.
Msg. displayed is a window with a start button. hint as to how the user title: an example; used for some widgets, delete if not.
might test the widget. Closing The box skips or ends the test. msg: displayed in a master window. Hints as to how the user might
test the widget. Close the window to skip or end the test.
''' '''
from importlib import import_module from importlib import import_module
import Tkinter as tk import Tkinter as tk
# Template for class_spec dicts, copy and uncomment
_Editor_window_spec = { _Editor_window_spec = {
'file': 'EditorWindow', 'file': 'EditorWindow',
...@@ -61,30 +64,30 @@ GetCfgSectionNameDialog_spec = { ...@@ -61,30 +64,30 @@ GetCfgSectionNameDialog_spec = {
"Close 'Get Name' with a valid entry (printed to Shell), [Cancel], or [X]", "Close 'Get Name' with a valid entry (printed to Shell), [Cancel], or [X]",
} }
def run(klas): def run(test):
"Test the widget class klas using _spec dict" "Display a widget with callable *test* using a _spec dict"
root = tk.Tk() root = tk.Tk()
klas_spec = globals()[klas.__name__+'_spec'] test_spec = globals()[test.__name__ + '_spec']
klas_kwds = klas_spec['kwds'] test_kwds = test_spec['kwds']
klas_kwds['parent'] = root test_kwds['parent'] = root
# This presumes that Idle consistently uses 'parent'
def run_klas(): def run_test():
widget = klas(**klas_kwds) widget = test(**test_kwds)
try: try:
print(widget.result) print(widget.result)
except AttributeError: except AttributeError:
pass pass
tk.Label(root, text=klas_spec['msg'], justify='left').pack() tk.Label(root, text=test_spec['msg'], justify='left').pack()
tk.Button(root, text='Test ' + klas.__name__, command=run_klas).pack() tk.Button(root, text='Test ' + test.__name__, command=run_test).pack()
root.mainloop() root.mainloop()
def runall(): def runall():
'Run all tests. Quick and dirty version.' "Run all tests. Quick and dirty version."
for k, d in globals().items(): for k, d in globals().items():
if k.endswith('_spec'): if k.endswith('_spec'):
mod = import_module('idlelib.' + d['file']) mod = import_module('idlelib.' + d['file'])
klas = getattr(mod, k[:-5]) test = getattr(mod, k[:-5])
run(klas) run(test)
if __name__ == '__main__': if __name__ == '__main__':
runall() runall()
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