bpo-24813: IDLE: Add default title to help_about (#2366)

Patch by Cheryl Sabella.
This commit is contained in:
csabella 2017-06-23 20:00:58 -04:00 committed by terryjreedy
parent 8f525882fa
commit 18ede06258
4 changed files with 33 additions and 9 deletions

View File

@ -463,7 +463,7 @@ class EditorWindow(object):
def about_dialog(self, event=None): def about_dialog(self, event=None):
"Handle Help 'About IDLE' event." "Handle Help 'About IDLE' event."
# Synchronize with macosx.overrideRootMenu.about_dialog. # Synchronize with macosx.overrideRootMenu.about_dialog.
help_about.AboutDialog(self.top,'About IDLE') help_about.AboutDialog(self.top)
def config_dialog(self, event=None): def config_dialog(self, event=None):
"Handle Options 'Configure IDLE' event." "Handle Options 'Configure IDLE' event."

View File

@ -2,7 +2,7 @@
""" """
import os import os
from sys import version from platform import python_version
from tkinter import Toplevel, Frame, Label, Button, PhotoImage from tkinter import Toplevel, Frame, Label, Button, PhotoImage
from tkinter import SUNKEN, TOP, BOTTOM, LEFT, X, BOTH, W, EW, NSEW, E from tkinter import SUNKEN, TOP, BOTTOM, LEFT, X, BOTH, W, EW, NSEW, E
@ -14,7 +14,7 @@ class AboutDialog(Toplevel):
"""Modal about dialog for idle """Modal about dialog for idle
""" """
def __init__(self, parent, title, _htest=False, _utest=False): def __init__(self, parent, title=None, _htest=False, _utest=False):
"""Create popup, do not return until tk widget destroyed. """Create popup, do not return until tk widget destroyed.
parent - parent of this dialog parent - parent of this dialog
@ -32,7 +32,7 @@ class AboutDialog(Toplevel):
self.fg = "#ffffff" self.fg = "#ffffff"
self.create_widgets() self.create_widgets()
self.resizable(height=False, width=False) self.resizable(height=False, width=False)
self.title(title) self.title(title or f'About IDLE {python_version()}')
self.transient(parent) self.transient(parent)
self.grab_set() self.grab_set()
self.protocol("WM_DELETE_WINDOW", self.ok) self.protocol("WM_DELETE_WINDOW", self.ok)
@ -48,7 +48,6 @@ class AboutDialog(Toplevel):
self.wait_window() self.wait_window()
def create_widgets(self): def create_widgets(self):
release = version[:version.index(' ')]
frame = Frame(self, borderwidth=2, relief=SUNKEN) frame = Frame(self, borderwidth=2, relief=SUNKEN)
frame_buttons = Frame(self) frame_buttons = Frame(self)
frame_buttons.pack(side=BOTTOM, fill=X) frame_buttons.pack(side=BOTTOM, fill=X)
@ -80,7 +79,7 @@ class AboutDialog(Toplevel):
justify=LEFT, fg=self.fg, bg=self.bg) justify=LEFT, fg=self.fg, bg=self.bg)
email.grid(row=6, column=0, columnspan=2, sticky=W, padx=10, pady=0) email.grid(row=6, column=0, columnspan=2, sticky=W, padx=10, pady=0)
docs = Label(frame_background, text='https://docs.python.org/' + docs = Label(frame_background, text='https://docs.python.org/' +
version[:3] + '/library/idle.html', python_version()[:3] + '/library/idle.html',
justify=LEFT, fg=self.fg, bg=self.bg) justify=LEFT, fg=self.fg, bg=self.bg)
docs.grid(row=7, column=0, columnspan=2, sticky=W, padx=10, pady=0) docs.grid(row=7, column=0, columnspan=2, sticky=W, padx=10, pady=0)
@ -88,7 +87,8 @@ class AboutDialog(Toplevel):
height=2, bg=self.bg).grid(row=8, column=0, sticky=EW, height=2, bg=self.bg).grid(row=8, column=0, sticky=EW,
columnspan=3, padx=5, pady=5) columnspan=3, padx=5, pady=5)
pyver = Label(frame_background, text='Python version: ' + release, pyver = Label(frame_background,
text='Python version: ' + python_version(),
fg=self.fg, bg=self.bg) fg=self.fg, bg=self.bg)
pyver.grid(row=9, column=0, sticky=W, padx=10, pady=0) pyver.grid(row=9, column=0, sticky=W, padx=10, pady=0)
tkver = Label(frame_background, text='Tk version: ' + tk_patchlevel, tkver = Label(frame_background, text='Tk version: ' + tk_patchlevel,
@ -113,7 +113,8 @@ class AboutDialog(Toplevel):
height=2, bg=self.bg).grid(row=11, column=0, sticky=EW, height=2, bg=self.bg).grid(row=11, column=0, sticky=EW,
columnspan=3, padx=5, pady=5) columnspan=3, padx=5, pady=5)
idlever = Label(frame_background, text='IDLE version: ' + release, idlever = Label(frame_background,
text='IDLE version: ' + python_version(),
fg=self.fg, bg=self.bg) fg=self.fg, bg=self.bg)
idlever.grid(row=12, column=0, sticky=W, padx=10, pady=0) idlever.grid(row=12, column=0, sticky=W, padx=10, pady=0)
idle_buttons = Frame(frame_background, bg=self.bg) idle_buttons = Frame(frame_background, bg=self.bg)

View File

@ -10,6 +10,7 @@ from idlelib.idle_test.mock_tk import Mbox_func
from idlelib.help_about import AboutDialog as About from idlelib.help_about import AboutDialog as About
from idlelib import textview from idlelib import textview
import os.path import os.path
from platform import python_version
class LiveDialogTest(unittest.TestCase): class LiveDialogTest(unittest.TestCase):
"""Simulate user clicking buttons other than [Close]. """Simulate user clicking buttons other than [Close].
@ -79,6 +80,28 @@ class LiveDialogTest(unittest.TestCase):
dialog._current_textview.destroy() dialog._current_textview.destroy()
class DefaultTitleTest(unittest.TestCase):
"Test default title."
@classmethod
def setUpClass(cls):
requires('gui')
cls.root = Tk()
cls.root.withdraw()
cls.dialog = About(cls.root, _utest=True)
@classmethod
def tearDownClass(cls):
del cls.dialog
cls.root.update_idletasks()
cls.root.destroy()
del cls.root
def test_dialog_title(self):
"""Test about dialog title"""
self.assertEqual(self.dialog.title(), f'About IDLE {python_version()}')
class CloseTest(unittest.TestCase): class CloseTest(unittest.TestCase):
"""Simulate user clicking [Close] button""" """Simulate user clicking [Close] button"""

View File

@ -165,7 +165,7 @@ def overrideRootMenu(root, flist):
"Handle Help 'About IDLE' event." "Handle Help 'About IDLE' event."
# Synchronize with editor.EditorWindow.about_dialog. # Synchronize with editor.EditorWindow.about_dialog.
from idlelib import help_about from idlelib import help_about
help_about.AboutDialog(root, 'About IDLE') help_about.AboutDialog(root)
def config_dialog(event=None): def config_dialog(event=None):
"Handle Options 'Configure IDLE' event." "Handle Options 'Configure IDLE' event."