aboutsummaryrefslogtreecommitdiff
path: root/tests/ut_mtextedit/ut_mtextedit.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/ut_mtextedit/ut_mtextedit.cpp')
-rw-r--r--tests/ut_mtextedit/ut_mtextedit.cpp31
1 files changed, 31 insertions, 0 deletions
diff --git a/tests/ut_mtextedit/ut_mtextedit.cpp b/tests/ut_mtextedit/ut_mtextedit.cpp
index fdde4d37..66fc47cb 100644
--- a/tests/ut_mtextedit/ut_mtextedit.cpp
+++ b/tests/ut_mtextedit/ut_mtextedit.cpp
@@ -1264,6 +1264,37 @@ void Ut_MTextEdit::testValidator()
}
+void Ut_MTextEdit::testValidatorSelectionRemoval_data()
+{
+ QTest::addColumn<int>("selectionRemovingKey");
+
+ QTest::newRow("removing selection with backspace") << static_cast<int>(Qt::Key_Backspace);
+ QTest::newRow("removing selection with delete") << static_cast<int>(Qt::Key_Delete);
+}
+
+void Ut_MTextEdit::testValidatorSelectionRemoval()
+{
+ QFETCH(int, selectionRemovingKey);
+
+ m_appWindow->scene()->addItem(m_subject.get());
+
+ QRegExpValidator abValidator(QRegExp("ab"), 0);
+
+ m_subject->setValidator(&abValidator);
+ m_subject->setText("ab");
+ QCOMPARE(m_subject->text(), QString("ab"));
+
+ // Select "a" and delete it. The result "b" should not be acceptable nor
+ // plausible string, thus original content should still remain.
+ m_subject->setSelection(0, 1);
+
+ QKeyEvent keyEvent(QEvent::KeyPress, selectionRemovingKey, Qt::NoModifier);
+ m_subject->scene()->sendEvent(m_subject.get(), &keyEvent);
+
+ QCOMPARE(m_subject->text(), QString("ab"));
+}
+
+
void Ut_MTextEdit::testClear()
{
// test that clear() works. first set content and then test that after clear the state has reset