summaryrefslogtreecommitdiffstats
path: root/tests/auto/q3table
diff options
context:
space:
mode:
authorLars Knoll <lars.knoll@nokia.com>2009-03-23 10:18:55 +0100
committerSimon Hausmann <simon.hausmann@nokia.com>2009-03-23 10:18:55 +0100
commite5fcad302d86d316390c6b0f62759a067313e8a9 (patch)
treec2afbf6f1066b6ce261f14341cf6d310e5595bc1 /tests/auto/q3table
Long live Qt 4.5!
Diffstat (limited to 'tests/auto/q3table')
-rw-r--r--tests/auto/q3table/.gitignore1
-rw-r--r--tests/auto/q3table/q3table.pro6
-rw-r--r--tests/auto/q3table/tst_q3table.cpp1559
3 files changed, 1566 insertions, 0 deletions
diff --git a/tests/auto/q3table/.gitignore b/tests/auto/q3table/.gitignore
new file mode 100644
index 0000000000..9f19350d81
--- /dev/null
+++ b/tests/auto/q3table/.gitignore
@@ -0,0 +1 @@
+tst_q3table
diff --git a/tests/auto/q3table/q3table.pro b/tests/auto/q3table/q3table.pro
new file mode 100644
index 0000000000..6d96a4e981
--- /dev/null
+++ b/tests/auto/q3table/q3table.pro
@@ -0,0 +1,6 @@
+load(qttest_p4)
+SOURCES += tst_q3table.cpp
+
+QT += qt3support
+
+
diff --git a/tests/auto/q3table/tst_q3table.cpp b/tests/auto/q3table/tst_q3table.cpp
new file mode 100644
index 0000000000..2fab3eba0a
--- /dev/null
+++ b/tests/auto/q3table/tst_q3table.cpp
@@ -0,0 +1,1559 @@
+/****************************************************************************
+**
+** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
+** Contact: Qt Software Information (qt-info@nokia.com)
+**
+** This file is part of the test suite of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** No Commercial Usage
+** This file contains pre-release code and may not be distributed.
+** You may use this file in accordance with the terms and conditions
+** contained in the either Technology Preview License Agreement or the
+** Beta Release License Agreement.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, 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.0, 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.
+**
+** If you are unsure which license is appropriate for your use, please
+** contact the sales department at qt-sales@nokia.com.
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+
+#include <QtTest/QtTest>
+
+#include <q3datetimeedit.h>
+#include <qapplication.h>
+#include <qcombobox.h>
+#include <qdialog.h>
+#include <qlineedit.h>
+#include <q3listbox.h>
+#include <q3table.h>
+#include <qlayout.h>
+
+#define WAITS 1
+#ifdef WAITS
+#endif
+
+Q_DECLARE_METATYPE(QPoint)
+
+//TESTED_FILES=
+
+QT_FORWARD_DECLARE_CLASS(Q3Table)
+
+class tst_Q3Table : public QObject
+{
+ Q_OBJECT
+public:
+ tst_Q3Table();
+
+public slots:
+ void initTestCase();
+ void cleanupTestCase();
+ void init();
+ void cleanup();
+private slots:
+ void setNumRowsColsItems();
+ void setNumRowsColsWidgets();
+
+ void selection();
+ void selectComboTableItem_data();
+ void selectComboTableItem();
+ void pageUpDownNavigation_data();
+ void pageUpDownNavigation();
+ void simpleKeyboardNavigation();
+ void setRowStretchable();
+ void setColumnStretchable();
+ void selectRow_data();
+ void selectRow();
+ void selectColumn_data();
+ void selectColumn();
+ void removeSelection_selectionChanged();
+ void cellNavigation();
+ void cellNavigationWhileEditing();
+ void removeRow_data();
+ void removeRow();
+ void swapRowMemoryLeak();
+ void insertRows_data();
+ void insertRows();
+ void editCheck();
+ void setCellWidgetFocus();
+ void selectionWithMouse_data();
+ void selectionWithMouse();
+ void valueChanged();
+ void numSelections(); // Task specific, moreNumSelections() should cover all bases
+ void dateTimeEdit();
+ void onValueChanged(int, int);
+ void moreNumSelections_data();
+ void moreNumSelections();
+ void headerSwapIconset();
+ void propagateEscapeKey();
+public slots:
+ void selectionWasChanged();
+private:
+ void setupTableItems();
+ Q3Table *testWidget;
+ bool isValueChanged, receivedSelectionChanged;
+};
+
+Q_DECLARE_METATYPE(Q3Table::SelectionMode);
+
+#if 0
+/* XPM */
+static const char *fileopen[] = {
+" 16 13 5 1",
+". c #040404",
+"# c #808304",
+"a c None",
+"b c #f3f704",
+"c c #f3f7f3",
+"aaaaaaaaa...aaaa",
+"aaaaaaaa.aaa.a.a",
+"aaaaaaaaaaaaa..a",
+"a...aaaaaaaa...a",
+".bcb.......aaaaa",
+".cbcbcbcbc.aaaaa",
+".bcbcbcbcb.aaaaa",
+".cbcb...........",
+".bcb.#########.a",
+".cb.#########.aa",
+".b.#########.aaa",
+"..#########.aaaa",
+"...........aaaaa"
+};
+#endif
+
+tst_Q3Table::tst_Q3Table()
+ : isValueChanged( false )
+{
+}
+
+void tst_Q3Table::initTestCase()
+{
+}
+
+void tst_Q3Table::cleanupTestCase()
+{
+}
+
+void tst_Q3Table::init()
+{
+ // Reset the table
+ testWidget = new Q3Table(4,4,0,"testWidget");
+ testWidget->show();
+#ifdef Q_WS_X11
+ qt_x11_wait_for_window_manager( testWidget );
+#endif
+}
+
+void tst_Q3Table::cleanup()
+{
+ testWidget->hide();
+ delete testWidget;
+ testWidget = 0;
+}
+
+/*
+ Function that will popuplate the testWidget with a variety of Q3TableItems
+*/
+
+void tst_Q3Table::setupTableItems()
+{
+ QStringList list;
+ list << "A" << "B";
+ Q3ComboTableItem *cbi = new Q3ComboTableItem(testWidget, list);
+ testWidget->setItem(1, 1, cbi);
+ Q3ComboTableItem *ecbi = new Q3ComboTableItem(testWidget, list, TRUE);
+ testWidget->setItem(1, 2, ecbi);
+ Q3CheckTableItem *chi = new Q3CheckTableItem(testWidget, "Check");
+ testWidget->setItem(2, 2, chi);
+ Q3TableItem *ne = new Q3TableItem(testWidget, Q3TableItem::Never, "Never");
+ testWidget->setItem(0, 0, ne);
+ Q3TableItem *ot = new Q3TableItem(testWidget, Q3TableItem::OnTyping, "On Typing");
+ testWidget->setItem(0, 1, ot);
+ Q3TableItem *wc = new Q3TableItem(testWidget, Q3TableItem::WhenCurrent, "When Current");
+ testWidget->setItem(0, 2, wc);
+ Q3TableItem *al = new Q3TableItem(testWidget, Q3TableItem::Always, "Always");
+ testWidget->setItem(0, 3, al);
+}
+
+#define CELL_TEXT(r, c) QString::number( r ) + "/" + QString::number( c )
+
+void tst_Q3Table::setNumRowsColsItems()
+{
+ Q3Table *t = new Q3Table( 0, "test_table" );
+
+ const int initial_num_rows = 4;
+ const int initial_num_cols = 4;
+
+ const int larger_num_rows = 8;
+ const int larger_num_cols = 8;
+
+ const int smaller_num_rows = 3;
+ const int smaller_num_cols = 3;
+
+ t->setNumRows( initial_num_cols );
+ t->setNumCols( initial_num_cols );
+
+ QCOMPARE( t->numRows(), initial_num_rows );
+ QCOMPARE( t->numCols(), initial_num_cols );
+
+ int r, c;
+ for ( r = 0; r < initial_num_rows; ++r ) {
+ for ( c = 0; c < initial_num_cols; ++c ) {
+ t->setText( r, c, CELL_TEXT( r, c ) );
+ }
+ }
+
+ for ( r = 0; r < initial_num_rows; ++r ) {
+ for ( c = 0; c < initial_num_cols; ++c ) {
+ QCOMPARE( t->text( r, c ), CELL_TEXT( r, c ) );
+ }
+ }
+
+ t->setNumRows( larger_num_rows );
+
+ for ( r = 0; r < larger_num_rows; ++r ) {
+ for ( c = 0; c < initial_num_cols; ++c ) {
+ if ( r < initial_num_rows && c < initial_num_cols ) {
+ QCOMPARE( t->text( r, c ), CELL_TEXT( r, c ) );
+ } else {
+ QCOMPARE( t->text( r, c ), QString() );
+ }
+ }
+ }
+
+ t->setNumCols( larger_num_cols );
+
+ for ( r = 0; r < larger_num_rows; ++r ) {
+ for ( c = 0; c < larger_num_cols; ++c ) {
+ if ( r < initial_num_rows && c < initial_num_cols ) {
+ QCOMPARE( t->text( r, c ), CELL_TEXT( r, c ) );
+ } else {
+ QCOMPARE( t->text( r, c ), QString() );
+ }
+ }
+ }
+
+ t->setNumRows( smaller_num_rows );
+
+ for ( r = 0; r < smaller_num_rows; ++r ) {
+ for ( c = 0; c < initial_num_cols; ++c ) {
+ QCOMPARE( t->text( r, c ), CELL_TEXT( r, c ) );
+ }
+ }
+
+ t->setNumCols( smaller_num_cols );
+
+ for ( r = 0; r < smaller_num_rows; ++r ) {
+ for ( c = 0; c < smaller_num_cols; ++c ) {
+ QCOMPARE( t->text( r, c ), CELL_TEXT( r, c ) );
+ }
+ }
+
+ delete t;
+}
+
+void tst_Q3Table::setNumRowsColsWidgets()
+{
+ Q3Table *t = new Q3Table( 0, "test_table" );
+
+ const int initial_num_rows = 4;
+ const int initial_num_cols = 4;
+
+ const int larger_num_rows = 8;
+ const int larger_num_cols = 8;
+
+ const int smaller_num_rows = 3;
+ const int smaller_num_cols = 3;
+
+ t->setNumRows( initial_num_cols );
+ t->setNumCols( initial_num_cols );
+
+ QCOMPARE( t->numRows(), initial_num_rows );
+ QCOMPARE( t->numCols(), initial_num_cols );
+
+ int r, c;
+
+ for ( r = 0; r < initial_num_rows; ++r ) {
+ for ( c = 0; c < initial_num_cols; ++c ) {
+ t->setCellWidget( r, c, new QWidget( t, CELL_TEXT( r, c ) ) );
+ }
+ }
+
+ for ( r = 0; r < initial_num_rows; ++r ) {
+ for ( c = 0; c < initial_num_cols; ++c ) {
+ QCOMPARE( QString( t->cellWidget( r, c )->name() ), CELL_TEXT( r, c ) );
+ }
+ }
+
+ t->setNumRows( larger_num_rows );
+
+ for ( r = 0; r < larger_num_rows; ++r ) {
+ for ( c = 0; c < initial_num_cols; ++c ) {
+ if ( r < initial_num_rows && c < initial_num_cols ) {
+ QCOMPARE( QString( t->cellWidget( r, c )->name() ), CELL_TEXT( r, c ) );
+ } else {
+ QCOMPARE( t->cellWidget( r, c ), (QWidget*)0 );
+ }
+ }
+ }
+
+ t->setNumCols( larger_num_cols );
+
+ for ( r = 0; r < larger_num_rows; ++r ) {
+ for ( c = 0; c < larger_num_cols; ++c ) {
+ if ( r < initial_num_rows && c < initial_num_cols ) {
+ QCOMPARE( QString( t->cellWidget( r, c )->name() ), CELL_TEXT( r, c ) );
+ } else {
+ QCOMPARE( t->cellWidget( r, c ), (QWidget*)0 );
+ }
+ }
+ }
+
+ t->setNumRows( smaller_num_rows );
+
+ for ( r = 0; r < smaller_num_rows; ++r ) {
+ for ( c = 0; c < initial_num_cols; ++c ) {
+ QCOMPARE( QString( t->cellWidget( r, c )->name() ), CELL_TEXT( r, c ) );
+ }
+ }
+
+ t->setNumCols( smaller_num_cols );
+
+ for ( r = 0; r < smaller_num_rows; ++r ) {
+ for ( c = 0; c < smaller_num_cols; ++c ) {
+ QCOMPARE( QString( t->cellWidget( r, c )->name() ), CELL_TEXT( r, c ) );
+ }
+ }
+
+ delete t;
+}
+
+
+void tst_Q3Table::selection()
+{
+ Q3Table *t = new Q3Table( 20, 20, 0, "test_table" );
+
+ t->selectCells( 0, 0, 50, 50 );
+
+ Q3TableSelection sel( 60, 60, 100, 100 );
+ t->addSelection( sel );
+
+ t->show();
+ QCOMPARE( t->numSelections(), 2 );
+ delete t;
+}
+
+void tst_Q3Table::selectComboTableItem_data()
+{
+ QTest::addColumn<bool>("editable");
+
+ QTest::newRow( "editable" ) << TRUE;
+ QTest::newRow( "non-editable" ) << FALSE;
+
+}
+
+class MyTable : public Q3Table
+{
+ // Conveience subclass used to be able to call isEditing()
+public:
+ MyTable(int rows,int cols,QWidget *parent = 0,const char *name = 0)
+ : Q3Table(rows,cols,parent,name) {}
+ bool isEditing() {
+ return Q3Table::isEditing();
+ }
+};
+
+void tst_Q3Table::selectComboTableItem()
+{
+// #if QT_VERSION >= 0x030100
+#if 0
+ MyTable table(4,4,0,"subclassTestWidget");
+ // Test for task #25026
+ QFETCH( bool, editable );
+
+ QStringList strings;
+ strings << "One" << "Two" << "Three" << "Four";
+ QComboTableItem *cbi = new QComboTableItem(testWidget,strings,editable);
+ table.setItem(0,0,cbi);
+ table.hide();
+ table.show();
+ QComboBox *cb;
+ if ( !editable )
+ cb = (QComboBox*)table.viewport()->child("qt_editor_cb","QComboBox");
+ else
+ cb = (QComboBox*)table.cellWidget(0,0);
+ QVERIFY( cb );
+ QCOMPARE(table.text(0,0),QString("One"));
+ QTest::mouseClick(cb,QtTestCase::LeftButton,QtTestCase::NoButton,QPoint(cb->width()-7,cb->height()-5));
+ QVERIFY(cb->listBox()->isVisible());
+ QTest::mouseClick(cb->listBox()->viewport(),QtTestCase::LeftButton,QtTestCase::NoButton,QPoint(5,cb->listBox()->height()-5));
+ QCOMPARE(table.text(0,0),QString("Four"));
+
+ // Ensure the edit is accepted
+ QTest::mouseClick(table.viewport(),QtTestCase::LeftButton,QtTestCase::NoButton,QPoint(table.width()-10,table.height()-10));
+ QVERIFY(!table.isEditing());
+ QCOMPARE(table.text(0,0),QString("Four"));
+
+ // Now check that Escape will revert any changes
+ QTest::mouseClick(cb,QtTestCase::LeftButton,QtTestCase::NoButton,QPoint(cb->width()-7,cb->height()-5));
+ QVERIFY(cb->listBox()->isVisible());
+ QTest::mouseClick(cb->listBox()->viewport(),QtTestCase::LeftButton,QtTestCase::NoButton,QPoint(5,5));
+ QCOMPARE(cb->currentText(),QString("One"));
+ QTest::keyClick(cb,Qt::Key_Escape);
+ QVERIFY(!table.isEditing());
+ QCOMPARE(table.text(0,0),QString("Four"));
+#else
+ QSKIP("This test will fail at the moment since the way qtestlib iss handling mouse events is broken",SkipAll);
+#endif
+}
+
+void tst_Q3Table::pageUpDownNavigation_data()
+{
+ QTest::addColumn<Q3Table::SelectionMode>("selectionMode");
+ QTest::addColumn<bool>("activeSelection");
+ QTest::addColumn<int>("pgUpTopRow");
+ QTest::addColumn<int>("pgUpBottomRow");
+ QTest::addColumn<int>("pgUpLeftCol");
+ QTest::addColumn<int>("pgUpRightCol");
+ QTest::addColumn<int>("pgDownTopRow");
+ QTest::addColumn<int>("pgDownBottomRow");
+ QTest::addColumn<int>("pgDownLeftCol");
+ QTest::addColumn<int>("pgDownRightCol");
+
+ QTest::newRow("NoSelection") << Q3Table::NoSelection << FALSE << -1 << -1 << -1 << -1 << -1 << -1 << -1 << -1;
+ QTest::newRow("SingleSelection") << Q3Table::Single << FALSE << -1 << -1 << -1 << -1 << -1 << -1 << -1 << -1;
+ QTest::newRow("MultiSelection") << Q3Table::Multi << FALSE << -1 << -1 << -1 << -1 << -1 << -1 << -1 << -1;
+ QTest::newRow("SingleRowSelection") << Q3Table::SingleRow << TRUE << 0 << 0 << 0 << 3 << 3 << 3 << 0 << 3;
+ QTest::newRow("MultiRowSelection") << Q3Table::MultiRow << TRUE << 0 << 0 << 0 << 3 << 3 << 3 << 0 << 3;
+}
+
+void tst_Q3Table::pageUpDownNavigation()
+{
+ setupTableItems();
+
+ // Test for task #25842
+ QFETCH(Q3Table::SelectionMode,selectionMode);
+ QFETCH(bool,activeSelection);
+ QFETCH(int,pgUpTopRow);
+ QFETCH(int,pgUpBottomRow);
+ QFETCH(int,pgUpLeftCol);
+ QFETCH(int,pgUpRightCol);
+ QFETCH(int,pgDownTopRow);
+ QFETCH(int,pgDownBottomRow);
+ QFETCH(int,pgDownLeftCol);
+ QFETCH(int,pgDownRightCol);
+
+ // Needed to force the table to have "no selection"
+ testWidget->setCurrentCell(-1,-1);
+
+ testWidget->setSelectionMode(selectionMode);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(testWidget->viewport(),Qt::Key_PageUp);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ Q3TableSelection ts = testWidget->selection(testWidget->currentSelection());
+ QVERIFY(ts.isActive() == activeSelection);
+ if (activeSelection) {
+ QVERIFY(ts.topRow() == pgUpTopRow);
+ QVERIFY(ts.bottomRow() == pgUpBottomRow);
+ QVERIFY(ts.leftCol() == pgUpLeftCol);
+ QVERIFY(ts.rightCol() == pgUpRightCol);
+ }
+ QTest::keyClick(testWidget->viewport(),Qt::Key_PageDown);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ ts = testWidget->selection(testWidget->currentSelection());
+ QVERIFY(ts.isActive() == activeSelection);
+ if (activeSelection) {
+ QVERIFY(ts.topRow() == pgDownTopRow);
+ QVERIFY(ts.bottomRow() == pgDownBottomRow);
+ QVERIFY(ts.leftCol() == pgDownLeftCol);
+ QVERIFY(ts.rightCol() == pgDownRightCol);
+ }
+}
+
+void tst_Q3Table::simpleKeyboardNavigation()
+{
+ QWidget *w;
+
+ // Test for task #24726
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::mouseClick(testWidget->viewport(),
+ Qt::LeftButton, Qt::NoModifier,
+ QPoint(testWidget->columnPos(0) + 3, testWidget->rowPos(0) + 3));
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QCOMPARE(testWidget->currentColumn(), 0);
+ QCOMPARE(testWidget->currentRow(), 0);
+
+ QTest::keyClick(testWidget->viewport(), Qt::Key_T);
+
+ // After the first keyevent, the table starts editing the item
+ w = testWidget->cellWidget(0, 0);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QTest::keyClick(w, Qt::Key_E);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QTest::keyClick(w, Qt::Key_C);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QTest::keyClick(w, Qt::Key_H);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+#ifdef Q_WS_MAC // Mac lineedits grab Up and Down
+ QTest::keyClick(w, Qt::Key_Return);
+#else
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Down);
+#endif
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QCOMPARE(testWidget->text(0,0), QString("tech"));
+ QCOMPARE(testWidget->currentColumn(), 0);
+ QCOMPARE(testWidget->currentRow(), 1);
+
+ QTest::keyClick(testWidget->viewport(), Qt::Key_A);
+ w = testWidget->cellWidget(0, 1);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QTest::keyClick(w, Qt::Key_B);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QTest::keyClick(w, Qt::Key_C);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+#ifdef Q_WS_MAC // Mac lineedits grab Up and Down
+ QTest::keyClick(w, Qt::Key_Return);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Up);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Up);
+#else
+ QTest::keyClick(w, Qt::Key_Up);
+#endif
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QCOMPARE(testWidget->text(1,0), QString("abc"));
+ QCOMPARE(testWidget->currentColumn(), 0);
+ QCOMPARE(testWidget->currentRow(), 0);
+ w = testWidget->cellWidget(0, 0);
+
+ QTest::keyClick(w, Qt::Key_D);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QTest::keyClick(w, Qt::Key_E);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QTest::keyClick(w, Qt::Key_F);
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+#ifdef Q_WS_MAC // Mac lineedits grab Up and Down
+ QTest::keyClick(w, Qt::Key_Return);
+#else
+ QTest::keyClick(w, Qt::Key_Down);
+#endif
+
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QCOMPARE(testWidget->text(0,0), QString("def"));
+ QCOMPARE(testWidget->currentColumn(), 0);
+ QCOMPARE(testWidget->currentRow(), 1);
+}
+
+void tst_Q3Table::setRowStretchable()
+{
+#if 1
+ QSKIP("This test currently fails on all versions", SkipAll);
+#endif
+ // Part of test for task 24471
+ // Only tests TRUE case, need FALSE case written
+ // Also needs to test the case where the user tries to resize it
+ testWidget->setRowStretchable(0,TRUE);
+ testWidget->show();
+ int height = testWidget->rowHeight(0);
+ testWidget->setRowHeight(0,height * 2);
+ QCOMPARE(height,testWidget->rowHeight(0));
+}
+
+void tst_Q3Table::setColumnStretchable()
+{
+#if 1
+ QSKIP("This test currently fails on all versions", SkipAll);
+#endif
+ // Part of test for task 24471
+ // Only tests TRUE case, need FALSE case written
+ // Also needs to test the case where the user tries to resize it
+ testWidget->setColumnStretchable(0,TRUE);
+ testWidget->show();
+ int width = testWidget->columnWidth(0);
+ testWidget->setColumnWidth(0,width * 2);
+ QCOMPARE(width,testWidget->columnWidth(0));
+}
+
+void tst_Q3Table::selectRow_data()
+{
+ QTest::addColumn<Q3Table::SelectionMode>("selectionMode");
+ QTest::addColumn<bool>("activeSelection");
+ QTest::addColumn<int>("topRow");
+ QTest::addColumn<int>("bottomRow");
+ QTest::addColumn<int>("leftCol");
+ QTest::addColumn<int>("rightCol");
+
+ QTest::newRow("NoSelection") << Q3Table::NoSelection << TRUE << 1 << 1 << 0 << 3;
+ QTest::newRow("SingleSelection") << Q3Table::Single << TRUE << 1 << 1 << 0 << 3;
+ QTest::newRow("MultiSelection") << Q3Table::Multi << TRUE << 1 << 1 << 0 << 3;
+ QTest::newRow("SingleRowSelection") << Q3Table::SingleRow << TRUE << 1 << 1 << 0 << 3;
+ QTest::newRow("MultiRowSelection") << Q3Table::MultiRow << TRUE << 1 << 1 << 0 << 3;
+}
+
+void tst_Q3Table::selectRow()
+{
+ QFETCH(Q3Table::SelectionMode,selectionMode);
+ QFETCH(bool,activeSelection);
+ QFETCH(int,topRow);
+ QFETCH(int,bottomRow);
+ QFETCH(int,leftCol);
+ QFETCH(int,rightCol);
+
+ testWidget->clearSelection();
+ testWidget->setSelectionMode(selectionMode);
+ testWidget->selectRow(1);
+
+ int current = testWidget->currentSelection();
+ QVERIFY(current != -1);
+ Q3TableSelection ts = testWidget->selection(current);
+
+ QCOMPARE(ts.isActive(), activeSelection);
+
+ if (activeSelection) {
+ QCOMPARE(ts.topRow(), topRow);
+ QCOMPARE(ts.bottomRow(), bottomRow);
+ QCOMPARE(ts.leftCol(), leftCol);
+ QCOMPARE(ts.rightCol(), rightCol);
+ }
+
+ // make sure selection is cleared
+ testWidget->clearSelection();
+ current = testWidget->currentSelection();
+ QVERIFY(current == -1);
+
+ testWidget->selectRow(1);
+ QEXPECT_FAIL("SingleRowSelection", "This currently fails in all versions", Abort);
+ QVERIFY(testWidget->numSelections() > 0); // selectRow in SingleRowSelection doesn't select anything (see qtable.cpp)
+ current = testWidget->currentSelection();
+ QVERIFY(current != -1);
+ ts = testWidget->selection(current);
+
+ QCOMPARE(ts.isActive(), activeSelection);
+
+ if (activeSelection) {
+ QCOMPARE(ts.topRow(), topRow);
+ QCOMPARE(ts.bottomRow(), bottomRow);
+ QCOMPARE(ts.leftCol(), leftCol);
+ QCOMPARE(ts.rightCol(), rightCol);
+ }
+}
+
+void tst_Q3Table::selectColumn_data()
+{
+ QTest::addColumn<Q3Table::SelectionMode>("selectionMode");
+ QTest::addColumn<bool>("activeSelection");
+ QTest::addColumn<int>("topRow");
+ QTest::addColumn<int>("bottomRow");
+ QTest::addColumn<int>("leftCol");
+ QTest::addColumn<int>("rightCol");
+
+ QTest::newRow("NoSelection") << Q3Table::NoSelection << TRUE << 0 << 3 << 1 << 1;
+ QTest::newRow("SingleSelection") << Q3Table::Single << TRUE << 0 << 3 << 1 << 1;
+ QTest::newRow("MultiSelection") << Q3Table::Multi << TRUE << 0 << 3 << 1 << 1;
+ QTest::newRow("SingleRowSelection") << Q3Table::SingleRow << TRUE << 0 << 3 << 1 << 1;
+ QTest::newRow("MultiRowSelection") << Q3Table::MultiRow << TRUE << 0 << 3 << 1 << 1;
+}
+
+void tst_Q3Table::selectColumn()
+{
+ QFETCH(Q3Table::SelectionMode,selectionMode);
+ QFETCH(bool,activeSelection);
+ QFETCH(int,topRow);
+ QFETCH(int,bottomRow);
+ QFETCH(int,leftCol);
+ QFETCH(int,rightCol);
+
+ testWidget->setSelectionMode(selectionMode);
+ testWidget->selectColumn(1);
+ Q3TableSelection ts = testWidget->selection(testWidget->currentSelection());
+ QCOMPARE(ts.isActive(), activeSelection);
+
+ if (activeSelection) {
+ QCOMPARE(ts.topRow(), topRow);
+ QCOMPARE(ts.bottomRow(), bottomRow);
+ QCOMPARE(ts.leftCol(), leftCol);
+ QCOMPARE(ts.rightCol(), rightCol);
+ }
+
+ testWidget->clearSelection();
+ ts = testWidget->selection(testWidget->currentSelection());
+ QVERIFY(!ts.isActive());
+
+ testWidget->selectColumn(1);
+ ts = testWidget->selection(testWidget->currentSelection());
+ QCOMPARE(ts.isActive(), activeSelection);
+ if (activeSelection) {
+ QCOMPARE(ts.topRow(), topRow);
+ QCOMPARE(ts.bottomRow(), bottomRow);
+ QCOMPARE(ts.leftCol(), leftCol);
+ QCOMPARE(ts.rightCol(), rightCol);
+ }
+}
+
+void tst_Q3Table::cellNavigation()
+{
+#if 0
+ setupTableItems();
+#endif
+
+ testWidget->setCurrentCell(0, 0);
+
+ // Check tab key first
+ QCOMPARE(testWidget->currentRow(), 0);
+ QCOMPARE(testWidget->currentColumn(), 0);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Tab);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QCOMPARE(testWidget->currentRow(), 0);
+ QCOMPARE(testWidget->currentColumn(), 1);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Tab);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QCOMPARE(testWidget->currentRow(), 0);
+ QCOMPARE(testWidget->currentColumn(), 2);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Tab);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ // One more, and it should stay where it is
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Tab);
+ QCOMPARE(testWidget->currentRow(), 0);
+ QCOMPARE(testWidget->currentColumn(), 3);
+
+ testWidget->setCurrentCell(3,3);
+
+ // Now check backtab key
+ QCOMPARE(testWidget->currentRow(), 3);
+ QCOMPARE(testWidget->currentColumn(), 3);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_BackTab);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QCOMPARE(testWidget->currentRow(), 3);
+ QCOMPARE(testWidget->currentColumn(), 2);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_BackTab);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QCOMPARE(testWidget->currentRow(), 3);
+ QCOMPARE(testWidget->currentColumn(), 1);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_BackTab);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ // One more, and it should stay where it is
+ QTest::keyClick(testWidget->viewport(), Qt::Key_BackTab);
+ QCOMPARE(testWidget->currentRow(), 3);
+ QCOMPARE(testWidget->currentColumn(), 0);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ testWidget->setCurrentCell(0, 0);
+
+ // Now check enter key
+ for (int row = 0; row < 3; ++row) {
+ QCOMPARE(testWidget->currentRow(), row);
+ QCOMPARE(testWidget->currentColumn(), 0);
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Enter);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ }
+ // One more, and it should go to back
+ QTest::keyClick(testWidget->viewport(), Qt::Key_Enter);
+ QCOMPARE(testWidget->currentRow(), 0);
+ QCOMPARE(testWidget->currentColumn(), 1);
+}
+
+void tst_Q3Table::cellNavigationWhileEditing()
+{
+ // This is basically the cellNavigation() test
+ // with the current cell being edited before
+ // navigation.
+#if 0
+ setupTableItems();
+
+ int a, b;
+ QPoint contentPos;
+ // Check tab key first
+ for (a = 0;a < 4;a++) {
+ for (b = 0;b < 4;b++) {
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ contentPos = QPoint(testWidget->columnPos(b) + 3, testWidget->rowPos(a) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+ if(a == 0 && b == 2) // On typing item
+ QTest::keyClick(testWidget->viewport(), Qt::Key_A);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Tab);
+ }
+ }
+ // One more should put it at the beginning again
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Tab);
+ QCOMPARE(testWidget->currentRow(),0);
+ QCOMPARE(testWidget->currentColumn(),0);
+
+ testWidget->setCurrentCell(3,3);
+ // Now check backtab key
+ for (a = 3;a > -1;a--) {
+ for (b = 3;b > -1;b--) {
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ contentPos = QPoint(testWidget->columnPos(b) + 3, testWidget->rowPos(a) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+ if(a == 0 && b == 2) // On typing item
+ QTest::keyClick(testWidget->viewport(), Qt::Key_A);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_BackTab);
+ }
+ }
+ // One more should put it at the end again
+ QTest::keyClick(testWidget->viewport(),Qt::Key_BackTab);
+ QCOMPARE(testWidget->currentRow(),3);
+ QCOMPARE(testWidget->currentColumn(),3);
+
+ testWidget->setCurrentCell(0,0);
+ // Now check enter key
+ for (a = 0;a < 4;a++) {
+ for (b = 0;b < 4;b++) {
+ QCOMPARE(testWidget->currentColumn(),a);
+ QCOMPARE(testWidget->currentRow(),b);
+ contentPos = QPoint(testWidget->columnPos(a) + 3, testWidget->rowPos(b) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+ if(a == 0 && b == 2) // On typing item
+ QTest::keyClick(testWidget->viewport(), Qt::Key_A);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Enter);
+ }
+ }
+ // One more should put it at the beginning again
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Enter);
+ QCOMPARE(testWidget->currentRow(),0);
+ QCOMPARE(testWidget->currentColumn(),0);
+
+ // Reset it back to the top
+ contentPos = QPoint(testWidget->columnPos(0) + 3, testWidget->rowPos(0) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+
+ // Now check down key
+ for (a = 0;a < 4;a++) {
+ for (b = 0;b < 4;b++) {
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ contentPos = QPoint(testWidget->columnPos(b) + 3, testWidget->rowPos(a) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+ if(a == 0 && b == 2) // On typing item
+ QTest::keyClick(testWidget->viewport(), Qt::Key_A);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Down);
+ if (a == 3) {
+ // Check it hasn't moved from the bottom even
+ // after clicking down
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ // Put it in correct place for next check
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Home);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Right);
+ }
+ }
+ }
+
+ // Start at the bottom now
+ contentPos = QPoint(testWidget->columnPos(0) + 3, testWidget->rowPos(3) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+
+ // Now check up key
+ for (a = 3;a > -1;a--) {
+ for (b = 3;b > -1;b--) {
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ contentPos = QPoint(testWidget->columnPos(b) + 3, testWidget->rowPos(a) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+ if(a == 0 && b == 2) // On typing item
+ QTest::keyClick(testWidget->viewport(), Qt::Key_A);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Up);
+ if (a == 0) {
+ // Check it hasn't moved from the bottom even
+ // after clicking down
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ // Put it in correct place for next check
+ QTest::keyClick(testWidget->viewport(),Qt::Key_End);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Right);
+ }
+ }
+ }
+
+ // Reset it back to the top
+ contentPos = QPoint(testWidget->columnPos(0) + 3, testWidget->rowPos(0) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+
+ // Now check right key
+ for (a = 0;a < 4;a++) {
+ for (b = 0;b < 4;b++) {
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ contentPos = QPoint(testWidget->columnPos(b) + 3, testWidget->rowPos(a) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+ if(a == 0 && b == 2) // On typing item
+ QTest::keyClick(testWidget->viewport(), Qt::Key_A);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Right);
+ if (b == 3) {
+ // Check it hasn't moved from the bottom even
+ // after clicking down
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ // Put it in correct place for next check
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Home);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Down);
+ }
+ }
+ }
+
+ // Start it at the far left
+ contentPos = QPoint(testWidget->columnPos(3) + 3, testWidget->rowPos(0) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+
+ // Now check up key
+ for (a = 3;a > -1;a--) {
+ for (b = 3;b > -1;b--) {
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ contentPos = QPoint(testWidget->columnPos(b) + 3, testWidget->rowPos(a) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoButton,
+ testWidget->contentsToViewport(contentPos));
+ if(a == 0 && b == 2) // On typing item
+ QTest::keyClick(testWidget->viewport(), Qt::Key_A);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Left);
+ if (b == 0) {
+ // Check it hasn't moved from the bottom even
+ // after clicking down
+ QCOMPARE(testWidget->currentRow(),a);
+ QCOMPARE(testWidget->currentColumn(),b);
+ // Put it in correct place for next check
+ QTest::keyClick(testWidget->viewport(),Qt::Key_End);
+ QTest::keyClick(testWidget->viewport(),Qt::Key_Down);
+ }
+ }
+ }
+#else
+ QSKIP( "This test currently fails on all versions", SkipAll);
+#endif
+}
+
+void tst_Q3Table::removeRow_data()
+{
+ QTest::addColumn<Q3Table::SelectionMode>("selectionMode");
+
+ QTest::newRow("NoSelection") << Q3Table::NoSelection;
+ QTest::newRow("SingleSelection") << Q3Table::Single;
+ QTest::newRow("MultiSelection") << Q3Table::Multi;
+ QTest::newRow("SingleRowSelection") << Q3Table::SingleRow;
+ QTest::newRow("MultiRowSelection") << Q3Table::MultiRow;
+}
+
+
+void tst_Q3Table::removeRow()
+{
+ QFETCH(Q3Table::SelectionMode, selectionMode);
+
+#if 1
+ if(selectionMode == Q3Table::SingleRow
+ || selectionMode == Q3Table::MultiRow)
+ QSKIP("removeRow() is expected to fail in SingleRow/MultiRow selection modes in all versions", SkipAll);
+#endif
+ // This tests task 26419
+
+
+ setupTableItems();
+ testWidget->setSelectionMode(selectionMode);
+ for(int a = 3;a > -1;a--) {
+ QPoint contentPos(testWidget->columnPos(0) + 3, testWidget->rowPos(a) + 3);
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoModifier,
+ testWidget->contentsToViewport(contentPos));
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ if (selectionMode != Q3Table::NoSelection) {
+ Q3TableSelection ts = testWidget->selection(testWidget->currentSelection());
+ QVERIFY(ts.isActive());
+ QVERIFY(ts.topRow() == a);
+ QVERIFY(ts.bottomRow() == a);
+ }
+ testWidget->removeRow(a);
+ // a is actually now the number of rows because the row sections are
+ // zero-based
+ QVERIFY(testWidget->numRows() == a);
+ QVERIFY(!testWidget->selection(testWidget->currentSelection()).isActive());
+ }
+}
+
+
+class SwapRowMemoryLeakTableItem : public Q3TableItem
+{
+public:
+ SwapRowMemoryLeakTableItem(Q3Table * table, const QString & text, bool * deletionFlag)
+ : Q3TableItem(table, OnTyping, text)
+ {
+ this->deletionFlag = deletionFlag;
+ }
+
+ ~SwapRowMemoryLeakTableItem()
+ {
+ *deletionFlag = TRUE;
+ }
+
+private:
+ bool * deletionFlag;
+};
+
+
+void tst_Q3Table::swapRowMemoryLeak()
+{
+ //Although this should fail due to code in Q3Table::swapRows() it dose not becuse it is saved
+ //in ~Q3Table
+ Q3Table * quickTable = new Q3Table(2, 1);
+
+
+ bool i1deletionFlag = FALSE;
+ SwapRowMemoryLeakTableItem * i1 = new SwapRowMemoryLeakTableItem(quickTable,"item 1", &i1deletionFlag);
+ quickTable->setItem(0, 0, i1);
+ bool i2deletionFlag = FALSE;
+ SwapRowMemoryLeakTableItem * i2 = new SwapRowMemoryLeakTableItem(quickTable,"item 2", &i2deletionFlag);
+ quickTable->setItem(1, 0, i2);
+
+ quickTable->swapRows(0, 1);
+
+ // quickTable->removeRow(0);
+
+ delete quickTable;
+
+ QVERIFY(i1deletionFlag);
+ QVERIFY(i2deletionFlag);
+}
+
+void tst_Q3Table::insertRows_data()
+{
+ QTest::addColumn<int>("rowToInsertAt");
+ QTest::addColumn<int>("numberOfRowsToInsert");
+
+ QTest::newRow("firstRowOneRow") << 1 << 1;
+ QTest::newRow("secondRowTenRows") << 2 << 10;
+ QTest::newRow("thirdRowNoRows") << 3 << 0;
+ QTest::newRow("zerothRowNegativeRows") << 0 << -1;
+}
+
+void tst_Q3Table::insertRows()
+{
+ QFETCH(int, rowToInsertAt);
+ QFETCH(int, numberOfRowsToInsert);
+
+ int i = 0;
+ for (i = 0;i < 4;i++)
+ testWidget->setText(i, 0, QString("Item %0,0").arg(i));
+
+ testWidget->insertRows(rowToInsertAt, numberOfRowsToInsert);
+ if(numberOfRowsToInsert <= 0) {
+ QVERIFY(testWidget->numRows() == 4);
+ } else {
+ QVERIFY(testWidget->numRows() == 4 + numberOfRowsToInsert);
+ }
+
+ int rowNumber = 0;
+ for (i = 0;i < rowToInsertAt;i++) {
+ QCOMPARE(testWidget->text(i, 0), QString("Item %0,0").arg(rowNumber));
+ rowNumber++;
+ }
+
+ if (numberOfRowsToInsert > 0) {
+ for (i = rowToInsertAt;i < rowToInsertAt + numberOfRowsToInsert;i++)
+ QCOMPARE(testWidget->text(i, 0), QString());
+
+ for (i = rowToInsertAt + numberOfRowsToInsert;i < 4 + numberOfRowsToInsert;i++) {
+ QCOMPARE(testWidget->text(i, 0), QString("Item %0,0").arg(rowNumber));
+ rowNumber++;
+ }
+ }
+}
+
+class EditCheckQ3Table : public Q3Table
+{
+public:
+ int endEditCount;
+ int beginEditCount;
+
+ EditCheckQ3Table(int r, int c, QWidget *parent = 0, const char *name = 0)
+ : Q3Table(r, c, parent, name)
+ {
+ endEditCount = beginEditCount = 0;
+ }
+protected:
+ void endEdit(int row, int col, bool accept, bool replace)
+ {
+ endEditCount++;
+ Q3Table::endEdit(row, col, accept, replace);
+ }
+ QWidget * beginEdit(int row, int col, bool replace)
+ {
+ beginEditCount++;
+ return Q3Table::beginEdit(row, col, replace);
+ }
+};
+
+void tst_Q3Table::editCheck()
+{
+ // Test for task 28086
+#if 0
+ QSKIP("This test currently fails on all versions", SkipAll);
+#endif
+
+ EditCheckQ3Table table(10, 10, 0);
+ table.show();
+ table.setCurrentCell(0, 0);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(table.viewport(), Qt::Key_T);
+ // After the first keyevent, the table starts editing the item
+ QLineEdit *le = qFindChild<QLineEdit *>(testWidget->viewport(), "qt_lineeditor");
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(le, Qt::Key_Enter);
+ le = 0;
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QCOMPARE(table.beginEditCount, 1);
+ QEXPECT_FAIL("", "this fails because endEdit is called for the old current item when we set a new one", Abort);
+ QCOMPARE(table.endEditCount, 1);
+}
+
+void tst_Q3Table::setCellWidgetFocus()
+{
+#define CELLWIDGET_CHEAT 1
+ // Test for task 27683
+ int numRows = testWidget->numRows();
+ int numCols = testWidget->numCols();
+ testWidget->setNumRows(1);
+ testWidget->setNumCols(1);
+#if CELLWIDGET_CHEAT
+ qApp->processEvents();
+#endif
+ QLineEdit *lineedit = new QLineEdit(testWidget);
+ testWidget->setCellWidget(0, 0, lineedit);
+ testWidget->show();
+ qApp->setActiveWindow(testWidget);
+ lineedit->setFocus();
+ QVERIFY(lineedit->hasFocus());
+ testWidget->setNumRows(numRows);
+ testWidget->setNumCols(numCols);
+}
+
+void tst_Q3Table::selectionWithMouse_data()
+{
+ QTest::addColumn<QPoint>("clickPos");
+ QTest::addColumn<Q3Table::SelectionMode>("selectionMode");
+ QTest::addColumn<int>("numSelections");
+ QTest::addColumn<bool>("activeSelection");
+ QTest::addColumn<int>("topRow");
+ QTest::addColumn<int>("bottomRow");
+ QTest::addColumn<int>("leftCol");
+ QTest::addColumn<int>("rightCol");
+
+ QTest::newRow("NoSelection") << QPoint(20, 15) << Q3Table::NoSelection << 0 << FALSE << -1 << -1 << -1 << -1;
+ QTest::newRow("SingleSelection") << QPoint(20, 15) << Q3Table::Single << 1 << TRUE << 0 << 0 << 0 << 0;
+ QTest::newRow("MultiSelection") << QPoint(20, 15) << Q3Table::Multi << 1 << TRUE << 0 << 0 << 0 << 0;
+ QTest::newRow("SingleRowSelection") << QPoint(20, 15) << Q3Table::SingleRow << 1 << TRUE << 0 << 0 << 0 << 3;
+ QTest::newRow("MultiRowSelection") << QPoint(20, 15) << Q3Table::MultiRow << 1 << TRUE << 0 << 0 << 0 << 3;
+}
+
+void tst_Q3Table::selectionWithMouse()
+{
+ QFETCH(QPoint, clickPos);
+ QFETCH(Q3Table::SelectionMode, selectionMode);
+ QFETCH(int, numSelections);
+ QFETCH(bool, activeSelection);
+ QFETCH(int, topRow);
+ QFETCH(int, bottomRow);
+ QFETCH(int, leftCol);
+ QFETCH(int, rightCol);
+
+ testWidget->setSelectionMode((Q3Table::SelectionMode)selectionMode);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::mouseClick(testWidget->viewport(), Qt::LeftButton, Qt::NoModifier, clickPos);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QVERIFY(testWidget->numSelections() == numSelections);
+ Q3TableSelection ts = testWidget->selection(testWidget->currentSelection());
+ QVERIFY(ts.isActive() == activeSelection);
+ if (activeSelection) {
+ QVERIFY(ts.topRow() == topRow);
+ QVERIFY(ts.bottomRow() == bottomRow);
+ QVERIFY(ts.leftCol() == leftCol);
+ QVERIFY(ts.rightCol() == rightCol);
+ }
+}
+
+class TimeTableItem : public Q3TableItem
+{
+public:
+ TimeTableItem(Q3Table *parent=0)
+ : Q3TableItem(parent, Q3TableItem::OnTyping, ""),
+ editorWasTimeEdit(false)
+ { setReplaceable(false); }
+
+ QWidget* createEditor() const
+ {
+ return new Q3TimeEdit(table()->viewport(), "time_edit");
+ }
+
+ void setContentFromEditor(QWidget* widget)
+ {
+ Q3TimeEdit *time_edit = ::qobject_cast<Q3TimeEdit*>(widget);
+ if (!time_edit) {
+ editorWasTimeEdit = false;
+ Q3TableItem::setContentFromEditor(widget);
+ return;
+ }
+ editorWasTimeEdit = true;
+ QTime res = time_edit->time();
+ setText(QString::number(QTime().secsTo(res)));
+ }
+
+ bool editorWasTimeEdit;
+};
+
+void tst_Q3Table::onValueChanged(int, int)
+{
+ isValueChanged = true;
+}
+
+void tst_Q3Table::valueChanged()
+{
+ // task 27496
+ isValueChanged = false;
+ TimeTableItem *ti = new TimeTableItem(testWidget);
+ testWidget->setItem(0, 0, ti);
+ connect(testWidget,SIGNAL(valueChanged(int,int)),this,SLOT(onValueChanged(int,int)));
+ testWidget->show();
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(testWidget->viewport(), Qt::Key_1);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(qApp->focusWidget(), Qt::Key_Enter);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QVERIFY(ti->editorWasTimeEdit);
+ disconnect(testWidget,SIGNAL(valueChanged(int,int)),this,SLOT(onValueChanged(int,int)));
+}
+
+void tst_Q3Table::numSelections()
+{
+ // task 28017
+ int numRows = testWidget->numRows();
+ int numCols = testWidget->numCols();
+ testWidget->setNumRows(10);
+ testWidget->setNumCols(10);
+ for (int i=0;i<10;++i)
+ for (int j=0;j<10;++j)
+ testWidget->setItem(i,j,new Q3TableItem(testWidget,Q3TableItem::OnTyping,"Item"));
+ QCOMPARE(testWidget->numSelections(),0);
+ testWidget->clearSelection();
+ QCOMPARE(testWidget->numSelections(),0);
+ testWidget->selectRow(2);
+ QCOMPARE(testWidget->numSelections(),1);
+ testWidget->selectRow(4);
+ QCOMPARE(testWidget->numSelections(),2);
+ testWidget->selectRow(5);
+ QCOMPARE(testWidget->numSelections(),3);
+ testWidget->clearSelection();
+ QCOMPARE(testWidget->numSelections(),0);
+ testWidget->setNumRows(numRows);
+ testWidget->setNumCols(numCols);
+}
+
+void tst_Q3Table::dateTimeEdit()
+{
+ // task 29002
+ TimeTableItem *ti = new TimeTableItem(testWidget);
+ testWidget->setItem(0, 0, ti);
+ testWidget->show();
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(testWidget->viewport(), Qt::Key_1);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(qApp->focusWidget(), Qt::Key_Enter);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QVERIFY(ti->editorWasTimeEdit);
+}
+
+void tst_Q3Table::moreNumSelections_data()
+{
+ QTest::addColumn<Q3Table::SelectionMode>("selectionMode");
+ QTest::addColumn<int>("numSelectionsBeforeAnyRowClicked");
+ QTest::addColumn<int>("numSelectionsAfter1stRowClicked");
+ QTest::addColumn<int>("numSelectionsAfter3rdRowClicked");
+ QTest::addColumn<int>("numSelectionsAfter3rdRowClickedAgain");
+
+ QTest::newRow("NoSelection") << Q3Table::NoSelection << 0 << 0 << 0 << 0;
+ QTest::newRow("SingleSelection") << Q3Table::Single << 0 << 1 << 1 << 1;
+ QTest::newRow("MultiSelection") << Q3Table::Multi << 0 << 1 << 2 << 2;
+ // in row selection modes the current item is always selected
+ QTest::newRow("SingleRowSelection") << Q3Table::SingleRow << 1 << 1 << 1 << 1;
+ QTest::newRow("MultiRowSelection") << Q3Table::MultiRow << 1 << 1 << 2 << 2;
+}
+
+void tst_Q3Table::moreNumSelections()
+{
+#if 0
+ QFETCH(Q3Table::SelectionMode, selectionMode);
+ QFETCH(int, numSelectionsBeforeAnyRowClicked);
+ QFETCH(int, numSelectionsAfter1stRowClicked);
+ QFETCH(int, numSelectionsAfter3rdRowClicked);
+ QFETCH(int, numSelectionsAfter3rdRowClickedAgain);
+
+ if((Q3Table::SelectionMode)selectionMode == Q3Table::Multi ||
+ (Q3Table::SelectionMode)selectionMode == Q3Table::MultiRow) {
+ QSKIP("numSelections() currently fails on all versions", SkipAll);
+ }
+
+ testWidget->setSelectionMode((Q3Table::SelectionMode)selectionMode);
+ QCOMPARE(testWidget->numSelections(), numSelectionsBeforeAnyRowClicked);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+
+ QTest::mouseClick(testWidget->verticalHeader(), QtTestCase::LeftButton, QtTestCase::NoButton,
+ QPoint(5, testWidget->verticalHeader()->sectionPos(0)+2));
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QCOMPARE(testWidget->numSelections(), numSelectionsAfter1stRowClicked);
+
+ QTest::mouseClick(testWidget->verticalHeader(), QtTestCase::LeftButton, QtTestCase::NoButton,
+ QPoint(5, testWidget->verticalHeader()->sectionPos(2)+2));
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QEXPECT_FAIL("MultiSelection", "Will not fix this for 3.x", Abort);
+ QEXPECT_FAIL("MultiRowSelection", "Will not fix this for 3.x", Abort);
+ QCOMPARE(testWidget->numSelections(), numSelectionsAfter3rdRowClicked);
+
+ QTest::mouseClick(testWidget->verticalHeader(), QtTestCase::LeftButton, QtTestCase::NoButton,
+ QPoint(5, testWidget->verticalHeader()->sectionPos(2)+2));
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QCOMPARE(testWidget->numSelections(), numSelectionsAfter3rdRowClickedAgain);
+#else
+ QSKIP( "This test is expected to fail on >= 3.2", SkipAll);
+#endif
+}
+
+void tst_Q3Table::headerSwapIconset()
+{
+#if 0
+ QIconSet is0, is1;
+ QString hl0, hl1;
+ if (testWidget->horizontalHeader()->iconSet(0))
+ is0 = *testWidget->horizontalHeader()->iconSet(0);
+ hl0 = testWidget->horizontalHeader()->label(0);
+ if (testWidget->horizontalHeader()->iconSet(1))
+ is1 = *testWidget->horizontalHeader()->iconSet(1);
+ hl1 = testWidget->horizontalHeader()->label(1);
+
+ testWidget->show();
+ testWidget->horizontalHeader()->setLabel(1, QPixmap(fileopen), "Test");
+ testWidget->swapColumns(0, 1, true);
+ QVERIFY(!testWidget->horizontalHeader()->iconSet(1)
+ || testWidget->horizontalHeader()->iconSet(1)->isNull());
+
+ testWidget->horizontalHeader()->setLabel(0, is0, hl0);
+ testWidget->horizontalHeader()->setLabel(1, is1, hl1);
+#else
+ QSKIP( "This test fails in Qt 4", SkipAll);
+#endif
+}
+
+
+class EscapeKeyDialog : public QDialog
+{
+public:
+ EscapeKeyDialog() : QDialog(0), recievedEscape(false) {}
+ bool recievedEscape;
+protected:
+ void keyPressEvent(QKeyEvent *e)
+ {
+ if (e->key() == Qt::Key_Escape)
+ recievedEscape = TRUE;
+ QDialog::keyPressEvent(e);
+ }
+};
+
+void tst_Q3Table::propagateEscapeKey()
+{
+#if 0
+ EscapeKeyDialog ekd;
+ Q3Table *table = new Q3Table(5, 5, &ekd);
+ ekd.show();
+#ifdef Q_WS_X11
+ qt_x11_wait_for_window_manager(&ekd);
+#endif
+ table->setCurrentCell(0,0);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(table->viewport(), Qt::Key_A);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QTest::keyClick(table->viewport(), Qt::Key_Escape);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QVERIFY(!ekd.recievedEscape);
+ QVERIFY(table->text(0,0).isEmpty());
+ QTest::keyClick(table->viewport(), Qt::Key_Escape);
+#ifdef WAITS
+ QTest::qWait(50);
+#endif
+ QVERIFY(ekd.recievedEscape);
+#else
+ QSKIP("This test fails for all versions of Qt", SkipAll);
+#endif
+}
+
+void tst_Q3Table::removeSelection_selectionChanged()
+{
+ int numRows = testWidget->numRows();
+ int numCols = testWidget->numCols();
+ testWidget->setNumRows(3);
+ testWidget->setNumCols(3);
+ Q3TableSelection sel(1, 1, 2, 2);
+ testWidget->addSelection(sel);
+ QObject::connect(testWidget, SIGNAL(selectionChanged()),
+ this, SLOT(selectionWasChanged()));
+ receivedSelectionChanged = false;
+ testWidget->removeSelection(sel);
+ qApp->processEvents();
+ QVERIFY(receivedSelectionChanged);
+ testWidget->setNumRows(numRows);
+ testWidget->setNumCols(numCols);
+ QObject::disconnect(testWidget, SIGNAL(selectionChanged()),
+ this, SLOT(selectionWasChanged()));
+}
+
+void tst_Q3Table::selectionWasChanged()
+{
+ receivedSelectionChanged = true;
+}
+
+QTEST_MAIN(tst_Q3Table)
+#include "tst_q3table.moc"
+