Improve keyutils tests
This commit is contained in:
parent
3c9e8ff9ab
commit
fb7c75a090
@ -157,8 +157,7 @@ def _parse_keystring(keystr):
|
|||||||
special = False
|
special = False
|
||||||
else:
|
else:
|
||||||
yield '>'
|
yield '>'
|
||||||
for c in key:
|
assert not key, key
|
||||||
yield 'Shift+' + c if c.isupper() else c
|
|
||||||
elif c == '<':
|
elif c == '<':
|
||||||
special = True
|
special = True
|
||||||
elif special:
|
elif special:
|
||||||
|
@ -18,7 +18,8 @@
|
|||||||
# along with qutebrowser. If not, see <http://www.gnu.org/licenses/>.
|
# along with qutebrowser. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
from PyQt5.QtCore import Qt, pyqtSignal
|
from PyQt5.QtCore import Qt, QEvent, pyqtSignal
|
||||||
|
from PyQt5.QtGui import QKeyEvent
|
||||||
from PyQt5.QtWidgets import QWidget
|
from PyQt5.QtWidgets import QWidget
|
||||||
|
|
||||||
from tests.unit.keyinput import key_data
|
from tests.unit.keyinput import key_data
|
||||||
@ -112,7 +113,7 @@ class TestKeyToString:
|
|||||||
assert keyutils._key_to_string(qt_key.member) == qt_key.name
|
assert keyutils._key_to_string(qt_key.member) == qt_key.name
|
||||||
|
|
||||||
def test_missing(self, monkeypatch):
|
def test_missing(self, monkeypatch):
|
||||||
monkeypatch.delattr(keyutils.Qt, 'Key_Blue')
|
monkeypatch.delattr(keyutils.Qt, 'Key_AltGr')
|
||||||
# We don't want to test the key which is actually missing - we only
|
# We don't want to test the key which is actually missing - we only
|
||||||
# want to know if the mapping still behaves properly.
|
# want to know if the mapping still behaves properly.
|
||||||
assert keyutils._key_to_string(Qt.Key_A) == 'A'
|
assert keyutils._key_to_string(Qt.Key_A) == 'A'
|
||||||
@ -199,6 +200,21 @@ def test_normalize_keystr(orig, normalized):
|
|||||||
assert str(keyutils.KeySequence.parse(orig)) == normalized
|
assert str(keyutils.KeySequence.parse(orig)) == normalized
|
||||||
|
|
||||||
|
|
||||||
|
def test_key_info_from_event():
|
||||||
|
ev = QKeyEvent(QEvent.KeyPress, Qt.Key_A, Qt.ShiftModifier, 'A')
|
||||||
|
info = keyutils.KeyInfo.from_event(ev)
|
||||||
|
assert info.key == Qt.Key_A
|
||||||
|
assert info.modifiers == Qt.ShiftModifier
|
||||||
|
|
||||||
|
|
||||||
|
def test_key_info_to_event():
|
||||||
|
info = keyutils.KeyInfo(Qt.Key_A, Qt.ShiftModifier)
|
||||||
|
ev = info.to_event()
|
||||||
|
assert ev.key() == Qt.Key_A
|
||||||
|
assert ev.modifiers() == Qt.ShiftModifier
|
||||||
|
assert ev.text() == 'A'
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('key, printable', [
|
@pytest.mark.parametrize('key, printable', [
|
||||||
(Qt.Key_Control, False),
|
(Qt.Key_Control, False),
|
||||||
(Qt.Key_Escape, False),
|
(Qt.Key_Escape, False),
|
||||||
|
Loading…
Reference in New Issue
Block a user