diff options
author | Terry Jan Reedy <tjreedy@udel.edu> | 2014-05-16 00:50:10 (GMT) |
---|---|---|
committer | Terry Jan Reedy <tjreedy@udel.edu> | 2014-05-16 00:50:10 (GMT) |
commit | 6936159dcd9b8d24fff9c8825d974dd0e6ae5c87 (patch) | |
tree | 1afe90612d3e18cc52a77d90efd807b01d8036d4 | |
parent | 2d1ec0648437abd3a96db363dd4d9fc4603dd313 (diff) | |
download | cpython-6936159dcd9b8d24fff9c8825d974dd0e6ae5c87.zip cpython-6936159dcd9b8d24fff9c8825d974dd0e6ae5c87.tar.gz cpython-6936159dcd9b8d24fff9c8825d974dd0e6ae5c87.tar.bz2 |
Issue #18104: revise docstrings, remove obsolete comments.
-rw-r--r-- | Lib/idlelib/idle_test/htest.py | 61 |
1 files changed, 32 insertions, 29 deletions
diff --git a/Lib/idlelib/idle_test/htest.py b/Lib/idlelib/idle_test/htest.py index 99f724c..001f7ee 100644 --- a/Lib/idlelib/idle_test/htest.py +++ b/Lib/idlelib/idle_test/htest.py @@ -1,35 +1,38 @@ -'''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. -runall() runs all the defined tests +run(test): run *test*, a callable that causes a widget to be displayed. +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__': <unittest, if there is one> from idlelib.idle_test.htest import run 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 = { 'file': '', 'kwds': {'title': ''}, 'msg': "" } -with X.__name__ prepended to _spec. -File (no .py) is used in runall() to import the file and get the class. -Kwds is 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 -might test the widget. Closing The box skips or ends the test. + +file (no .py): used in runall() to import the file and get X. +kwds: passed to X (**kwds), after 'parent' is added, to initialize X. +title: an example; used for some widgets, delete if not. +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 import tkinter as tk -# Template for class_spec dicts, copy and uncomment _Editor_window_spec = { 'file': 'EditorWindow', @@ -61,30 +64,30 @@ GetCfgSectionNameDialog_spec = { "Close 'Get Name' with a valid entry (printed to Shell), [Cancel], or [X]", } -def run(klas): - "Test the widget class klas using _spec dict" +def run(test): + "Display a widget with callable *test* using a _spec dict" root = tk.Tk() - klas_spec = globals()[klas.__name__+'_spec'] - klas_kwds = klas_spec['kwds'] - klas_kwds['parent'] = root - # This presumes that Idle consistently uses 'parent' - def run_klas(): - widget = klas(**klas_kwds) + test_spec = globals()[test.__name__ + '_spec'] + test_kwds = test_spec['kwds'] + test_kwds['parent'] = root + + def run_test(): + widget = test(**test_kwds) try: print(widget.result) except AttributeError: pass - tk.Label(root, text=klas_spec['msg'], justify='left').pack() - tk.Button(root, text='Test ' + klas.__name__, command=run_klas).pack() + tk.Label(root, text=test_spec['msg'], justify='left').pack() + tk.Button(root, text='Test ' + test.__name__, command=run_test).pack() root.mainloop() def runall(): - 'Run all tests. Quick and dirty version.' + "Run all tests. Quick and dirty version." for k, d in globals().items(): if k.endswith('_spec'): mod = import_module('idlelib.' + d['file']) - klas = getattr(mod, k[:-5]) - run(klas) + test = getattr(mod, k[:-5]) + run(test) if __name__ == '__main__': runall() |