Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
b0a6196f
Commit
b0a6196f
authored
Dec 29, 2018
by
Cheryl Sabella
Committed by
Terry Jan Reedy
Dec 29, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bpo-35598: IDLE: Increase test coverage for config_key.py (#11360)
parent
0e5f771f
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
197 additions
and
8 deletions
+197
-8
Lib/idlelib/config_key.py
Lib/idlelib/config_key.py
+4
-4
Lib/idlelib/idle_test/test_config_key.py
Lib/idlelib/idle_test/test_config_key.py
+192
-3
Misc/NEWS.d/next/IDLE/2018-12-27-15-29-11.bpo-35598.FWOOm8.rst
...NEWS.d/next/IDLE/2018-12-27-15-29-11.bpo-35598.FWOOm8.rst
+1
-1
No files found.
Lib/idlelib/config_key.py
View file @
b0a6196f
...
@@ -67,7 +67,7 @@ class GetKeysDialog(Toplevel):
...
@@ -67,7 +67,7 @@ class GetKeysDialog(Toplevel):
messagebox
.
showerror
(
*
args
,
**
kwargs
)
messagebox
.
showerror
(
*
args
,
**
kwargs
)
def
create_widgets
(
self
):
def
create_widgets
(
self
):
frame
=
Frame
(
self
,
borderwidth
=
2
,
relief
=
SUNKEN
)
self
.
frame
=
frame
=
Frame
(
self
,
borderwidth
=
2
,
relief
=
SUNKEN
)
frame
.
pack
(
side
=
TOP
,
expand
=
True
,
fill
=
BOTH
)
frame
.
pack
(
side
=
TOP
,
expand
=
True
,
fill
=
BOTH
)
frame_buttons
=
Frame
(
self
)
frame_buttons
=
Frame
(
self
)
...
@@ -81,7 +81,7 @@ class GetKeysDialog(Toplevel):
...
@@ -81,7 +81,7 @@ class GetKeysDialog(Toplevel):
self
.
button_cancel
.
grid
(
row
=
0
,
column
=
1
,
padx
=
5
,
pady
=
5
)
self
.
button_cancel
.
grid
(
row
=
0
,
column
=
1
,
padx
=
5
,
pady
=
5
)
# Basic entry key sequence.
# Basic entry key sequence.
self
.
frame_keyseq_basic
=
Frame
(
frame
)
self
.
frame_keyseq_basic
=
Frame
(
frame
,
name
=
'keyseq_basic'
)
self
.
frame_keyseq_basic
.
grid
(
row
=
0
,
column
=
0
,
sticky
=
NSEW
,
self
.
frame_keyseq_basic
.
grid
(
row
=
0
,
column
=
0
,
sticky
=
NSEW
,
padx
=
5
,
pady
=
5
)
padx
=
5
,
pady
=
5
)
basic_title
=
Label
(
self
.
frame_keyseq_basic
,
basic_title
=
Label
(
self
.
frame_keyseq_basic
,
...
@@ -135,7 +135,7 @@ class GetKeysDialog(Toplevel):
...
@@ -135,7 +135,7 @@ class GetKeysDialog(Toplevel):
self
.
button_clear
.
grid
(
row
=
2
,
column
=
0
,
columnspan
=
4
)
self
.
button_clear
.
grid
(
row
=
2
,
column
=
0
,
columnspan
=
4
)
# Advanced entry key sequence.
# Advanced entry key sequence.
self
.
frame_keyseq_advanced
=
Frame
(
frame
)
self
.
frame_keyseq_advanced
=
Frame
(
frame
,
name
=
'keyseq_advanced'
)
self
.
frame_keyseq_advanced
.
grid
(
row
=
0
,
column
=
0
,
sticky
=
NSEW
,
self
.
frame_keyseq_advanced
.
grid
(
row
=
0
,
column
=
0
,
sticky
=
NSEW
,
padx
=
5
,
pady
=
5
)
padx
=
5
,
pady
=
5
)
advanced_title
=
Label
(
self
.
frame_keyseq_advanced
,
justify
=
LEFT
,
advanced_title
=
Label
(
self
.
frame_keyseq_advanced
,
justify
=
LEFT
,
...
@@ -197,7 +197,7 @@ class GetKeysDialog(Toplevel):
...
@@ -197,7 +197,7 @@ class GetKeysDialog(Toplevel):
self
.
frame_controls_basic
.
lift
()
self
.
frame_controls_basic
.
lift
()
self
.
advanced
=
False
self
.
advanced
=
False
def
final_key_selected
(
self
,
event
):
def
final_key_selected
(
self
,
event
=
None
):
"Handler for clicking on key in basic settings list."
"Handler for clicking on key in basic settings list."
self
.
build_key_string
()
self
.
build_key_string
()
...
...
Lib/idlelib/idle_test/test_config_key.py
View file @
b0a6196f
"Test config_key, coverage 82%"
"""Test config_key, coverage 98%.
Coverage is effectively 100%. Tkinter dialog is mocked, Mac-only line
may be skipped, and dummy function in bind test should not be called.
Not tested: exit with 'self.advanced or self.keys_ok(keys)) ...' False.
"""
from
idlelib
import
config_key
from
idlelib
import
config_key
from
test.support
import
requires
from
test.support
import
requires
import
unittest
import
unittest
from
tkinter
import
Tk
from
unittest
import
mock
from
tkinter
import
Tk
,
TclError
from
idlelib.idle_test.mock_idle
import
Func
from
idlelib.idle_test.mock_idle
import
Func
from
idlelib.idle_test.mock_tk
import
Mbox_func
from
idlelib.idle_test.mock_tk
import
Mbox_func
gkd
=
config_key
.
GetKeysDialog
class
ValidationTest
(
unittest
.
TestCase
):
class
ValidationTest
(
unittest
.
TestCase
):
"Test validation methods: ok, keys_ok, bind_ok."
"Test validation methods: ok, keys_ok, bind_ok."
class
Validator
(
config_key
.
GetKeysDialog
):
class
Validator
(
gkd
):
def
__init__
(
self
,
*
args
,
**
kwargs
):
def
__init__
(
self
,
*
args
,
**
kwargs
):
config_key
.
GetKeysDialog
.
__init__
(
self
,
*
args
,
**
kwargs
)
config_key
.
GetKeysDialog
.
__init__
(
self
,
*
args
,
**
kwargs
)
class
list_keys_final
:
class
list_keys_final
:
...
@@ -95,5 +103,186 @@ class ValidationTest(unittest.TestCase):
...
@@ -95,5 +103,186 @@ class ValidationTest(unittest.TestCase):
self
.
assertIn
(
'not accepted'
,
self
.
dialog
.
showerror
.
message
)
self
.
assertIn
(
'not accepted'
,
self
.
dialog
.
showerror
.
message
)
class
ToggleLevelTest
(
unittest
.
TestCase
):
"Test toggle between Basic and Advanced frames."
@
classmethod
def
setUpClass
(
cls
):
requires
(
'gui'
)
cls
.
root
=
Tk
()
cls
.
root
.
withdraw
()
cls
.
dialog
=
gkd
(
cls
.
root
,
'Title'
,
'<<Test>>'
,
[],
_utest
=
True
)
@
classmethod
def
tearDownClass
(
cls
):
cls
.
dialog
.
cancel
()
cls
.
root
.
update_idletasks
()
cls
.
root
.
destroy
()
del
cls
.
dialog
,
cls
.
root
def
test_toggle_level
(
self
):
dialog
=
self
.
dialog
def
stackorder
():
"""Get the stack order of the children of the frame.
winfo_children() stores the children in stack order, so
this can be used to check whether a frame is above or
below another one.
"""
for
index
,
child
in
enumerate
(
dialog
.
frame
.
winfo_children
()):
if
child
.
_name
==
'keyseq_basic'
:
basic
=
index
if
child
.
_name
==
'keyseq_advanced'
:
advanced
=
index
return
basic
,
advanced
# New window starts at basic level.
self
.
assertFalse
(
dialog
.
advanced
)
self
.
assertIn
(
'Advanced'
,
dialog
.
button_level
[
'text'
])
basic
,
advanced
=
stackorder
()
self
.
assertGreater
(
basic
,
advanced
)
# Toggle to advanced.
dialog
.
toggle_level
()
self
.
assertTrue
(
dialog
.
advanced
)
self
.
assertIn
(
'Basic'
,
dialog
.
button_level
[
'text'
])
basic
,
advanced
=
stackorder
()
self
.
assertGreater
(
advanced
,
basic
)
# Toggle to basic.
dialog
.
button_level
.
invoke
()
self
.
assertFalse
(
dialog
.
advanced
)
self
.
assertIn
(
'Advanced'
,
dialog
.
button_level
[
'text'
])
basic
,
advanced
=
stackorder
()
self
.
assertGreater
(
basic
,
advanced
)
class
KeySelectionTest
(
unittest
.
TestCase
):
"Test selecting key on Basic frames."
class
Basic
(
gkd
):
def
__init__
(
self
,
*
args
,
**
kwargs
):
super
().
__init__
(
*
args
,
**
kwargs
)
class
list_keys_final
:
get
=
Func
()
select_clear
=
Func
()
yview
=
Func
()
self
.
list_keys_final
=
list_keys_final
def
set_modifiers_for_platform
(
self
):
self
.
modifiers
=
[
'foo'
,
'bar'
,
'BAZ'
]
self
.
modifier_label
=
{
'BAZ'
:
'ZZZ'
}
showerror
=
Mbox_func
()
@
classmethod
def
setUpClass
(
cls
):
requires
(
'gui'
)
cls
.
root
=
Tk
()
cls
.
root
.
withdraw
()
cls
.
dialog
=
cls
.
Basic
(
cls
.
root
,
'Title'
,
'<<Test>>'
,
[],
_utest
=
True
)
@
classmethod
def
tearDownClass
(
cls
):
cls
.
dialog
.
cancel
()
cls
.
root
.
update_idletasks
()
cls
.
root
.
destroy
()
del
cls
.
dialog
,
cls
.
root
def
setUp
(
self
):
self
.
dialog
.
clear_key_seq
()
def
test_get_modifiers
(
self
):
dialog
=
self
.
dialog
gm
=
dialog
.
get_modifiers
eq
=
self
.
assertEqual
# Modifiers are set by selecting/deselecting the checkbutton.
dialog
.
modifier_checkbuttons
[
'foo'
].
select
()
eq
(
gm
(),
[
'foo'
])
dialog
.
modifier_checkbuttons
[
'BAZ'
].
select
()
eq
(
gm
(),
[
'foo'
,
'BAZ'
])
dialog
.
modifier_checkbuttons
[
'foo'
].
deselect
()
eq
(
gm
(),
[
'BAZ'
])
def
test_translate_key
(
self
):
dialog
=
self
.
dialog
tr
=
dialog
.
translate_key
eq
=
self
.
assertEqual
# Letters return unchanged with no 'Shift'.
eq
(
tr
(
'q'
,
[]),
'Key-q'
)
eq
(
tr
(
'q'
,
[
'Control'
,
'Alt'
]),
'Key-q'
)
# 'Shift' uppercases single lowercase letters.
eq
(
tr
(
'q'
,
[
'Shift'
]),
'Key-Q'
)
eq
(
tr
(
'q'
,
[
'Control'
,
'Shift'
]),
'Key-Q'
)
eq
(
tr
(
'q'
,
[
'Control'
,
'Alt'
,
'Shift'
]),
'Key-Q'
)
# Convert key name to keysym.
eq
(
tr
(
'Page Up'
,
[]),
'Key-Prior'
)
# 'Shift' doesn't change case.
eq
(
tr
(
'Page Down'
,
[
'Shift'
]),
'Key-Next'
)
@
mock
.
patch
.
object
(
gkd
,
'get_modifiers'
)
def
test_build_key_string
(
self
,
mock_modifiers
):
dialog
=
self
.
dialog
key
=
dialog
.
list_keys_final
string
=
dialog
.
key_string
.
get
eq
=
self
.
assertEqual
key
.
get
.
result
=
'a'
mock_modifiers
.
return_value
=
[]
dialog
.
build_key_string
()
eq
(
string
(),
'<Key-a>'
)
mock_modifiers
.
return_value
=
[
'mymod'
]
dialog
.
build_key_string
()
eq
(
string
(),
'<mymod-Key-a>'
)
key
.
get
.
result
=
''
mock_modifiers
.
return_value
=
[
'mymod'
,
'test'
]
dialog
.
build_key_string
()
eq
(
string
(),
'<mymod-test>'
)
@
mock
.
patch
.
object
(
gkd
,
'get_modifiers'
)
def
test_final_key_selected
(
self
,
mock_modifiers
):
dialog
=
self
.
dialog
key
=
dialog
.
list_keys_final
string
=
dialog
.
key_string
.
get
eq
=
self
.
assertEqual
mock_modifiers
.
return_value
=
[
'Shift'
]
key
.
get
.
result
=
'{'
dialog
.
final_key_selected
()
eq
(
string
(),
'<Shift-Key-braceleft>'
)
class
CancelTest
(
unittest
.
TestCase
):
"Simulate user clicking [Cancel] button."
@
classmethod
def
setUpClass
(
cls
):
requires
(
'gui'
)
cls
.
root
=
Tk
()
cls
.
root
.
withdraw
()
cls
.
dialog
=
gkd
(
cls
.
root
,
'Title'
,
'<<Test>>'
,
[],
_utest
=
True
)
@
classmethod
def
tearDownClass
(
cls
):
cls
.
dialog
.
cancel
()
cls
.
root
.
update_idletasks
()
cls
.
root
.
destroy
()
del
cls
.
dialog
,
cls
.
root
def
test_cancel
(
self
):
self
.
assertEqual
(
self
.
dialog
.
winfo_class
(),
'Toplevel'
)
self
.
dialog
.
button_cancel
.
invoke
()
with
self
.
assertRaises
(
TclError
):
self
.
dialog
.
winfo_class
()
self
.
assertEqual
(
self
.
dialog
.
result
,
''
)
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
unittest
.
main
(
verbosity
=
2
)
unittest
.
main
(
verbosity
=
2
)
Misc/NEWS.d/next/IDLE/2018-12-27-15-29-11.bpo-35598.FWOOm8.rst
View file @
b0a6196f
Apply PEP8 naming convention to config_key.py
.
Update config_key: use PEP 8 names and add tests
.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment