diff options
author | Lars Knoll <lars.knoll@qt.io> | 2020-08-21 13:09:21 +0200 |
---|---|---|
committer | Lars Knoll <lars.knoll@qt.io> | 2020-09-02 22:44:28 +0200 |
commit | 9b6df7deb3fff6179071ee59603250cb59c03222 (patch) | |
tree | 58b61e7757b775fc2b0b2b87fb53139bc460685e /tests/auto | |
parent | 638df6138e7acecc2d3b6aad0771e2d81355f2d2 (diff) |
Ground work for bindable properties in QObject
Add a private QBindableInterface and a public QBindable<T>
class, that will be the API interface for accessing bindings
for properties in QObject.
The QBindable class gives access to all aspects of
the property related to bindings. This includes setting
and retrieving bindings, installing observers and creating
a direct binding on this property.
Change-Id: Iaead54d2bd6947bd2cda5052142b2a47dd8bf7c4
Reviewed-by: Ulf Hermann <ulf.hermann@qt.io>
Diffstat (limited to 'tests/auto')
-rw-r--r-- | tests/auto/corelib/kernel/qproperty/tst_qproperty.cpp | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/tests/auto/corelib/kernel/qproperty/tst_qproperty.cpp b/tests/auto/corelib/kernel/qproperty/tst_qproperty.cpp index 4f250992c9..340099a7e9 100644 --- a/tests/auto/corelib/kernel/qproperty/tst_qproperty.cpp +++ b/tests/auto/corelib/kernel/qproperty/tst_qproperty.cpp @@ -72,6 +72,9 @@ private slots: void arrowAndStarOperator(); void typeNoOperatorEqual(); void bindingValueReplacement(); + + void testNewStuff(); + void qobjectObservers(); }; void tst_QProperty::functorBinding() @@ -873,6 +876,115 @@ void tst_QProperty::bindingValueReplacement() // QCOMPARE(test.iconText.value(), 42); } +class MyQObject : public QObject +{ + Q_OBJECT + Q_PROPERTY(int foo READ foo WRITE setFoo NOTIFY fooChanged) // Use Q_BINDABLE_PROPERTY and generate iface API + Q_PROPERTY(int bar READ bar WRITE setBar NOTIFY barChanged) + Q_PROPERTY(int read READ read NOTIFY readChanged) + +signals: + void fooChanged(); + void barChanged(); + void readChanged(); + +public slots: + void fooHasChanged() { fooChangedCount++; } + void barHasChanged() { barChangedCount++; } + void readHasChanged() { readChangedCount++; } + +public: + int foo() const { return fooData.value(); } + void setFoo(int i) { fooData.setValue(i); } + int bar() const { return barData.value(); } + void setBar(int i) { barData.setValue(i); } + int read() const { return readData.value(); } + + QBindable<int> bindableFoo() { return QBindable<int>(&fooData); } + QBindable<int> bindableBar() { return QBindable<int>(&barData); } + QBindable<int> bindableRead() { return QBindable<int>(&readData); } + +public: + int fooChangedCount = 0; + int barChangedCount = 0; + int readChangedCount = 0; + QProperty<int> fooData; + QProperty<int> barData; + QProperty<int> readData; +}; + +void tst_QProperty::testNewStuff() +{ + MyQObject object; + QObject::connect(&object, &MyQObject::fooChanged, &object, &MyQObject::fooHasChanged); + QObject::connect(&object, &MyQObject::barChanged, &object, &MyQObject::barHasChanged); + QObject::connect(&object, &MyQObject::readChanged, &object, &MyQObject::readHasChanged); + +// QCOMPARE(object.fooChangedCount, 0); + object.setFoo(10); +// QCOMPARE(object.fooChangedCount, 1); + QCOMPARE(object.foo(), 10); + + auto f = [&object]() -> int { + return object.barData; + }; +// QCOMPARE(object.barChangedCount, 0); + object.setBar(42); +// QCOMPARE(object.barChangedCount, 1); +// QCOMPARE(object.fooChangedCount, 1); + object.fooData.setBinding(f); +// QCOMPARE(object.fooChangedCount, 2); + QCOMPARE(object.fooData.value(), 42); + object.setBar(666); +// QCOMPARE(object.fooChangedCount, 3); +// QCOMPARE(object.barChangedCount, 2); + QCOMPARE(object.fooData.value(), 666); +// QCOMPARE(object.fooChangedCount, 3); + + auto f2 = [&object]() -> int { + return object.barData / 2; + }; + + object.bindableFoo().setBinding(Qt::makePropertyBinding(f2)); + QVERIFY(object.bindableFoo().hasBinding()); + QCOMPARE(object.foo(), 333); + auto oldBinding = object.bindableFoo().setBinding(QPropertyBinding<int>()); + QVERIFY(!object.bindableFoo().hasBinding()); + QVERIFY(!oldBinding.isNull()); + QCOMPARE(object.foo(), 333); + object.setBar(222); + QCOMPARE(object.foo(), 333); + object.bindableFoo().setBinding(oldBinding); + QCOMPARE(object.foo(), 111); + + auto b = object.bindableRead().makeBinding(); + object.bindableFoo().setBinding(b); + QCOMPARE(object.foo(), 0); + object.readData.setValue(10); + QCOMPARE(object.foo(), 10); +} + +void tst_QProperty::qobjectObservers() +{ + MyQObject object; + int onValueChangedCalled = 0; + { + auto handler = object.bindableFoo().onValueChanged([&onValueChangedCalled]() { ++onValueChangedCalled;}); + QCOMPARE(onValueChangedCalled, 0); + + object.setFoo(10); + QCOMPARE(onValueChangedCalled, 1); + + object.bindableFoo().setBinding(object.bindableBar().makeBinding()); + QCOMPARE(onValueChangedCalled, 2); + + object.setBar(42); + QCOMPARE(onValueChangedCalled, 3); + } + object.setBar(0); + QCOMPARE(onValueChangedCalled, 3); +} + QTEST_MAIN(tst_QProperty); #include "tst_qproperty.moc" |