diff options
author | Roberto Raggi <roberto.raggi@nokia.com> | 2011-05-05 17:19:01 +0200 |
---|---|---|
committer | Roberto Raggi <roberto.raggi@nokia.com> | 2011-05-05 17:19:01 +0200 |
commit | e50b7c92998905efdd40314724480e3070bdbcb5 (patch) | |
tree | f83dcfbc426e5a98d120f926d54cdf98892e31c7 /tests | |
parent | 8883e0500eb7dee2439fce884acfd2177e07811a (diff) |
Fix evaluation of boolean conditions
Ensure that the operand of IR::OpIfTrue and IR::OpNot has boolean type.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/auto/declarative/qdeclarativev4/data/conditionalExpr.qml | 6 | ||||
-rw-r--r-- | tests/auto/declarative/qdeclarativev4/tst_qdeclarativev4.cpp | 18 |
2 files changed, 24 insertions, 0 deletions
diff --git a/tests/auto/declarative/qdeclarativev4/data/conditionalExpr.qml b/tests/auto/declarative/qdeclarativev4/data/conditionalExpr.qml new file mode 100644 index 0000000000..b74a95a94b --- /dev/null +++ b/tests/auto/declarative/qdeclarativev4/data/conditionalExpr.qml @@ -0,0 +1,6 @@ +import Qt.v4 1.0 + +Result { + property int n: 2 + result: !n ? 100 : 0 +} diff --git a/tests/auto/declarative/qdeclarativev4/tst_qdeclarativev4.cpp b/tests/auto/declarative/qdeclarativev4/tst_qdeclarativev4.cpp index 0f8c5bcf66..fb34696ef5 100644 --- a/tests/auto/declarative/qdeclarativev4/tst_qdeclarativev4.cpp +++ b/tests/auto/declarative/qdeclarativev4/tst_qdeclarativev4.cpp @@ -72,6 +72,7 @@ private slots: void unnecessaryReeval(); void logicalOr(); + void conditionalExpr(); void qtscript(); void qtscript_data(); void nestedObjectAccess(); @@ -121,6 +122,7 @@ void tst_qdeclarativev4::qtscript_data() QTest::newRow("qreal -> int rounding") << "qrealToIntRounding.qml"; QTest::newRow("exception on fetch") << "fetchException.qml"; QTest::newRow("logical or") << "logicalOr.qml"; + QTest::newRow("conditional expressions") << "conditionalExpr.qml"; QTest::newRow("double bool jump") << "doubleBoolJump.qml"; QTest::newRow("unary minus") << "unaryMinus.qml"; QTest::newRow("null qobject") << "nullQObject.qml"; @@ -188,6 +190,22 @@ void tst_qdeclarativev4::logicalOr() } } +void tst_qdeclarativev4::conditionalExpr() +{ + { + QDeclarativeComponent component(&engine, TEST_FILE("conditionalExpr.qml")); + + QObject *o = component.create(); + QVERIFY(o != 0); + + ResultObject *ro = qobject_cast<ResultObject *>(o); + QVERIFY(ro != 0); + + QCOMPARE(ro->result(), 0); + delete o; + } +} + // This would previously use the metaObject of the root element to result the nested access. // That is, the index for accessing "result" would have been RootObject::result, instead of // NestedObject::result. |