/**************************************************************************** ** ** Copyright (C) 2012 Digia Plc ** All rights reserved. ** For any questions to Digia, please use contact form at http://qt.digia.com ** ** This file is part of the Qt Commercial Charts Add-on. ** ** $QT_BEGIN_LICENSE$ ** Licensees holding valid Qt Commercial licenses may use this file in ** accordance with the Qt Commercial License Agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. ** ** If you have questions regarding the use of this file, please use ** contact form at http://qt.digia.com ** $QT_END_LICENSE$ ** ****************************************************************************/ #include #include #include QTCOMMERCIALCHART_USE_NAMESPACE class tst_QBarSeries : public QObject { Q_OBJECT public slots: void initTestCase(); void cleanupTestCase(); void init(); void cleanup(); private slots: void qbarseries_data(); void qbarseries(); void type_data(); void type(); void appendBarSet_data(); void appendBarSet(); void removeBarSet_data(); void removeBarSet(); void appendBarSets_data(); void appendBarSets(); void removeBarSets_data(); void removeBarSets(); void barsetCount_data(); void barsetCount(); void categoryCount_data(); void categoryCount(); void barSets_data(); void barSets(); void categories_data(); void categories(); void setLabelsVisible_data(); void setLabelsVisible(); private: QBarSeries* m_barseries; QBarSeries* m_barseries_with_sets; QList m_testSets; QBarCategories m_categories; }; void tst_QBarSeries::initTestCase() { } void tst_QBarSeries::cleanupTestCase() { } void tst_QBarSeries::init() { m_categories << "category0" << "category1" << "category2"; m_barseries = new QBarSeries(m_categories); m_barseries_with_sets = new QBarSeries(m_categories); for (int i=0; i<5; i++) { m_testSets.append(new QBarSet("testset")); m_barseries_with_sets->appendBarSet(m_testSets.at(i)); } } void tst_QBarSeries::cleanup() { foreach(QBarSet* s, m_testSets) { m_barseries_with_sets->removeBarSet(s); delete s; } m_testSets.clear(); delete m_barseries; m_barseries = 0; delete m_barseries_with_sets; m_barseries_with_sets = 0; m_categories.clear(); } void tst_QBarSeries::qbarseries_data() { QTest::addColumn ("categories"); QBarCategories c; c << "category0" << "category1" << "category2"; QTest::newRow("categories") << c; } void tst_QBarSeries::qbarseries() { QFETCH(QBarCategories, categories); QBarSeries *barseries = new QBarSeries(categories); QVERIFY(barseries != 0); QBarCategories verifyCategories = barseries->categories(); QVERIFY(verifyCategories.count() == categories.count()); for (int i=0; itype() == QAbstractSeries::SeriesTypeBar); } void tst_QBarSeries::appendBarSet_data() { } void tst_QBarSeries::appendBarSet() { QVERIFY(m_barseries->barsetCount() == 0); QBarSet *barset = new QBarSet("testset"); m_barseries->appendBarSet(barset); QVERIFY(m_barseries->barsetCount() == 1); QBarSet *barset2 = new QBarSet("testset2"); m_barseries->appendBarSet(barset2); QVERIFY(m_barseries->barsetCount() == 2); } void tst_QBarSeries::removeBarSet_data() { } void tst_QBarSeries::removeBarSet() { int count = m_testSets.count(); QVERIFY(m_barseries_with_sets->barsetCount() == count); // remove some sets m_barseries_with_sets->removeBarSet(m_testSets.at(2)); m_barseries_with_sets->removeBarSet(m_testSets.at(3)); m_barseries_with_sets->removeBarSet(m_testSets.at(4)); QVERIFY(m_barseries_with_sets->barsetCount() == 2); QList verifysets = m_barseries_with_sets->barSets(); QVERIFY(verifysets.at(0) == m_testSets.at(0)); QVERIFY(verifysets.at(1) == m_testSets.at(1)); // Try removing all sets again for (int i=0; iremoveBarSet(m_testSets.at(i)); } QVERIFY(m_barseries_with_sets->barsetCount() == 0); } void tst_QBarSeries::appendBarSets_data() { } void tst_QBarSeries::appendBarSets() { int count = 5; QVERIFY(m_barseries->barsetCount() == 0); QList sets; for (int i=0; iappendBarSets(sets); QVERIFY(m_barseries->barsetCount() == count); } void tst_QBarSeries::removeBarSets_data() { } void tst_QBarSeries::removeBarSets() { int count = m_testSets.count(); QVERIFY(m_barseries_with_sets->barsetCount() == count); // Try removing empty list of sets QList empty; m_barseries_with_sets->removeBarSets(empty); QVERIFY(m_barseries_with_sets->barsetCount() == count); // remove all sets m_barseries_with_sets->removeBarSets(m_testSets); QVERIFY(m_barseries_with_sets->barsetCount() == 0); // Try removing empty list again m_barseries_with_sets->removeBarSets(empty); QVERIFY(m_barseries_with_sets->barsetCount() == 0); // remove all sets again m_barseries_with_sets->removeBarSets(m_testSets); QVERIFY(m_barseries_with_sets->barsetCount() == 0); } void tst_QBarSeries::barsetCount_data() { } void tst_QBarSeries::barsetCount() { QVERIFY(m_barseries->barsetCount() == 0); QVERIFY(m_barseries_with_sets->barsetCount() == m_testSets.count()); } void tst_QBarSeries::categoryCount_data() { } void tst_QBarSeries::categoryCount() { QVERIFY(m_barseries->categoryCount() == m_categories.count()); QVERIFY(m_barseries_with_sets->categoryCount() == m_categories.count()); } void tst_QBarSeries::barSets_data() { } void tst_QBarSeries::barSets() { QVERIFY(m_barseries->barSets().count() == 0); QList sets = m_barseries_with_sets->barSets(); QVERIFY(sets.count() == m_testSets.count()); for (int i=0; icategories(); QVERIFY(categories.count() == m_categories.count()); for (int i=0; ilabelsVisible() == false); } m_barseries_with_sets->setLabelsVisible(true); foreach (QBarSet* s, m_testSets) { QVERIFY(s->labelsVisible() == true); } m_barseries_with_sets->setLabelsVisible(false); foreach (QBarSet* s, m_testSets) { QVERIFY(s->labelsVisible() == false); } } /* void setLabelsVisible(bool visible = true); bool setModel(QAbstractItemModel *model); void setModelMapping(int categories, int bottomBoundary, int topBoundary, Qt::Orientation orientation = Qt::Vertical); void setModelMappingRange(int first, int count = -1); */ QTEST_MAIN(tst_QBarSeries) #include "tst_qbarseries.moc"