summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsborderimage.cpp6
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsborderimage_p.h3
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsmouseregion.cpp7
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsmouseregion_p.h3
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsparticles.cpp7
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsparticles_p.h1
-rw-r--r--src/declarative/graphicsitems/qmlgraphicspath.cpp5
-rw-r--r--src/declarative/graphicsitems/qmlgraphicspath_p.h1
-rw-r--r--src/declarative/graphicsitems/qmlgraphicspathview.cpp7
-rw-r--r--src/declarative/graphicsitems/qmlgraphicspathview_p.h3
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsrectangle.cpp8
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsrectangle_p.h3
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsrepeater.cpp8
-rw-r--r--src/declarative/graphicsitems/qmlgraphicsrepeater_p.h1
-rw-r--r--src/declarative/graphicsitems/qmlgraphicstext.cpp7
-rw-r--r--src/declarative/graphicsitems/qmlgraphicstext_p.h1
-rw-r--r--src/declarative/graphicsitems/qmlgraphicstextedit.cpp10
-rw-r--r--src/declarative/graphicsitems/qmlgraphicstextedit_p.h1
-rw-r--r--src/declarative/graphicsitems/qmlgraphicstextinput.cpp10
-rw-r--r--src/declarative/graphicsitems/qmlgraphicstextinput_p.h1
-rw-r--r--src/declarative/graphicsitems/qmlgraphicswebview.cpp6
-rw-r--r--src/declarative/graphicsitems/qmlgraphicswebview_p.h2
-rw-r--r--tests/auto/declarative/qmldebug/tst_qmldebug.cpp346
23 files changed, 171 insertions, 276 deletions
diff --git a/src/declarative/graphicsitems/qmlgraphicsborderimage.cpp b/src/declarative/graphicsitems/qmlgraphicsborderimage.cpp
index 78b0be4..fba9d69 100644
--- a/src/declarative/graphicsitems/qmlgraphicsborderimage.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicsborderimage.cpp
@@ -402,10 +402,4 @@ void QmlGraphicsBorderImage::paint(QPainter *p, const QStyleOptionGraphicsItem *
}
}
-QmlGraphicsBorderImage::QmlGraphicsBorderImage(QmlGraphicsBorderImagePrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsImageBase(dd, parent)
-{
- setFlag(QGraphicsItem::ItemHasNoContents, false);
-}
-
QT_END_NAMESPACE
diff --git a/src/declarative/graphicsitems/qmlgraphicsborderimage_p.h b/src/declarative/graphicsitems/qmlgraphicsborderimage_p.h
index 04850e6..18195e2 100644
--- a/src/declarative/graphicsitems/qmlgraphicsborderimage_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicsborderimage_p.h
@@ -83,9 +83,6 @@ Q_SIGNALS:
void horizontalTileModeChanged();
void verticalTileModeChanged();
-protected:
- QmlGraphicsBorderImage(QmlGraphicsBorderImagePrivate &dd, QmlGraphicsItem *parent);
-
private:
void setGridScaledImage(const QmlGraphicsGridScaledImage& sci);
diff --git a/src/declarative/graphicsitems/qmlgraphicsmouseregion.cpp b/src/declarative/graphicsitems/qmlgraphicsmouseregion.cpp
index 22c2c0a..ec613af 100644
--- a/src/declarative/graphicsitems/qmlgraphicsmouseregion.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicsmouseregion.cpp
@@ -246,13 +246,6 @@ QmlGraphicsMouseRegion::QmlGraphicsMouseRegion(QmlGraphicsItem *parent)
d->init();
}
-QmlGraphicsMouseRegion::QmlGraphicsMouseRegion(QmlGraphicsMouseRegionPrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsItem(dd, parent)
-{
- Q_D(QmlGraphicsMouseRegion);
- d->init();
-}
-
QmlGraphicsMouseRegion::~QmlGraphicsMouseRegion()
{
}
diff --git a/src/declarative/graphicsitems/qmlgraphicsmouseregion_p.h b/src/declarative/graphicsitems/qmlgraphicsmouseregion_p.h
index 3403c75..9c3398a 100644
--- a/src/declarative/graphicsitems/qmlgraphicsmouseregion_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicsmouseregion_p.h
@@ -162,9 +162,6 @@ private:
void handlePress();
void handleRelease();
-protected:
- QmlGraphicsMouseRegion(QmlGraphicsMouseRegionPrivate &dd, QmlGraphicsItem *parent);
-
private:
Q_DISABLE_COPY(QmlGraphicsMouseRegion)
Q_DECLARE_PRIVATE_D(QGraphicsItem::d_ptr.data(), QmlGraphicsMouseRegion)
diff --git a/src/declarative/graphicsitems/qmlgraphicsparticles.cpp b/src/declarative/graphicsitems/qmlgraphicsparticles.cpp
index 4ac02b4..399e1a5 100644
--- a/src/declarative/graphicsitems/qmlgraphicsparticles.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicsparticles.cpp
@@ -635,13 +635,6 @@ QmlGraphicsParticles::QmlGraphicsParticles(QmlGraphicsItem *parent)
d->init();
}
-QmlGraphicsParticles::QmlGraphicsParticles(QmlGraphicsParticlesPrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsItem(dd, parent)
-{
- Q_D(QmlGraphicsParticles);
- d->init();
-}
-
QmlGraphicsParticles::~QmlGraphicsParticles()
{
Q_D(QmlGraphicsParticles);
diff --git a/src/declarative/graphicsitems/qmlgraphicsparticles_p.h b/src/declarative/graphicsitems/qmlgraphicsparticles_p.h
index 851edd7..2554605 100644
--- a/src/declarative/graphicsitems/qmlgraphicsparticles_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicsparticles_p.h
@@ -214,7 +214,6 @@ public Q_SLOTS:
protected:
virtual void componentComplete();
- QmlGraphicsParticles(QmlGraphicsParticlesPrivate &dd, QmlGraphicsItem *parent);
Q_SIGNALS:
void sourceChanged();
diff --git a/src/declarative/graphicsitems/qmlgraphicspath.cpp b/src/declarative/graphicsitems/qmlgraphicspath.cpp
index a8f571e..0812d11 100644
--- a/src/declarative/graphicsitems/qmlgraphicspath.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicspath.cpp
@@ -100,11 +100,6 @@ QmlGraphicsPath::QmlGraphicsPath(QObject *parent)
{
}
-QmlGraphicsPath::QmlGraphicsPath(QmlGraphicsPathPrivate &dd, QObject *parent)
- : QObject(dd, parent)
-{
-}
-
QmlGraphicsPath::~QmlGraphicsPath()
{
}
diff --git a/src/declarative/graphicsitems/qmlgraphicspath_p.h b/src/declarative/graphicsitems/qmlgraphicspath_p.h
index 4710367..8abfb2a 100644
--- a/src/declarative/graphicsitems/qmlgraphicspath_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicspath_p.h
@@ -215,7 +215,6 @@ Q_SIGNALS:
protected:
virtual void componentComplete();
- QmlGraphicsPath(QmlGraphicsPathPrivate &dd, QObject *parent);
private Q_SLOTS:
void processPath();
diff --git a/src/declarative/graphicsitems/qmlgraphicspathview.cpp b/src/declarative/graphicsitems/qmlgraphicspathview.cpp
index f664763..180954c 100644
--- a/src/declarative/graphicsitems/qmlgraphicspathview.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicspathview.cpp
@@ -106,13 +106,6 @@ QmlGraphicsPathView::QmlGraphicsPathView(QmlGraphicsItem *parent)
d->init();
}
-QmlGraphicsPathView::QmlGraphicsPathView(QmlGraphicsPathViewPrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsItem(dd, parent)
-{
- Q_D(QmlGraphicsPathView);
- d->init();
-}
-
QmlGraphicsPathView::~QmlGraphicsPathView()
{
Q_D(QmlGraphicsPathView);
diff --git a/src/declarative/graphicsitems/qmlgraphicspathview_p.h b/src/declarative/graphicsitems/qmlgraphicspathview_p.h
index f713794..59118d4 100644
--- a/src/declarative/graphicsitems/qmlgraphicspathview_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicspathview_p.h
@@ -118,9 +118,6 @@ private Q_SLOTS:
void createdItem(int index, QmlGraphicsItem *item);
void destroyingItem(QmlGraphicsItem *item);
-protected:
- QmlGraphicsPathView(QmlGraphicsPathViewPrivate &dd, QmlGraphicsItem *parent);
-
private:
friend class QmlGraphicsPathViewAttached;
static QHash<QObject*, QObject*> attachedProperties;
diff --git a/src/declarative/graphicsitems/qmlgraphicsrectangle.cpp b/src/declarative/graphicsitems/qmlgraphicsrectangle.cpp
index caec90c..cc09436 100644
--- a/src/declarative/graphicsitems/qmlgraphicsrectangle.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicsrectangle.cpp
@@ -186,14 +186,6 @@ QmlGraphicsRectangle::QmlGraphicsRectangle(QmlGraphicsItem *parent)
setFlag(QGraphicsItem::ItemHasNoContents, false);
}
-QmlGraphicsRectangle::QmlGraphicsRectangle(QmlGraphicsRectanglePrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsItem(dd, parent)
-{
- Q_D(QmlGraphicsRectangle);
- d->init();
- setFlag(QGraphicsItem::ItemHasNoContents, false);
-}
-
void QmlGraphicsRectangle::doUpdate()
{
Q_D(QmlGraphicsRectangle);
diff --git a/src/declarative/graphicsitems/qmlgraphicsrectangle_p.h b/src/declarative/graphicsitems/qmlgraphicsrectangle_p.h
index 2a80619..2f0a518 100644
--- a/src/declarative/graphicsitems/qmlgraphicsrectangle_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicsrectangle_p.h
@@ -169,9 +169,6 @@ private:
void generateBorderedRect();
void drawRect(QPainter &painter);
-protected:
- QmlGraphicsRectangle(QmlGraphicsRectanglePrivate &dd, QmlGraphicsItem *parent);
-
private:
Q_DISABLE_COPY(QmlGraphicsRectangle)
Q_DECLARE_PRIVATE_D(QGraphicsItem::d_ptr.data(), QmlGraphicsRectangle)
diff --git a/src/declarative/graphicsitems/qmlgraphicsrepeater.cpp b/src/declarative/graphicsitems/qmlgraphicsrepeater.cpp
index 82d6da3..48758a7 100644
--- a/src/declarative/graphicsitems/qmlgraphicsrepeater.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicsrepeater.cpp
@@ -119,14 +119,6 @@ QmlGraphicsRepeater::QmlGraphicsRepeater(QmlGraphicsItem *parent)
}
/*!
- \internal
- */
-QmlGraphicsRepeater::QmlGraphicsRepeater(QmlGraphicsRepeaterPrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsItem(dd, parent)
-{
-}
-
-/*!
Destroy the repeater instance. All items it instantiated are also
destroyed.
*/
diff --git a/src/declarative/graphicsitems/qmlgraphicsrepeater_p.h b/src/declarative/graphicsitems/qmlgraphicsrepeater_p.h
index 8d71303..4058df0 100644
--- a/src/declarative/graphicsitems/qmlgraphicsrepeater_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicsrepeater_p.h
@@ -82,7 +82,6 @@ private:
protected:
virtual void componentComplete();
QVariant itemChange(GraphicsItemChange change, const QVariant &value);
- QmlGraphicsRepeater(QmlGraphicsRepeaterPrivate &dd, QmlGraphicsItem *parent);
private Q_SLOTS:
void itemsInserted(int,int);
diff --git a/src/declarative/graphicsitems/qmlgraphicstext.cpp b/src/declarative/graphicsitems/qmlgraphicstext.cpp
index 374972e..504eb2a 100644
--- a/src/declarative/graphicsitems/qmlgraphicstext.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicstext.cpp
@@ -111,13 +111,6 @@ QmlGraphicsText::QmlGraphicsText(QmlGraphicsItem *parent)
setFlag(QGraphicsItem::ItemHasNoContents, false);
}
-QmlGraphicsText::QmlGraphicsText(QmlGraphicsTextPrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsItem(dd, parent)
-{
- setAcceptedMouseButtons(Qt::LeftButton);
- setFlag(QGraphicsItem::ItemHasNoContents, false);
-}
-
QmlGraphicsText::~QmlGraphicsText()
{
}
diff --git a/src/declarative/graphicsitems/qmlgraphicstext_p.h b/src/declarative/graphicsitems/qmlgraphicstext_p.h
index ac1ded0..31b049a 100644
--- a/src/declarative/graphicsitems/qmlgraphicstext_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicstext_p.h
@@ -131,7 +131,6 @@ Q_SIGNALS:
void linkActivated(const QString &link);
protected:
- QmlGraphicsText(QmlGraphicsTextPrivate &dd, QmlGraphicsItem *parent);
void mousePressEvent(QGraphicsSceneMouseEvent *event);
void mouseReleaseEvent(QGraphicsSceneMouseEvent *event);
virtual void geometryChanged(const QRectF &newGeometry,
diff --git a/src/declarative/graphicsitems/qmlgraphicstextedit.cpp b/src/declarative/graphicsitems/qmlgraphicstextedit.cpp
index d8fe5d4..b691304 100644
--- a/src/declarative/graphicsitems/qmlgraphicstextedit.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicstextedit.cpp
@@ -103,16 +103,6 @@ QmlGraphicsTextEdit::QmlGraphicsTextEdit(QmlGraphicsItem *parent)
d->init();
}
-/*!
-\internal
-*/
-QmlGraphicsTextEdit::QmlGraphicsTextEdit(QmlGraphicsTextEditPrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsPaintedItem(dd, parent)
-{
- Q_D(QmlGraphicsTextEdit);
- d->init();
-}
-
QString QmlGraphicsTextEdit::text() const
{
Q_D(const QmlGraphicsTextEdit);
diff --git a/src/declarative/graphicsitems/qmlgraphicstextedit_p.h b/src/declarative/graphicsitems/qmlgraphicstextedit_p.h
index efbe998..fa95373 100644
--- a/src/declarative/graphicsitems/qmlgraphicstextedit_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicstextedit_p.h
@@ -201,7 +201,6 @@ private:
void updateSize();
protected:
- QmlGraphicsTextEdit(QmlGraphicsTextEditPrivate &dd, QmlGraphicsItem *parent);
virtual void geometryChanged(const QRectF &newGeometry,
const QRectF &oldGeometry);
diff --git a/src/declarative/graphicsitems/qmlgraphicstextinput.cpp b/src/declarative/graphicsitems/qmlgraphicstextinput.cpp
index cd7377e..d7612aa 100644
--- a/src/declarative/graphicsitems/qmlgraphicstextinput.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicstextinput.cpp
@@ -70,16 +70,6 @@ QmlGraphicsTextInput::QmlGraphicsTextInput(QmlGraphicsItem* parent)
d->init();
}
-/*
- \internal
-*/
-QmlGraphicsTextInput::QmlGraphicsTextInput(QmlGraphicsTextInputPrivate &dd, QmlGraphicsItem* parent)
- : QmlGraphicsPaintedItem(dd, parent)
-{
- Q_D(QmlGraphicsTextInput);
- d->init();
-}
-
QmlGraphicsTextInput::~QmlGraphicsTextInput()
{
}
diff --git a/src/declarative/graphicsitems/qmlgraphicstextinput_p.h b/src/declarative/graphicsitems/qmlgraphicstextinput_p.h
index 7d3fef0..87ceccf 100644
--- a/src/declarative/graphicsitems/qmlgraphicstextinput_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicstextinput_p.h
@@ -172,7 +172,6 @@ Q_SIGNALS:
void acceptableInputChanged();
protected:
- QmlGraphicsTextInput(QmlGraphicsTextInputPrivate &dd, QmlGraphicsItem *parent);
virtual void geometryChanged(const QRectF &newGeometry,
const QRectF &oldGeometry);
diff --git a/src/declarative/graphicsitems/qmlgraphicswebview.cpp b/src/declarative/graphicsitems/qmlgraphicswebview.cpp
index 214117f..827144d 100644
--- a/src/declarative/graphicsitems/qmlgraphicswebview.cpp
+++ b/src/declarative/graphicsitems/qmlgraphicswebview.cpp
@@ -260,12 +260,6 @@ QmlGraphicsWebView::QmlGraphicsWebView(QmlGraphicsItem *parent)
init();
}
-QmlGraphicsWebView::QmlGraphicsWebView(QmlGraphicsWebViewPrivate &dd, QmlGraphicsItem *parent)
- : QmlGraphicsPaintedItem(dd, parent)
-{
- init();
-}
-
QmlGraphicsWebView::~QmlGraphicsWebView()
{
Q_D(QmlGraphicsWebView);
diff --git a/src/declarative/graphicsitems/qmlgraphicswebview_p.h b/src/declarative/graphicsitems/qmlgraphicswebview_p.h
index d574c59..6373246 100644
--- a/src/declarative/graphicsitems/qmlgraphicswebview_p.h
+++ b/src/declarative/graphicsitems/qmlgraphicswebview_p.h
@@ -209,8 +209,6 @@ private Q_SLOTS:
void contentsSizeChanged(const QSize&);
protected:
- QmlGraphicsWebView(QmlGraphicsWebViewPrivate &dd, QmlGraphicsItem *parent);
-
void drawContents(QPainter *, const QRect &);
void mousePressEvent(QGraphicsSceneMouseEvent *event);
diff --git a/tests/auto/declarative/qmldebug/tst_qmldebug.cpp b/tests/auto/declarative/qmldebug/tst_qmldebug.cpp
index a7573da..0890557 100644
--- a/tests/auto/declarative/qmldebug/tst_qmldebug.cpp
+++ b/tests/auto/declarative/qmldebug/tst_qmldebug.cpp
@@ -51,12 +51,18 @@
#include <QtDeclarative/qmlcontext.h>
#include <QtDeclarative/qmlcomponent.h>
#include <QtDeclarative/qmlexpression.h>
+#include <QtDeclarative/qmlmetatype.h>
+#include <QtDeclarative/qmlmetaproperty.h>
+#include <QtDeclarative/qmlcontext.h>
+#include <QtDeclarative/qmlbinding.h>
#include <private/qmldebug_p.h>
+#include <private/qmlenginedebug_p.h>
#include <private/qmldebugclient_p.h>
#include <private/qmldebugservice_p.h>
#include <private/qmlgraphicsrectangle_p.h>
#include <private/qmlgraphicstext_p.h>
+#include <private/qmldeclarativedata_p.h>
class tst_QmlDebug : public QObject
@@ -74,101 +80,18 @@ protected slots:
}
private:
+ QmlDebugObjectReference findRootObject();
+ QmlDebugPropertyReference findProperty(const QList<QmlDebugPropertyReference> &props, const QString &name);
+ QObject *findObjectWithId(const QObjectList &objects, int id);
+ void waitForQuery(QmlDebugQuery *query);
+ void recursiveObjectTest(QObject *o, const QmlDebugObjectReference &oref, bool recursive);
+
QmlDebugConnection *m_conn;
QmlEngineDebug *m_dbg;
QmlEngine *m_engine;
QmlGraphicsItem *m_rootItem;
-
QHash<QByteArray, QVariant> m_savedValueChanges;
- void waitForQuery(QmlDebugQuery *query)
- {
- QCOMPARE(query->parent(), this);
- QEventLoop loop;
- QTimer timer;
- QVERIFY(query->state() == QmlDebugQuery::Waiting);
- connect(query, SIGNAL(stateChanged(State)), &loop, SLOT(quit()));
- connect(&timer, SIGNAL(timeout()), &loop, SLOT(quit()));
- timer.start(5000);
- loop.exec();
- if (!timer.isActive())
- QFAIL("query timed out");
- }
-
- void verifyRootObject(const QmlDebugObjectReference &obj)
- {
- // verifies object according to component definition in main()
-
- QCOMPARE(obj.debugId(), QmlDebugService::idForObject(m_rootItem));
- QCOMPARE(obj.className(), QLatin1String("Item"));
- QCOMPARE(obj.name(), m_rootItem->objectName());
- QCOMPARE(obj.contextDebugId(), QmlDebugService::idForObject(qmlContext(m_rootItem)));
-
- QmlDebugFileReference source = obj.source();
- QCOMPARE(source.url(), QUrl("file://"));
- QCOMPARE(source.lineNumber(), 3);
- QCOMPARE(source.columnNumber(), 3);
-
- QList<QmlDebugPropertyReference> props = obj.properties();
- QHash<QString, QVariant> expected;
-
- expected["width"] = 10;
- expected["height"] = 20;
- verifyProperties(props, expected);
- }
-
- void verifyProperties(const QList<QmlDebugPropertyReference> &actual, const QHash<QString, QVariant> &expected)
- {
- foreach(const QmlDebugPropertyReference &p, actual) {
- if (expected.contains(p.name()))
- QCOMPARE(p.value(), expected[p.name()]);
- }
- }
-
- QmlDebugObjectReference findRootObject()
- {
- QmlDebugEnginesQuery *q_engines = m_dbg->queryAvailableEngines(this);
- waitForQuery(q_engines);
-
- if (q_engines->engines().count() == 0)
- return QmlDebugObjectReference();
- QmlDebugRootContextQuery *q_context = m_dbg->queryRootContexts(q_engines->engines()[0].debugId(), this);
- waitForQuery(q_context);
-
- if (q_context->rootContext().objects().count() == 0)
- return QmlDebugObjectReference();
- QmlDebugObjectQuery *q_obj = m_dbg->queryObject(q_context->rootContext().objects()[0], this);
- waitForQuery(q_obj);
-
- QmlDebugObjectReference result = q_obj->object();
-
- delete q_engines;
- delete q_context;
- delete q_obj;
-
- return result;
- }
-
- QmlDebugPropertyReference findProperty(const QList<QmlDebugPropertyReference> &props, const QString &name)
- {
- foreach(const QmlDebugPropertyReference &p, props) {
- if (p.name() == name)
- return p;
- }
- return QmlDebugPropertyReference();
- }
-
- int countNotifiableProperties(const QObject *obj)
- {
- int count = 0;
- for (int i=0; i<obj->metaObject()->propertyCount(); i++) {
- QMetaProperty p = obj->metaObject()->property(i);
- if (p.hasNotifySignal())
- count++;
- }
- return count;
- }
-
private slots:
void initTestCase();
@@ -180,11 +103,115 @@ private slots:
void queryAvailableEngines();
void queryRootContexts();
void queryObject();
- void queryObjectRecursive();
+ void queryObject_data();
void queryExpressionResult();
void queryExpressionResult_data();
};
+QmlDebugObjectReference tst_QmlDebug::findRootObject()
+{
+ QmlDebugEnginesQuery *q_engines = m_dbg->queryAvailableEngines(this);
+ waitForQuery(q_engines);
+
+ if (q_engines->engines().count() == 0)
+ return QmlDebugObjectReference();
+ QmlDebugRootContextQuery *q_context = m_dbg->queryRootContexts(q_engines->engines()[0].debugId(), this);
+ waitForQuery(q_context);
+
+ if (q_context->rootContext().objects().count() == 0)
+ return QmlDebugObjectReference();
+ QmlDebugObjectQuery *q_obj = m_dbg->queryObject(q_context->rootContext().objects()[0], this);
+ waitForQuery(q_obj);
+
+ QmlDebugObjectReference result = q_obj->object();
+
+ delete q_engines;
+ delete q_context;
+ delete q_obj;
+
+ return result;
+}
+
+QmlDebugPropertyReference tst_QmlDebug::findProperty(const QList<QmlDebugPropertyReference> &props, const QString &name)
+{
+ foreach(const QmlDebugPropertyReference &p, props) {
+ if (p.name() == name)
+ return p;
+ }
+ return QmlDebugPropertyReference();
+}
+
+QObject *tst_QmlDebug::findObjectWithId(const QObjectList &objects, int id)
+{
+ foreach (QObject *o, objects) {
+ if (id == QmlDebugService::idForObject(o))
+ return o;
+ }
+ return 0;
+}
+
+void tst_QmlDebug::waitForQuery(QmlDebugQuery *query)
+{
+ QVERIFY(query);
+ QCOMPARE(query->parent(), this);
+ QEventLoop loop;
+ QTimer timer;
+ QVERIFY(query->state() == QmlDebugQuery::Waiting);
+ connect(query, SIGNAL(stateChanged(State)), &loop, SLOT(quit()));
+ connect(&timer, SIGNAL(timeout()), &loop, SLOT(quit()));
+ timer.start(5000);
+ loop.exec();
+ if (!timer.isActive())
+ QFAIL("query timed out");
+}
+
+void tst_QmlDebug::recursiveObjectTest(QObject *o, const QmlDebugObjectReference &oref, bool recursive)
+{
+ const QMetaObject *meta = o->metaObject();
+
+ QmlType *type = QmlMetaType::qmlType(o->metaObject());
+ QString className = type ? type->qmlTypeName() : QString();
+ className = className.mid(className.lastIndexOf(QLatin1Char('/'))+1);
+
+ QCOMPARE(oref.debugId(), QmlDebugService::idForObject(o));
+ QCOMPARE(oref.name(), o->objectName());
+ QCOMPARE(oref.className(), className);
+ QCOMPARE(oref.contextDebugId(), QmlDebugService::idForObject(qmlContext(o)));
+
+ foreach (const QmlDebugObjectReference &cref, oref.children()) {
+ // ignore children with no context
+ if (cref.contextDebugId() < 0)
+ continue;
+
+ QObject *childObject = findObjectWithId(o->children(), cref.debugId());
+ QVERIFY2(childObject, qPrintable(QString("Can't find QObject* for %1").arg(cref.className())));
+
+ if (recursive)
+ recursiveObjectTest(childObject, cref, true);
+ }
+
+ foreach (const QmlDebugPropertyReference &p, oref.properties()) {
+ QMetaProperty pmeta = meta->property(meta->indexOfProperty(p.name().toUtf8().constData()));
+ QVERIFY(pmeta.isValid());
+
+ QCOMPARE(p.name(), QString::fromUtf8(pmeta.name()));
+
+ if (pmeta.type() < QVariant::UserType) // TODO test complex types
+ QCOMPARE(p.value(), pmeta.read(o));
+
+ if (p.name() == "parent")
+ QVERIFY(p.valueTypeName() == "QGraphicsObject*" || p.valueTypeName() == "QmlGraphicsItem*");
+ else
+ QCOMPARE(p.valueTypeName(), QString::fromUtf8(pmeta.typeName()));
+
+ QmlAbstractBinding *binding = QmlMetaProperty(o, p.name()).binding();
+ if (binding)
+ QCOMPARE(binding->expression(), p.binding());
+
+ QCOMPARE(p.hasNotifySignal(), pmeta.hasNotifySignal());
+ }
+}
+
void tst_QmlDebug::initTestCase()
{
m_dbg = new QmlEngineDebug(m_conn, this);
@@ -219,7 +246,7 @@ void tst_QmlDebug::watch_property()
// restore original value and verify spy doesn't get a signal since watch has been removed
m_rootItem->setProperty("width", origWidth);
- QTest::qWait(500);
+ QTest::qWait(100);
QCOMPARE(spy.count(), 1);
QCOMPARE(spy.at(0).at(0).value<QByteArray>(), prop.name().toUtf8());
@@ -274,7 +301,7 @@ void tst_QmlDebug::watch_object()
m_savedValueChanges.clear();
m_rootItem->setProperty("width", origWidth);
m_rootItem->setProperty("height", origHeight);
- QTest::qWait(500);
+ QTest::qWait(100);
QCOMPARE(m_savedValueChanges.count(), 0);
if (newWidth.isNull() || newHeight.isNull()) {
@@ -326,8 +353,8 @@ void tst_QmlDebug::watch_expression()
delete watch;
// restore original value and verify spy doesn't get a signal since watch has been removed
- m_rootItem->setProperty("width", origWidth); // may increase spy count before QCOMPARE()
- QTest::qWait(500);
+ m_rootItem->setProperty("width", origWidth);
+ QTest::qWait(100);
QCOMPARE(spy.count(), expectedSpyCount);
width = origWidth + increment;
@@ -352,7 +379,7 @@ void tst_QmlDebug::queryAvailableEngines()
QmlDebugEnginesQuery *q_engines = m_dbg->queryAvailableEngines(this);
waitForQuery(q_engines);
- // TODO have multiple engines
+ // TODO test multiple engines
QList<QmlDebugEngineReference> engines = q_engines->engines();
QCOMPARE(engines.count(), 1);
@@ -377,7 +404,7 @@ void tst_QmlDebug::queryRootContexts()
QCOMPARE(context.debugId(), QmlDebugService::idForObject(actualContext));
QCOMPARE(context.name(), actualContext->objectName());
- QCOMPARE(context.objects().count(), 1);
+ QCOMPARE(context.objects().count(), 2); // 2 objects created for engine in main()
// root context query sends only root object data - it doesn't fill in
// the children or property info
@@ -393,104 +420,70 @@ void tst_QmlDebug::queryRootContexts()
void tst_QmlDebug::queryObject()
{
- QmlDebugEnginesQuery *q_engines = m_dbg->queryAvailableEngines(this);
- waitForQuery(q_engines);
-
- QmlDebugRootContextQuery *q_context = m_dbg->queryRootContexts(q_engines->engines()[0].debugId(), this);
- waitForQuery(q_context);
-
- QmlDebugObjectQuery *q_obj = m_dbg->queryObject(q_context->rootContext().objects()[0], this);
- waitForQuery(q_obj);
-
- QmlDebugObjectReference obj = q_obj->object();
- verifyRootObject(obj);
+ QFETCH(bool, recursive);
- QVERIFY(obj.children().count() >= 2);
-
- // non-recursive query, children data not available
- foreach(const QmlDebugObjectReference &child, obj.children())
- QCOMPARE(child.properties().count(), 0);
-
- delete q_engines;
- delete q_context;
- delete q_obj;
-}
-
-void tst_QmlDebug::queryObjectRecursive()
-{
QmlDebugEnginesQuery *q_engines = m_dbg->queryAvailableEngines(this);
waitForQuery(q_engines);
QmlDebugRootContextQuery *q_context = m_dbg->queryRootContexts(q_engines->engines()[0].debugId(), this);
waitForQuery(q_context);
- QmlDebugObjectQuery *q_obj = m_dbg->queryObjectRecursive(q_context->rootContext().objects()[0], this);
+ QmlDebugObjectQuery *q_obj = 0;
+ if (recursive)
+ q_obj = m_dbg->queryObjectRecursive(q_context->rootContext().objects()[0], this);
+ else
+ q_obj = m_dbg->queryObject(q_context->rootContext().objects()[0], this);
waitForQuery(q_obj);
QmlDebugObjectReference obj = q_obj->object();
- verifyRootObject(obj);
delete q_engines;
delete q_context;
delete q_obj;
- QList<QmlDebugObjectReference> children = obj.children();
- QVERIFY(children.count() >= 2); // there may be additional properties e.g. StateGroup
-
- QList<QmlDebugPropertyReference> props;
- QHash<QString, QVariant> expected;
-
- QmlDebugObjectReference rectRef;
- QmlDebugObjectReference textRef;
- foreach (const QmlDebugObjectReference &child, children) {
- if (child.className() == "Rectangle") {
- props = child.properties();
- QVERIFY(props.count() > 0);
- expected.clear();
- expected["width"] = 500;
- expected["height"] = 600;
- expected["color"] = "blue";
- verifyProperties(props, expected);
- rectRef = child;
- } else if (child.className() == "Text") {
- props = child.properties();
- QVERIFY(props.count() > 0);
- expected.clear();
- expected["color"] = "red";
- verifyProperties(props, expected);
- textRef = child;
+ // check source as defined in main()
+ QmlDebugFileReference source = obj.source();
+ QCOMPARE(source.url(), QUrl("file://"));
+ QCOMPARE(source.lineNumber(), 2);
+ QCOMPARE(source.columnNumber(), 1);
+
+ // generically test all properties, children and childrens' properties
+ recursiveObjectTest(m_rootItem, obj, recursive);
+
+ if (recursive) {
+ foreach(const QmlDebugObjectReference &child, obj.children())
+ QVERIFY(child.properties().count() > 0);
+
+ QmlDebugObjectReference rect;
+ QmlDebugObjectReference text;
+ foreach (const QmlDebugObjectReference &child, obj.children()) {
+ if (child.className() == "Rectangle")
+ rect = child;
+ else if (child.className() == "Text")
+ text = child;
}
- }
- QVERIFY(!rectRef.className().isEmpty());
- QVERIFY(!textRef.className().isEmpty());
+ // test specific property values
+ QCOMPARE(findProperty(rect.properties(), "width").value(), qVariantFromValue(500));
+ QCOMPARE(findProperty(rect.properties(), "height").value(), qVariantFromValue(600));
+ QCOMPARE(findProperty(rect.properties(), "color").value(), qVariantFromValue(QColor("blue")));
- QObject *rectObj = 0;
- QObject *textObj = 0;
- foreach (QObject *o, m_rootItem->children()) {
- if (o->metaObject()->className() == QmlGraphicsRectangle::staticMetaObject.className())
- rectObj = o;
- else if (o->metaObject()->className() == QmlGraphicsText::staticMetaObject.className())
- textObj = o;
- }
+ QCOMPARE(findProperty(text.properties(), "color").value(), qVariantFromValue(QColor("blue")));
- QVERIFY(rectObj);
- QVERIFY(textObj);
-
- for (int i=0; i<rectObj->metaObject()->propertyCount(); i++) {
- QMetaProperty p = rectObj->metaObject()->property(i);
- QmlDebugPropertyReference pd = findProperty(rectRef.properties(), p.name());
- if (!pd.name().isEmpty()) {
- QCOMPARE(pd.name(), QString::fromUtf8(p.name()));
- if (p.type() < QVariant::UserType)
- QCOMPARE(pd.value(), p.read(rectObj));
- if (pd.name() != "parent")
- QCOMPARE(pd.valueTypeName(), QString::fromUtf8(p.typeName()));
- QCOMPARE(pd.hasNotifySignal(), p.hasNotifySignal());
- }
+ } else {
+ foreach(const QmlDebugObjectReference &child, obj.children())
+ QCOMPARE(child.properties().count(), 0);
}
}
+void tst_QmlDebug::queryObject_data()
+{
+ QTest::addColumn<bool>("recursive");
+
+ QTest::newRow("non-recursive") << false;
+ QTest::newRow("recursive") << true;
+}
+
void tst_QmlDebug::queryExpressionResult()
{
QFETCH(QString, expr);
@@ -570,17 +563,20 @@ int main(int argc, char *argv[])
QmlComponent component(&engine,
"import Qt 4.6\n"
- "\n" // don't remove, line number is tested
- " Item {\n" // don't remove spaces, column number is tested
+ "Item {\n"
"width: 10; height: 20;\n"
"Rectangle { id: blueRect; width: 500; height: 600; color: \"blue\"; }"
- "Text { color: \"red\"; }"
+ "Text { color: blueRect.color; }"
"}\n",
QUrl("file://"));
Q_ASSERT(component.isReady());
QObject *o = component.create();
QObject::connect(&thread, SIGNAL(testsFinished()), o, SLOT(deleteLater()));
+ // allows us to test that multiple contexts can be detected
+ QObject *o2 = component.create();
+ QObject::connect(&thread, SIGNAL(testsFinished()), o2, SLOT(deleteLater()));
+
// start the test
thread.m_engine = &engine;
thread.m_item = qobject_cast<QmlGraphicsItem*>(o);