Merge with 3.5

This commit is contained in:
Terry Jan Reedy 2016-05-17 18:18:55 -04:00
commit 40a05621f9
2 changed files with 98 additions and 10 deletions

View File

@ -4,6 +4,7 @@ from idlelib import SearchEngine
from idlelib.SearchDialogBase import SearchDialogBase from idlelib.SearchDialogBase import SearchDialogBase
def _setup(text): def _setup(text):
"Create or find the singleton SearchDialog instance."
root = text._root() root = text._root()
engine = SearchEngine.get(root) engine = SearchEngine.get(root)
if not hasattr(engine, "_searchdialog"): if not hasattr(engine, "_searchdialog"):
@ -11,13 +12,16 @@ def _setup(text):
return engine._searchdialog return engine._searchdialog
def find(text): def find(text):
"Handle the editor edit menu item and corresponding event."
pat = text.get("sel.first", "sel.last") pat = text.get("sel.first", "sel.last")
return _setup(text).open(text,pat) return _setup(text).open(text, pat) # Open is inherited from SDBase.
def find_again(text): def find_again(text):
"Handle the editor edit menu item and corresponding event."
return _setup(text).find_again(text) return _setup(text).find_again(text)
def find_selection(text): def find_selection(text):
"Handle the editor edit menu item and corresponding event."
return _setup(text).find_selection(text) return _setup(text).find_selection(text)
class SearchDialog(SearchDialogBase): class SearchDialog(SearchDialogBase):
@ -66,24 +70,28 @@ class SearchDialog(SearchDialogBase):
self.engine.setcookedpat(pat) self.engine.setcookedpat(pat)
return self.find_again(text) return self.find_again(text)
def _search_dialog(parent):
root = Tk() def _search_dialog(parent): # htest #
root.title("Test SearchDialog") '''Display search test box.'''
box = Toplevel(parent)
box.title("Test SearchDialog")
width, height, x, y = list(map(int, re.split('[x+]', parent.geometry()))) width, height, x, y = list(map(int, re.split('[x+]', parent.geometry())))
root.geometry("+%d+%d"%(x, y + 150)) box.geometry("+%d+%d"%(x, y + 150))
text = Text(root) text = Text(box, inactiveselectbackground='gray')
text.pack() text.pack()
text.insert("insert","This is a sample string.\n"*10) text.insert("insert","This is a sample string.\n"*5)
def show_find(): def show_find():
text.tag_add(SEL, "1.0", END) text.tag_add(SEL, "1.0", END)
s = _setup(text) _setup(text).open(text)
s.open(text)
text.tag_remove(SEL, "1.0", END) text.tag_remove(SEL, "1.0", END)
button = Button(root, text="Search", command=show_find) button = Button(box, text="Search (selection ignored)", command=show_find)
button.pack() button.pack()
if __name__ == '__main__': if __name__ == '__main__':
import unittest
unittest.main('idlelib.idle_test.test_searchdialog',
verbosity=2, exit=False)
from idlelib.idle_test.htest import run from idlelib.idle_test.htest import run
run(_search_dialog) run(_search_dialog)

View File

@ -0,0 +1,80 @@
"""Test SearchDialog class in SearchDialogue.py"""
# Does not currently test the event handler wrappers.
# A usage test should simulate clicks and check hilighting.
# Tests need to be coordinated with SearchDialogBase tests
# to avoid duplication.
from test.support import requires
requires('gui')
import unittest
import tkinter as tk
from tkinter import BooleanVar
import idlelib.SearchEngine as se
import idlelib.SearchDialog as sd
class SearchDialogTest(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.root = tk.Tk()
@classmethod
def tearDownClass(cls):
cls.root.destroy()
del cls.root
def setUp(self):
self.engine = se.SearchEngine(self.root)
self.dialog = sd.SearchDialog(self.root, self.engine)
self.text = tk.Text()
self.text.insert('1.0', 'Hello World!')
def test_find_again(self):
# Search for various expressions
text = self.text
self.engine.setpat('')
self.assertFalse(self.dialog.find_again(text))
self.engine.setpat('Hello')
self.assertTrue(self.dialog.find_again(text))
self.engine.setpat('Goodbye')
self.assertFalse(self.dialog.find_again(text))
self.engine.setpat('World!')
self.assertTrue(self.dialog.find_again(text))
self.engine.setpat('Hello World!')
self.assertTrue(self.dialog.find_again(text))
# Regular expression
self.engine.revar = BooleanVar(self.root, True)
self.engine.setpat('W[aeiouy]r')
self.assertTrue(self.dialog.find_again(text))
def test_find_selection(self):
# Select some text and make sure it's found
text = self.text
# Add additional line to find
self.text.insert('2.0', 'Hello World!')
text.tag_add('sel', '1.0', '1.4') # Select 'Hello'
self.assertTrue(self.dialog.find_selection(text))
text.tag_remove('sel', '1.0', 'end')
text.tag_add('sel', '1.6', '1.11') # Select 'World!'
self.assertTrue(self.dialog.find_selection(text))
text.tag_remove('sel', '1.0', 'end')
text.tag_add('sel', '1.0', '1.11') # Select 'Hello World!'
self.assertTrue(self.dialog.find_selection(text))
# Remove additional line
text.delete('2.0', 'end')
if __name__ == '__main__':
unittest.main(verbosity=2, exit=2)