From 2c19fa1a574c29e7fd293d5ee789b08c44cf3da2 Mon Sep 17 00:00:00 2001 From: Damian Jansen Date: Wed, 26 Oct 2011 14:13:23 +1000 Subject: [PATCH] System test for TextEdit Basic tests for the QtQuick TextEdit element Change-Id: I532a6b4d3d433ac853248780ee9a6ac03c2f7275 Reviewed-by: Natalia Shubina Reviewed-by: Daniel Kovacic --- tests/system/sys_textedit.qtt | 218 ++++++++++++++++++ tests/testapplications/text/textedit.qml | 268 +++++++++++++++++++++++ 2 files changed, 486 insertions(+) create mode 100644 tests/system/sys_textedit.qtt create mode 100644 tests/testapplications/text/textedit.qml diff --git a/tests/system/sys_textedit.qtt b/tests/system/sys_textedit.qtt new file mode 100644 index 0000000000..632da21a8f --- /dev/null +++ b/tests/system/sys_textedit.qtt @@ -0,0 +1,218 @@ +/**************************************************************************** +** +** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies). +** All rights reserved. +** Contact: Nokia Corporation (qt-info@nokia.com) +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** GNU Lesser General Public License Usage +** This file may be used under the terms of the GNU Lesser General Public +** License version 2.1 as published by the Free Software Foundation and +** appearing in the file LICENSE.LGPL included in the packaging of this +** file. Please review the following information to ensure the GNU Lesser +** General Public License version 2.1 requirements will be met: +** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Nokia gives you certain additional +** rights. These rights are described in the Nokia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU General +** Public License version 3.0 as published by the Free Software Foundation +** and appearing in the file LICENSE.GPL included in the packaging of this +** file. Please review the following information to ensure the GNU General +** Public License version 3.0 requirements will be met: +** http://www.gnu.org/copyleft/gpl.html. +** +** Other Usage +** Alternatively, this file may be used in accordance with the terms and +** conditions contained in a signed written agreement between you and Nokia. +** +** +** +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +//TESTED_COMPONENT=qtdeclarative + +testcase = { + + text_formatting_data: { + // Text type, autotext, plain text, rich text, styled text + BasicText: ["Basic","plain, unformatted red text","plain, unformatted red text","plain, unformatted red text","plain, unformatted red text"], + Rich: ["Rich","bold style","surrounding b,/b tags and no formatting","bold style","bold style"] + }, + + text_formatting: function(texttype,autoformat,plainformat,richformat,styledformat) { + // Test Meta-data + testTitle = "Text Formats"; + testBinary = "qmlscene tests/testapplications/text/textedit.qml"; + testGoal = "Verify that text shows correctly when displayed in different formats"; + testPreconditions = "None"; + testGroups = "BAT"; + + // Test Steps + prompt(twiki('---+++ ' + testTitle + '

+ *Goal:* ' + testGoal + '
+ *Pre-Requisites:* ' + testPreconditions + '
+ *Tested Binary:* ' + testBinary + '
+ | *Step* | *Verification* | + | Run ' + testBinary + ' | Verify that the Text application is displayed | + | Select Text: '+texttype+', Format: AutoText controls | A single line of text is shown | + | | Qt Quick should be rendered with '+autoformat+' | + | Select the Wrap: Word option | A block of text is shown | + | Select the Format: PlainText option | Qt Quick should be shown with '+plainformat+' | + | Select the Format: RichText option | Qt Quick should be shown with '+richformat+' | + | Select the Format: StyledText option | Qt Quick should be shown with '+styledformat+' |')); + }, + + text_wrapping_data: { + // Text type, No wrap, word wrap, wrap anywhere, auto wrap + Basic: ["Basic", + "two lines, wrapped at the newline (Qt Quick consists...)", + "many lines, with no broken words", + "many lines, words broken at the text boundary", + "many lines, with no broken words"], + Long: ["Long", + "one lone line", + "two lines, wrapped at the - (topboxesand...),", + "many lines, wrapped at the boundary", + "many lines, wrapped at the boundary, and specifically the - in set-top"], + Rich: ["Rich", + "two lines, wrapped at the break (Qt Quick consists...)", + "many lines, with no broken words", + "many lines, words broken at the text boundary", + "many lines, with no broken words"] + }, + + text_wrapping: function(texttype,noWrap,wordWrap,anywhereWrap,autoWrap) { + // Test Meta-data + testTitle = "Wrap Modes"; + testBinary = "qmlscene tests/testapplications/text/textedit.qml"; + testGoal = "Verify that text wraps correctly with different wrap methods and text formats"; + testPreconditions = "None"; + testGroups = "BAT"; + + // Test Steps + prompt(twiki('---+++ ' + testTitle + '

+ *Goal:* ' + testGoal + '
+ *Pre-Requisites:* ' + testPreconditions + '
+ *Tested Binary:* ' + testBinary + '
+ | *Step* | *Verification* | + | Run ' + testBinary + ' | Verify that the Text application is displayed | + | Select Text: '+texttype+', Format: AutoText controls | Verify '+noWrap+' is displayed | + | Select the Wrap: Word option | Verify '+wordWrap+' is displayed | + | Select the Wrap: Anywhere option | Verify '+anywhereWrap+' is displayed | + | Select the Wrap: Auto option | Verify '+autoWrap+' is displayed |')); + }, + + text_styling_data: { + // Text type + Basic: ["Basic"], + Long: ["Long"], + Rich: ["Rich"] + }, + + text_styling: function(texttype) { + // Test Meta-data + testTitle = "Style Effects"; + testBinary = "qmlscene tests/testapplications/text/textedit.qml"; + testGoal = "Verify that styling (underline, strikeout etc) works as intended"; + testPreconditions = "None"; + testGroups = "BAT"; + + // Test Steps + prompt(twiki('---+++ ' + testTitle + '

+ *Goal:* ' + testGoal + '
+ *Pre-Requisites:* ' + testPreconditions + '
+ *Tested Binary:* ' + testBinary + '
+ | *Step* | *Verification* | + | Run ' + testBinary + ' | Verify that the Text application is displayed | + | Select Text: '+texttype+', Wrap: WordWrap | Verify the text is displayed, wrapped if necessary | + | Select the U_Line: On option | Verify an underline is drawn under each character | + | Select the Strike: On option | Verify a strikethrough is drawn through each character |')); + }, + + select_text: function() + { + // Test meta data + testTitle = "Text Selection"; + testBinary = "qmlscene tests/testapplications/text/text.qml"; + testGoal = "Verify text can be selected via various methods"; + testPreconditions = "None"; + testGroups = "BAT"; + + // Test Steps + prompt(twiki('---+++ ' + testTitle + '

+ *Goal:* ' + testGoal + '
+ *Pre-Requisites:* ' + testPreconditions + '
+ *Tested Binary:* ' + testBinary + '
+ + | *Step* | *Verification* | + | Execute '+testBinary+' | "The TextInput item displays an editable line of text." is displayed | + | Select the Text: Short option | "Hello World" is shown | + | Press the Select Word button | World is selected | + | Press the Select All button | Hello World is selected | + | Press the Select None button | No text is selected | + | Select the Mouse: On option | | + | Drag over some text | Only that text is selected. On a touchscreen only device the virtual keyboard may show | + | Select the Mouse: Off option | | + | Press the Select None button | No text is selected | + | Drag over some text | No text is selected. On a touchscreen only device the virtual keyboard may show | ')); + }, + + cut_copy_and_paste: function() + { + // Test meta data + testTitle = "Cut, copy and paste"; + testBinary = "qmlscene tests/testapplications/text/textedit.qml"; + testGoal = "Verify selected text can be copied/cut to the clipboard, and returned"; + testPreconditions = "None"; + testGroups = "BAT"; + + // Test Steps + prompt(twiki('---+++ ' + testTitle + '

+ *Goal:* ' + testGoal + '
+ *Pre-Requisites:* ' + testPreconditions + '
+ *Tested Binary:* ' + testBinary + '
+ + | *Step* | *Verification* | + | Execute '+testBinary+' | "The TextInput item displays an editable line of text." is displayed | + | Select the Text: Short option | "Hello World" is shown | + | Press the Select All button | Hello World is selected | + | Press the Copy Button | | + | Tap at the end of the text | Text is no longer selected, cursor is at the text end | + | Press the Paste Button | "Hello WorldHello World" is shown | + | Press the Select Word button | World is highlighted | + | Press the Cut button | World is removed from the text | + | Press the Paste button | "Hello WorldHello World" is shown | ')); + }, + + activate_links: function() + { + // Test meta data + testTitle = "Link Activation"; + testBinary = "qmlscene tests/testapplications/text/textedit.qml"; + testGoal = "Verify http links in text can be activated"; + testPreconditions = "None"; + testGroups = "BAT"; + + // Test Steps + prompt(twiki('---+++ ' + testTitle + '

+ *Goal:* ' + testGoal + '
+ *Pre-Requisites:* ' + testPreconditions + '
+ *Tested Binary:* ' + testBinary + '
+ + | *Step* | *Verification* | + | Execute '+testBinary+' | "The TextInput item displays an editable line of text." is displayed | + | Select the Text: Links option | "This is a link..." is shown | + | Tap on the "Qt Docs" text | The border around the TextEdit will become red | ')); + } + +} diff --git a/tests/testapplications/text/textedit.qml b/tests/testapplications/text/textedit.qml new file mode 100644 index 0000000000..a33859b0b8 --- /dev/null +++ b/tests/testapplications/text/textedit.qml @@ -0,0 +1,268 @@ +/**************************************************************************** +** +** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies). +** All rights reserved. +** Contact: Nokia Corporation (qt-info@nokia.com) +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** GNU Lesser General Public License Usage +** This file may be used under the terms of the GNU Lesser General Public +** License version 2.1 as published by the Free Software Foundation and +** appearing in the file LICENSE.LGPL included in the packaging of this +** file. Please review the following information to ensure the GNU Lesser +** General Public License version 2.1 requirements will be met: +** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Nokia gives you certain additional +** rights. These rights are described in the Nokia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU General +** Public License version 3.0 as published by the Free Software Foundation +** and appearing in the file LICENSE.GPL included in the packaging of this +** file. Please review the following information to ensure the GNU General +** Public License version 3.0 requirements will be met: +** http://www.gnu.org/copyleft/gpl.html. +** +** Other Usage +** Alternatively, this file may be used in accordance with the terms and +** conditions contained in a signed written agreement between you and Nokia. +** +** +** +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +import QtQuick 2.0 + +Rectangle { + height: 360; width: 640 + property int intmax: 2147483647 + + Connections { target: pointvalue; onReset: { texteditelement.font.pointSize = 12 } } + + Item { + id: textpanel + height: 360 + width: 440 + TextEdit { + id: texteditelement + height: parent.height - 20; width: parent.width - 20 + anchors.centerIn: parent + + text: { textvalue.model.get(textvalue.currentIndex).value } + textFormat: { formatvalue.model.get(formatvalue.currentIndex).value } + color: { colorvalue.model.get(colorvalue.currentIndex).value } + font.bold: { boldvalue.model.get(boldvalue.currentIndex).value } + font.italic: { italicsvalue.model.get(italicsvalue.currentIndex).value } + font.capitalization: { capsvalue.model.get(capsvalue.currentIndex).value } + font.family: { familyvalue.model.get(familyvalue.currentIndex).value } + font.strikeout: strikeoutvalue.currentIndex + font.underline: underlinevalue.currentIndex + font.letterSpacing: { lspacingvalue.model.get(lspacingvalue.currentIndex).value } + font.wordSpacing: { wspacingvalue.model.get(wspacingvalue.currentIndex).value } + font.weight: { weightvalue.model.get(weightvalue.currentIndex).value } + font.pointSize: { pointvalue.model.get(pointvalue.currentIndex).value } + font.pixelSize: { pixelvalue.model.get(pixelvalue.currentIndex).value } + horizontalAlignment: { halignvalue.model.get(halignvalue.currentIndex).value } + verticalAlignment: { valignvalue.model.get(valignvalue.currentIndex).value } + wrapMode: { wrapvalue.model.get(wrapvalue.currentIndex).value } + smooth: { smoothvalue.model.get(smoothvalue.currentIndex).value } + selectByMouse: { mousevalue.model.get(mousevalue.currentIndex).value } + onLinkActivated: { bordercolor.border.color = "red" } + Rectangle { id: bordercolor; color: "transparent"; border.color: "green"; anchors.fill: parent } + } + + Text { + id: infopanel + anchors { left: parent.left; leftMargin: 10; bottom: parent.bottom } + height: 150; color: "black"; width: 150 + text: + "LineCount: "+texteditelement.lineCount+ + "\nPaintedHeight/Width: "+texteditelement.paintedHeight+"/"+texteditelement.paintedWidth+ + "\nPointSize: "+texteditelement.font.pointSize+"\nPixelSize: "+texteditelement.font.pixelSize+ + "\nCan Paste: "+texteditelement.canPaste + } + Row { + id: selectionbuttons + height:40 + width: 300 + anchors.right: texteditelement.right; anchors.bottom: texteditelement.bottom + Button { buttontext: "Select Word"; width: parent.width/3; onClicked: { texteditelement.selectWord() } } + Button { buttontext: "Select All"; width: parent.width/3; onClicked: { texteditelement.selectAll() } } + Button { buttontext: "Select None"; width: parent.width/3; onClicked: { texteditelement.deselect() } } + } + Row { + height:40 + width: 300 + anchors.right: texteditelement.right; anchors.bottom: selectionbuttons.top + Button { buttontext: "Cut"; width: parent.width/3; onClicked: { texteditelement.cut() } } + Button { buttontext: "Copy"; width: parent.width/3; onClicked: { texteditelement.copy() } } + Button { buttontext: "Paste"; width: parent.width/3; onClicked: { texteditelement.paste() } } + } + } + + Item { + id: controlpanel + width: 200; height: parent.height + anchors.right: parent.right + Rectangle { anchors.fill: parent; color: "transparent"; border.color: "black" } + ListView { id: controls; model: controlsmodel; anchors.fill: parent; clip: true; cacheBuffer: 500 } + VisualItemModel { + id: controlsmodel + ControlView { + id: textvalue + controlname: "Text" + model: textmodel + ListModel { id: textmodel } + Component.onCompleted: { + textmodel.append({ "name": "Basic", + "value": "Qt Quick is a collection of technologies that are designed to help developers create the kind of intuitive, "+ + "modern, fluid user interfaces that are increasingly used on mobile phones, media players, set-top boxes and other "+ + "portable devices."+texteditelement.newline+ + "Qt Quick consists of a rich set of user interface elements, a declarative language for describing user interfaces "+ + "and a language runtime.\n"+ + "A collection of C++ APIs is used to integrate these high level features with classic Qt applications."}); + textmodel.append({ "name": "Short", + "value": "Hello World"}); + textmodel.append({ "name": "Long", + "value": "QtQuickisacollectionoftechnologiesthataredesignedtohelpdeveloperscreatethekindofintuitive,"+ + "modern,fluiduserinterfacesthatareincreasinglyusedonmobilephones,mediaplayers,set-topboxesandother"+ + "portabledevices."}); + textmodel.append({ "name": "Rich", + "value": "Qt Quick is a collection of technologies that are designed to help developers create the kind of intuitive, "+ + "modern, fluid user interfaces that are increasingly used on mobile phones, media players, set-top boxes and other "+ + "portable devices.
"+ + "Qt Quick consists of a rich set of user interface elements, a declarative language for describing user interfaces "+ + "and a language runtime. "+ + "A collection of C++ APIs is used to integrate these high level features with classic Qt applications."}); + textmodel.append({ "name": "Links", + "value": "This is a link - Qt Docs"}); + } + } + ControlView { + id: formatvalue + controlname: "Format" + model: ListModel { ListElement { name: "Auto"; value: Text.AutoText } ListElement { name: "Plain"; value: Text.PlainText } + ListElement { name: "Rich"; value: Text.RichText } ListElement { name: "Styled"; value: Text.StyledText } } } + ControlView { + id: colorvalue + controlname: "Color" + model: ListModel { ListElement { name: "Red"; value: "red" } + ListElement { name: "Green"; value: "green" } ListElement { name: "Blue"; value: "blue" } } + } + ControlView { + id: boldvalue + controlname: "Bold" + model: ListModel { ListElement { name: "Off"; value: false } ListElement { name: "On"; value: true } } + } + ControlView { + id: italicsvalue + controlname: "Italic" + model: ListModel { ListElement { name: "Off"; value: false } ListElement { name: "On"; value: true } } + } + ControlView { + id: capsvalue + controlname: "Cap10n" + model: ListModel { + ListElement { name: "Mixed"; value: Font.MixedCase } ListElement { name: "Upper"; value: Font.AllUppercase } + ListElement { name: "Lower"; value: Font.AllLowercase } ListElement { name: "SmallCaps"; value: Font.SmallCaps } + ListElement { name: "Capitals"; value: Font.Capitalize } + } + } + ControlView { + id: familyvalue + controlname: "Font" + property variant fontfamilies + function setModel() { + familiesmodel.clear(); + for (var i = 0; i < fontfamilies.length; ++i) { + familiesmodel.append({ "name": fontfamilies[i], "value": fontfamilies[i] }); + } + familyvalue.currentIndex = 0; + } + model: familiesmodel + ListModel { id: familiesmodel } + Component.onCompleted: { fontfamilies = Qt.fontFamilies(); setModel(); } + } + ControlView { + id: lspacingvalue + controlname: "LSpacing" + model: ListModel { ListElement { name: "0"; value: 0 } ListElement { name: "1"; value: 1 } ListElement { name: "2.5"; value: 2.5 } } } + ControlView { + id: wspacingvalue + controlname: "WSpacing" + model: ListModel { ListElement { name: "-1"; value: -1 } ListElement { name: "8"; value: 8 } ListElement { name: "20"; value: 20 } } } + ControlView { + id: pixelvalue + controlname: "Pixel" + model: ListModel { ListElement { name: "-1"; value: -1 } ListElement { name: "8"; value: 8 } ListElement { name: "20"; value: 20 } } } + ControlView { + id: pointvalue + controlname: "Point" + model: ListModel { ListElement { name: "-1"; value: -1 } ListElement { name: "8"; value: 8 } ListElement { name: "20"; value: 20 } } } + ControlView { + id: strikeoutvalue + controlname: "Strike" + model: ListModel { ListElement { name: "Off"; value: false } ListElement { name: "On"; value: true } } } + ControlView { + id: underlinevalue + controlname: "U_line" + model: ListModel { ListElement { name: "Off"; value: false } ListElement { name: "On"; value: true } } } + ControlView { + id: weightvalue + controlname: "Weight" + model: ListModel { ListElement { name: "Light"; value: Font.Light } ListElement { name: "Normal"; value: Font.Normal } + ListElement { name: "DemiBold"; value: Font.DemiBold } ListElement { name: "Bold"; value: Font.Bold } + ListElement { name: "Black"; value: Font.Black } } + Component.onCompleted: { currentIndex = 1 } // set to default + } + ControlView { + id: mousevalue + controlname: "Mouse" + model: ListModel { ListElement { name: "Off"; value: false } ListElement { name: "On"; value: true } } } + ControlView { + id: halignvalue + controlname: "HAlign" + model: ListModel { ListElement { name: "Left"; value: Text.AlignLeft } ListElement { name: "Right"; value: Text.AlignRight } + ListElement { name: "Center"; value: Text.AlignHCenter } ListElement { name: "Justify"; value: Text.AlignJustify } } } + ControlView { + id: valignvalue + controlname: "VAlign" + model: ListModel { ListElement { name: "Top"; value: Text.AlignTop } ListElement { name: "Bottom"; value: Text.AlignBottom } + ListElement { name: "Center"; value: Text.AlignVCenter } } } + ControlView { + id: smoothvalue + controlname: "Smooth" + model: ListModel { ListElement { name: "Off"; value: false } ListElement { name: "On"; value: true } } } + ControlView { + id: wrapvalue + controlname: "Wrap" + model: ListModel { ListElement { name: "None"; value: Text.NoWrap } ListElement { name: "Word"; value: Text.WordWrap } + ListElement { name: "Anywhere"; value: Text.WrapAnywhere } ListElement { name: "Wrap"; value: Text.Wrap } } } + } + } +} + + + + + + + + + + + + + + + + +